Finish script_menu code decomp
This commit is contained in:
-1330
File diff suppressed because it is too large
Load Diff
+13
-7
@@ -1033,19 +1033,25 @@ gUnknown_83E0738:: @ 83E0738
|
|||||||
gUnknown_83E0748:: @ 83E0748
|
gUnknown_83E0748:: @ 83E0748
|
||||||
.incbin "baserom.gba", 0x3E0748, 0x20
|
.incbin "baserom.gba", 0x3E0748, 0x20
|
||||||
|
|
||||||
gUnknown_83E0768:: @ 83E0768
|
sMuseumFossilSprTemplate:: @ 83E0768
|
||||||
.incbin "baserom.gba", 0x3E0768, 0x818
|
.incbin "baserom.gba", 0x3E0768, 0x18
|
||||||
|
|
||||||
gUnknown_83E0F80:: @ 83E0F80
|
gUnknown_83E7080::
|
||||||
.incbin "baserom.gba", 0x3E0F80, 0x820
|
.incbin "baserom.gba", 0x3E0780, 0x800
|
||||||
|
|
||||||
gUnknown_83E17A0:: @ 83E17A0
|
sMuseumAerodactylSprPalette:: @ 83E0F80
|
||||||
|
.incbin "baserom.gba", 0x3E0F80, 0x20
|
||||||
|
|
||||||
|
gUnknown_83E0FA0::
|
||||||
|
.incbin "baserom.gba", 0x3E0FA0, 0x800
|
||||||
|
|
||||||
|
sMuseumKabutopsSprPalette:: @ 83E17A0
|
||||||
.incbin "baserom.gba", 0x3E17A0, 0x20
|
.incbin "baserom.gba", 0x3E17A0, 0x20
|
||||||
|
|
||||||
gUnknown_83E17C0:: @ 83E17C0
|
sMuseumKabutopsSprSheets:: @ 83E17C0
|
||||||
.incbin "baserom.gba", 0x3E17C0, 0x10
|
.incbin "baserom.gba", 0x3E17C0, 0x10
|
||||||
|
|
||||||
gUnknown_83E17D0:: @ 83E17D0
|
sMuseumAerodactylSprSheets:: @ 83E17D0
|
||||||
.incbin "baserom.gba", 0x3E17D0, 0x10
|
.incbin "baserom.gba", 0x3E17D0, 0x10
|
||||||
|
|
||||||
gUnknown_83E17E0:: @ 83E17E0
|
gUnknown_83E17E0:: @ 83E17E0
|
||||||
|
|||||||
@@ -190,9 +190,9 @@ PewterCity_Museum_1F_EventScript_16A512:: @ 816A512
|
|||||||
setvar VAR_0x8004, SPECIES_AERODACTYL
|
setvar VAR_0x8004, SPECIES_AERODACTYL
|
||||||
setvar VAR_0x8005, 10
|
setvar VAR_0x8005, 10
|
||||||
setvar VAR_0x8006, 3
|
setvar VAR_0x8006, 3
|
||||||
special sub_809D504
|
special Special_OpenMuseumFossilPic
|
||||||
msgbox gUnknown_8190945
|
msgbox gUnknown_8190945
|
||||||
special sub_809D620
|
special Special_CloseMuseumFossilPic
|
||||||
releaseall
|
releaseall
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -201,8 +201,8 @@ PewterCity_Museum_1F_EventScript_16A532:: @ 816A532
|
|||||||
setvar VAR_0x8004, SPECIES_KABUTOPS
|
setvar VAR_0x8004, SPECIES_KABUTOPS
|
||||||
setvar VAR_0x8005, 10
|
setvar VAR_0x8005, 10
|
||||||
setvar VAR_0x8006, 3
|
setvar VAR_0x8006, 3
|
||||||
special sub_809D504
|
special Special_OpenMuseumFossilPic
|
||||||
msgbox gUnknown_8190975
|
msgbox gUnknown_8190975
|
||||||
special sub_809D620
|
special Special_CloseMuseumFossilPic
|
||||||
releaseall
|
releaseall
|
||||||
end
|
end
|
||||||
|
|||||||
+2
-2
@@ -403,8 +403,8 @@ gSpecials:: @ 815FD60
|
|||||||
def_special sub_8112364
|
def_special sub_8112364
|
||||||
def_special Special_GetMENewsJisanItemAndState
|
def_special Special_GetMENewsJisanItemAndState
|
||||||
def_special get_unknown_box_id
|
def_special get_unknown_box_id
|
||||||
def_special sub_809D504
|
def_special Special_OpenMuseumFossilPic
|
||||||
def_special sub_809D620
|
def_special Special_CloseMuseumFossilPic
|
||||||
def_special sub_812781C
|
def_special sub_812781C
|
||||||
def_special sub_8127888
|
def_special sub_8127888
|
||||||
def_special sub_80803FC
|
def_special sub_80803FC
|
||||||
|
|||||||
@@ -1168,4 +1168,7 @@ extern const u8 gText_SavingDontTurnOffThePower[];
|
|||||||
extern const u8 gText_PlayerSavedTheGame[];
|
extern const u8 gText_PlayerSavedTheGame[];
|
||||||
extern const u8 gText_DifferentGameFile[];
|
extern const u8 gText_DifferentGameFile[];
|
||||||
|
|
||||||
|
// script_menu
|
||||||
|
extern const u8 EventScript_1A7AE0[];
|
||||||
|
|
||||||
#endif //GUARD_EVENT_SCRIPTS_H
|
#endif //GUARD_EVENT_SCRIPTS_H
|
||||||
|
|||||||
@@ -21,5 +21,7 @@ void sub_8084784(u8 a0, u8 a1);
|
|||||||
void sub_8084F2C(u8 a0);
|
void sub_8084F2C(u8 a0);
|
||||||
void sub_80853CC(u8 a0);
|
void sub_80853CC(u8 a0);
|
||||||
void sub_8083598(u8 a0);
|
void sub_8083598(u8 a0);
|
||||||
|
void sub_8083A5C(struct Sprite * sprite, u8 spriteId);
|
||||||
|
u8 sub_8083970(u16 species, s16 x, s16 y, bool8 unused);
|
||||||
|
|
||||||
#endif //GUARD_FIELD_EFFECTS_H
|
#endif //GUARD_FIELD_EFFECTS_H
|
||||||
|
|||||||
+1
-1
@@ -25,7 +25,7 @@ void sub_8113550(u16, const u16 *);
|
|||||||
void sub_811539C(void);
|
void sub_811539C(void);
|
||||||
void sub_8115748(u16);
|
void sub_8115748(u16);
|
||||||
u8 sub_8112CAC(void);
|
u8 sub_8112CAC(void);
|
||||||
bool8 sub_81119D4(void (*func)(void));
|
bool8 QuestLog_ScheduleRoutineIfNotInPlaybackMode(void (*func)(void));
|
||||||
void sub_8111F38(u16, u16);
|
void sub_8111F38(u16, u16);
|
||||||
void sub_8111134(void);
|
void sub_8111134(void);
|
||||||
void DestroyHelpMessageWindow(u8 a0);
|
void DestroyHelpMessageWindow(u8 a0);
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ bool8 ScriptMenu_MultichoiceWithDefault(u8 left, u8 top, u8 var3, u8 var4, u8 va
|
|||||||
bool8 ScriptMenu_YesNo(u8 var1, u8 var2);
|
bool8 ScriptMenu_YesNo(u8 var1, u8 var2);
|
||||||
bool8 ScriptMenu_MultichoiceGrid(u8 left, u8 top, u8 multichoiceId, u8 a4, u8 columnCount);
|
bool8 ScriptMenu_MultichoiceGrid(u8 left, u8 top, u8 multichoiceId, u8 a4, u8 columnCount);
|
||||||
bool8 ScriptMenu_ShowPokemonPic(u16 var1, u8 var2, u8 var3);
|
bool8 ScriptMenu_ShowPokemonPic(u16 var1, u8 var2, u8 var3);
|
||||||
bool32 ScrSpecial_CreatePCMenu(void);
|
bool8 ScrSpecial_CreatePCMenu(void);
|
||||||
void ScriptMenu_DisplayPCStartupPrompt(void);
|
void ScriptMenu_DisplayPCStartupPrompt(void);
|
||||||
|
|
||||||
bool8 (*ScriptMenu_GetPicboxWaitFunc(void))(void);
|
bool8 (*ScriptMenu_GetPicboxWaitFunc(void))(void);
|
||||||
|
|||||||
@@ -521,4 +521,14 @@ extern const u8 gUnknown_8418142[];
|
|||||||
extern const u8 gUnknown_8418152[];
|
extern const u8 gUnknown_8418152[];
|
||||||
extern const u8 gUnknown_8418163[];
|
extern const u8 gUnknown_8418163[];
|
||||||
|
|
||||||
|
// script_menu
|
||||||
|
extern const u8 gUnknown_8417B9F[];
|
||||||
|
extern const u8 gUnknown_8417BAC[];
|
||||||
|
extern const u8 gUnknown_8417BB6[];
|
||||||
|
extern const u8 gUnknown_8417BBE[];
|
||||||
|
extern const u8 gUnknown_8417BCB[];
|
||||||
|
extern const u8 gUnknown_8417BD3[];
|
||||||
|
extern const u8 gUnknown_8417DED[];
|
||||||
|
extern const u8 gUnknown_81A508A[];
|
||||||
|
|
||||||
#endif //GUARD_STRINGS_H
|
#endif //GUARD_STRINGS_H
|
||||||
|
|||||||
@@ -142,7 +142,6 @@ SECTIONS {
|
|||||||
asm/shop.o(.text);
|
asm/shop.o(.text);
|
||||||
src/berry.o(.text);
|
src/berry.o(.text);
|
||||||
src/script_menu.o(.text);
|
src/script_menu.o(.text);
|
||||||
asm/script_menu.o(.text);
|
|
||||||
asm/naming_screen.o(.text);
|
asm/naming_screen.o(.text);
|
||||||
src/money.o(.text);
|
src/money.o(.text);
|
||||||
asm/script_pokemon_util_80A0058.o(.text);
|
asm/script_pokemon_util_80A0058.o(.text);
|
||||||
|
|||||||
+1
-1
@@ -111,7 +111,7 @@ void sub_815F094(void)
|
|||||||
{
|
{
|
||||||
struct WindowTemplate template;
|
struct WindowTemplate template;
|
||||||
|
|
||||||
if (sub_81119D4(sub_809D6D4) != TRUE)
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
{
|
{
|
||||||
template = SetWindowTemplateFields(0, 1, 1, 8, 3, 15, 32);
|
template = SetWindowTemplateFields(0, 1, 1, 8, 3, 15, 32);
|
||||||
gUnknown_203F464 = AddWindow(&template);
|
gUnknown_203F464 = AddWindow(&template);
|
||||||
|
|||||||
@@ -1064,7 +1064,7 @@ void Special_DrawElevatorCurrentFloorWindow(void)
|
|||||||
{
|
{
|
||||||
const u8 *floorname;
|
const u8 *floorname;
|
||||||
u32 strwidth;
|
u32 strwidth;
|
||||||
if (sub_81119D4(sub_809D6D4) != TRUE)
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
{
|
{
|
||||||
sElevatorCurrentFloorWindowId = AddWindow(&sElevatorCurrentFloorWindowTemplate);
|
sElevatorCurrentFloorWindowId = AddWindow(&sElevatorCurrentFloorWindowTemplate);
|
||||||
TextWindow_SetStdFrame0_WithPal(sElevatorCurrentFloorWindowId, 0x21D, 0xD0);
|
TextWindow_SetStdFrame0_WithPal(sElevatorCurrentFloorWindowId, 0x21D, 0xD0);
|
||||||
@@ -1137,7 +1137,7 @@ void Special_ListMenu(void)
|
|||||||
{
|
{
|
||||||
u8 taskId;
|
u8 taskId;
|
||||||
struct Task * task;
|
struct Task * task;
|
||||||
if (sub_81119D4(sub_809D6D4) != TRUE)
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
{
|
{
|
||||||
taskId = CreateTask(Task_CreateScriptListMenu, 8);
|
taskId = CreateTask(Task_CreateScriptListMenu, 8);
|
||||||
task = &gTasks[taskId];
|
task = &gTasks[taskId];
|
||||||
|
|||||||
+337
-337
@@ -813,13 +813,13 @@ static bool8 sub_8110E68(struct UnkStruct_203AE98 * a0)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
switch (a0[i].unk_6)
|
switch (a0[i].unk_6)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
case 1:
|
case 1:
|
||||||
gUnknown_203AE08 = sub_8113D48(gUnknown_203AE08, &a0[i]);
|
gUnknown_203AE08 = sub_8113D48(gUnknown_203AE08, &a0[i]);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
gUnknown_203AE08 = sub_8113CC8(gUnknown_203AE08, &a0[i]);
|
gUnknown_203AE08 = sub_8113CC8(gUnknown_203AE08, &a0[i]);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (gUnknown_203AE08 == NULL)
|
if (gUnknown_203AE08 == NULL)
|
||||||
{
|
{
|
||||||
@@ -1176,29 +1176,29 @@ static void sub_811175C(u8 a0, struct UnkStruct_203AE98 * a1)
|
|||||||
{
|
{
|
||||||
switch (r4[0] & 0xFFF)
|
switch (r4[0] & 0xFFF)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
r4 = sub_8113D08(r4, &a1[r6]);
|
r4 = sub_8113D08(r4, &a1[r6]);
|
||||||
r6++;
|
r6++;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
case 2:
|
case 2:
|
||||||
r4 = sub_8113D94(r4, &a1[r6]);
|
r4 = sub_8113D94(r4, &a1[r6]);
|
||||||
r6++;
|
r6++;
|
||||||
break;
|
break;
|
||||||
case 39:
|
case 39:
|
||||||
r4 = sub_8113C20(r4, &a1[r6]);
|
r4 = sub_8113C20(r4, &a1[r6]);
|
||||||
r6++;
|
r6++;
|
||||||
break;
|
break;
|
||||||
case 41:
|
case 41:
|
||||||
r4 = sub_8113C8C(r4, &a1[r6]);
|
r4 = sub_8113C8C(r4, &a1[r6]);
|
||||||
r6++;
|
r6++;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
r4 = sub_8113A78(r4, &gUnknown_203AE0C[r9]);
|
r4 = sub_8113A78(r4, &gUnknown_203AE0C[r9]);
|
||||||
if (r9 == 0)
|
if (r9 == 0)
|
||||||
sub_8113ABC(gUnknown_203AE0C[0]);
|
sub_8113ABC(gUnknown_203AE0C[0]);
|
||||||
r9++;
|
r9++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (r4 == NULL)
|
if (r4 == NULL)
|
||||||
break;
|
break;
|
||||||
@@ -1246,7 +1246,7 @@ void sub_81119C8(void)
|
|||||||
sub_8111914();
|
sub_8111914();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool8 sub_81119D4(void (*a0)(void))
|
bool8 QuestLog_ScheduleRoutineIfNotInPlaybackMode(void (*a0)(void))
|
||||||
{
|
{
|
||||||
u8 taskId;
|
u8 taskId;
|
||||||
|
|
||||||
@@ -1260,7 +1260,7 @@ bool8 sub_81119D4(void (*a0)(void))
|
|||||||
taskId = CreateTask(sub_8111A34, 80);
|
taskId = CreateTask(sub_8111A34, 80);
|
||||||
gTasks[taskId].data[0] = 0;
|
gTasks[taskId].data[0] = 0;
|
||||||
gTasks[taskId].data[1] = 0;
|
gTasks[taskId].data[1] = 0;
|
||||||
SetWordTaskArg(taskId, 14, (u32)a0);
|
SetWordTaskArg(taskId, 14, (uintptr_t)a0);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@@ -1273,25 +1273,25 @@ static void sub_8111A34(u8 taskId)
|
|||||||
|
|
||||||
switch (data[1])
|
switch (data[1])
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
if (++data[0] == 0x7F)
|
if (++data[0] == 0x7F)
|
||||||
{
|
{
|
||||||
BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, 0);
|
BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, 0);
|
||||||
gUnknown_203AE94.unk_0_6 = 2;
|
gUnknown_203AE94.unk_0_6 = 2;
|
||||||
data[1]++;
|
data[1]++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if (!gPaletteFade.active)
|
if (!gPaletteFade.active)
|
||||||
{
|
{
|
||||||
gUnknown_3005E88 = 0;
|
gUnknown_3005E88 = 0;
|
||||||
routine = (void (*)(void)) GetWordTaskArg(taskId, 14);
|
routine = (void (*)(void)) GetWordTaskArg(taskId, 14);
|
||||||
if (routine != NULL)
|
if (routine != NULL)
|
||||||
routine();
|
routine();
|
||||||
DestroyTask(taskId);
|
DestroyTask(taskId);
|
||||||
gUnknown_203AE8C = sub_8111914;
|
gUnknown_203AE8C = sub_8111914;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1431,15 +1431,15 @@ static void sub_8111D90(u8 a0)
|
|||||||
{
|
{
|
||||||
switch (i)
|
switch (i)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
y = 1;
|
y = 1;
|
||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
y = 0;
|
y = 0;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
y = 2;
|
y = 2;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// r6 = y * 32
|
// r6 = y * 32
|
||||||
@@ -1563,46 +1563,46 @@ static void sub_81120AC(u8 taskId)
|
|||||||
|
|
||||||
switch (data[0])
|
switch (data[0])
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
gDisableMapMusicChangeOnMapLoad = 0;
|
gDisableMapMusicChangeOnMapLoad = 0;
|
||||||
Overworld_PlaySpecialMapMusic();
|
Overworld_PlaySpecialMapMusic();
|
||||||
sub_811229C();
|
sub_811229C();
|
||||||
FillWindowPixelRect(gUnknown_203ADFE[0], 0xF, 0, 0, gUnknown_845661C[0].width * 8, gUnknown_845661C[0].height * 8);
|
FillWindowPixelRect(gUnknown_203ADFE[0], 0xF, 0, 0, gUnknown_845661C[0].width * 8, gUnknown_845661C[0].height * 8);
|
||||||
data[0]++;
|
data[0]++;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if (sub_81121D8(taskId))
|
if (sub_81121D8(taskId))
|
||||||
|
{
|
||||||
|
for (i = 0; i < 3; i++)
|
||||||
{
|
{
|
||||||
for (i = 0; i < 3; i++)
|
ClearWindowTilemap(gUnknown_203ADFE[i]);
|
||||||
{
|
CopyWindowToVram(gUnknown_203ADFE[i], 1);
|
||||||
ClearWindowTilemap(gUnknown_203ADFE[i]);
|
RemoveWindow(gUnknown_203ADFE[i]);
|
||||||
CopyWindowToVram(gUnknown_203ADFE[i], 1);
|
|
||||||
RemoveWindow(gUnknown_203ADFE[i]);
|
|
||||||
}
|
|
||||||
data[1] = 0;
|
|
||||||
data[0]++;
|
|
||||||
}
|
}
|
||||||
break;
|
data[1] = 0;
|
||||||
case 2:
|
data[0]++;
|
||||||
if (data[1] < 32)
|
}
|
||||||
data[1]++;
|
break;
|
||||||
else
|
case 2:
|
||||||
data[0]++;
|
if (data[1] < 32)
|
||||||
break;
|
data[1]++;
|
||||||
default:
|
else
|
||||||
if (gUnknown_203AE94.unk_0_6 == 1)
|
data[0]++;
|
||||||
sub_8098110(1);
|
break;
|
||||||
CpuCopy16(gUnknown_203AE90, gPlttBufferUnfaded, 0x400);
|
default:
|
||||||
Free(gUnknown_203AE90);
|
if (gUnknown_203AE94.unk_0_6 == 1)
|
||||||
gUnknown_203AE94 = (struct UnkStruct_203AE94){};
|
sub_8098110(1);
|
||||||
sub_80696C0();
|
CpuCopy16(gUnknown_203AE90, gPlttBufferUnfaded, 0x400);
|
||||||
ScriptContext2_Disable();
|
Free(gUnknown_203AE90);
|
||||||
gTextFlags.autoScroll = FALSE;
|
gUnknown_203AE94 = (struct UnkStruct_203AE94){};
|
||||||
gUnknown_2036E28 = 0;
|
sub_80696C0();
|
||||||
sub_8082740(0);
|
ScriptContext2_Disable();
|
||||||
gHelpSystemEnabled = TRUE;
|
gTextFlags.autoScroll = FALSE;
|
||||||
DestroyTask(taskId);
|
gUnknown_2036E28 = 0;
|
||||||
break;
|
sub_8082740(0);
|
||||||
|
gHelpSystemEnabled = TRUE;
|
||||||
|
DestroyTask(taskId);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1834,14 +1834,14 @@ static void sub_8112888(u8 a0)
|
|||||||
{
|
{
|
||||||
switch (a0)
|
switch (a0)
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
if (gUnknown_3005E88 == 1)
|
if (gUnknown_3005E88 == 1)
|
||||||
gUnknown_3005E88 = 3;
|
gUnknown_3005E88 = 3;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if (gUnknown_3005E88 == 3)
|
if (gUnknown_3005E88 == 3)
|
||||||
gUnknown_3005E88 = 1;
|
gUnknown_3005E88 = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1851,24 +1851,24 @@ void sub_81128BC(u8 a0)
|
|||||||
|
|
||||||
switch (a0)
|
switch (a0)
|
||||||
{
|
{
|
||||||
case 1:
|
case 1:
|
||||||
if (r1 == 1)
|
if (r1 == 1)
|
||||||
gUnknown_3005E88 = 3;
|
gUnknown_3005E88 = 3;
|
||||||
else if (r1 == 2)
|
else if (r1 == 2)
|
||||||
{
|
{
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_4 = gUnknown_203B01A;
|
gUnknown_3005E94[sQuestLogIdx].unk_4 = gUnknown_203B01A;
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_6 = 3;
|
gUnknown_3005E94[sQuestLogIdx].unk_6 = 3;
|
||||||
sQuestLogIdx++;
|
sQuestLogIdx++;
|
||||||
gUnknown_203B01A = 0;
|
gUnknown_203B01A = 0;
|
||||||
gUnknown_3005E88 = 4;
|
gUnknown_3005E88 = 4;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if (r1 == 1)
|
if (r1 == 1)
|
||||||
gUnknown_3005E88 = 1;
|
gUnknown_3005E88 = 1;
|
||||||
else if (r1 == 2)
|
else if (r1 == 2)
|
||||||
gUnknown_3005E88 = 2;
|
gUnknown_3005E88 = 2;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1878,64 +1878,64 @@ static void sub_8112940(u8 a0, struct UnkStruct_203AE98 *a1, u16 a2)
|
|||||||
|
|
||||||
switch (a0)
|
switch (a0)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
gUnknown_3005E88 = 0;
|
gUnknown_3005E88 = 0;
|
||||||
break;
|
break;
|
||||||
|
case 1:
|
||||||
|
gUnknown_3005E94 = a1;
|
||||||
|
sNumQuestLogs = a2 / 8;
|
||||||
|
for (i = 0; i < 0x40; i++)
|
||||||
|
{
|
||||||
|
gUnknown_203AF9A[i][0] |= 0xFF;
|
||||||
|
gUnknown_203AF9A[i][1] |= 0xFF;
|
||||||
|
}
|
||||||
|
sQuestLogIdx = 0;
|
||||||
|
gUnknown_203B01C = 0;
|
||||||
|
gUnknown_3005E90 = (struct UnkStruct_3005E90){};
|
||||||
|
gUnknown_203B01A = gUnknown_3005E94[sQuestLogIdx].unk_4;
|
||||||
|
gUnknown_203AF9A[0][0] = gUnknown_3005E94[sQuestLogIdx].unk_3;
|
||||||
|
gUnknown_203AF9A[0][1] = 0xFF;
|
||||||
|
gUnknown_3005E88 = 1;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
gUnknown_3005E94 = a1;
|
||||||
|
sNumQuestLogs = a2 / 8;
|
||||||
|
for (i = 0; i < sNumQuestLogs; i++)
|
||||||
|
{
|
||||||
|
gUnknown_3005E94[i] = (struct UnkStruct_203AE98){ 0, 0, 0, 0, 0xFFFF, 0xFF };
|
||||||
|
}
|
||||||
|
sQuestLogIdx = 0;
|
||||||
|
gUnknown_203B01A = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_4 = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_6 = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_0 = 0;
|
||||||
|
switch (GetPlayerFacingDirection())
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
case 1:
|
case 1:
|
||||||
gUnknown_3005E94 = a1;
|
gUnknown_3005E94[sQuestLogIdx].unk_3 = 0;
|
||||||
sNumQuestLogs = a2 / 8;
|
break;
|
||||||
for (i = 0; i < 0x40; i++)
|
case 4:
|
||||||
{
|
gUnknown_3005E94[sQuestLogIdx].unk_3 = 3;
|
||||||
gUnknown_203AF9A[i][0] |= 0xFF;
|
|
||||||
gUnknown_203AF9A[i][1] |= 0xFF;
|
|
||||||
}
|
|
||||||
sQuestLogIdx = 0;
|
|
||||||
gUnknown_203B01C = 0;
|
|
||||||
gUnknown_3005E90 = (struct UnkStruct_3005E90){};
|
|
||||||
gUnknown_203B01A = gUnknown_3005E94[sQuestLogIdx].unk_4;
|
|
||||||
gUnknown_203AF9A[0][0] = gUnknown_3005E94[sQuestLogIdx].unk_3;
|
|
||||||
gUnknown_203AF9A[0][1] = 0xFF;
|
|
||||||
gUnknown_3005E88 = 1;
|
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
gUnknown_3005E94 = a1;
|
gUnknown_3005E94[sQuestLogIdx].unk_3 = 1;
|
||||||
sNumQuestLogs = a2 / 8;
|
|
||||||
for (i = 0; i < sNumQuestLogs; i++)
|
|
||||||
{
|
|
||||||
gUnknown_3005E94[i] = (struct UnkStruct_203AE98){ 0, 0, 0, 0, 0xFFFF, 0xFF };
|
|
||||||
}
|
|
||||||
sQuestLogIdx = 0;
|
|
||||||
gUnknown_203B01A = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_4 = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_6 = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_0 = 0;
|
|
||||||
switch (GetPlayerFacingDirection())
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
case 1:
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_3 = 0;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_3 = 3;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_3 = 1;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_3 = 2;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
gUnknown_203B01C = 0;
|
|
||||||
sQuestLogIdx++;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_4 = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_6 = 2;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_0 = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_1 = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_2 = 0;
|
|
||||||
gUnknown_3005E94[sQuestLogIdx].unk_3 = 0;
|
|
||||||
sQuestLogIdx++;
|
|
||||||
gUnknown_3005E88 = 2;
|
|
||||||
break;
|
break;
|
||||||
|
case 3:
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_3 = 2;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
gUnknown_203B01C = 0;
|
||||||
|
sQuestLogIdx++;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_4 = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_6 = 2;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_0 = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_1 = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_2 = 0;
|
||||||
|
gUnknown_3005E94[sQuestLogIdx].unk_3 = 0;
|
||||||
|
sQuestLogIdx++;
|
||||||
|
gUnknown_3005E88 = 2;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1944,67 +1944,67 @@ void sub_8112B3C(void)
|
|||||||
{
|
{
|
||||||
switch (gUnknown_3005E88)
|
switch (gUnknown_3005E88)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if (sub_8112CEC())
|
if (sub_8112CEC())
|
||||||
|
{
|
||||||
|
if (gUnknown_203B01A != 0)
|
||||||
|
gUnknown_203B01A--;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
if (gUnknown_203B01A != 0)
|
while (1)
|
||||||
gUnknown_203B01A--;
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
while (1)
|
switch (gUnknown_3005E94[sQuestLogIdx].unk_6)
|
||||||
{
|
{
|
||||||
switch (gUnknown_3005E94[sQuestLogIdx].unk_6)
|
case 0:
|
||||||
{
|
gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][0] = gUnknown_3005E94[sQuestLogIdx].unk_3;
|
||||||
case 0:
|
break;
|
||||||
gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][0] = gUnknown_3005E94[sQuestLogIdx].unk_3;
|
case 1:
|
||||||
break;
|
gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][1] = gUnknown_3005E94[sQuestLogIdx].unk_3;
|
||||||
case 1:
|
break;
|
||||||
gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][1] = gUnknown_3005E94[sQuestLogIdx].unk_3;
|
case 2:
|
||||||
break;
|
*(u32 *)&gUnknown_3005E90 = ((gUnknown_3005E94[sQuestLogIdx].unk_3 << 24) | (gUnknown_3005E94[sQuestLogIdx].unk_2 << 16) | (gUnknown_3005E94[sQuestLogIdx].unk_1 << 8) | (gUnknown_3005E94[sQuestLogIdx].unk_0 << 0));
|
||||||
case 2:
|
break;
|
||||||
*(u32 *)&gUnknown_3005E90 = ((gUnknown_3005E94[sQuestLogIdx].unk_3 << 24) | (gUnknown_3005E94[sQuestLogIdx].unk_2 << 16) | (gUnknown_3005E94[sQuestLogIdx].unk_1 << 8) | (gUnknown_3005E94[sQuestLogIdx].unk_0 << 0));
|
case 3:
|
||||||
break;
|
gUnknown_3005E88 = 3;
|
||||||
case 3:
|
break;
|
||||||
gUnknown_3005E88 = 3;
|
case 0xFE:
|
||||||
break;
|
break;
|
||||||
case 0xFE:
|
case 0xFF:
|
||||||
break;
|
gUnknown_3005E88 = 0;
|
||||||
case 0xFF:
|
break;
|
||||||
gUnknown_3005E88 = 0;
|
}
|
||||||
break;
|
if (gUnknown_3005E88 == 0)
|
||||||
}
|
break;
|
||||||
if (gUnknown_3005E88 == 0)
|
if (++sQuestLogIdx >= sNumQuestLogs)
|
||||||
break;
|
{
|
||||||
if (++sQuestLogIdx >= sNumQuestLogs)
|
gUnknown_3005E88 = 0;
|
||||||
{
|
break;
|
||||||
gUnknown_3005E88 = 0;
|
}
|
||||||
break;
|
gUnknown_203B01A = gUnknown_3005E94[sQuestLogIdx].unk_4;
|
||||||
}
|
if (gUnknown_3005E88 == 3)
|
||||||
gUnknown_203B01A = gUnknown_3005E94[sQuestLogIdx].unk_4;
|
break;
|
||||||
if (gUnknown_3005E88 == 3)
|
if (gUnknown_203B01A == 0)
|
||||||
break;
|
continue;
|
||||||
if (gUnknown_203B01A == 0)
|
if (gUnknown_203B01A == 0xFFFF)
|
||||||
continue;
|
break;
|
||||||
if (gUnknown_203B01A == 0xFFFF)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (sQuestLogIdx >= sNumQuestLogs)
|
}
|
||||||
gUnknown_3005E88 = 0;
|
else if (sQuestLogIdx >= sNumQuestLogs)
|
||||||
break;
|
gUnknown_3005E88 = 0;
|
||||||
case 2:
|
break;
|
||||||
if (ScriptContext2_IsEnabled() != 1)
|
case 2:
|
||||||
gUnknown_203B01A++;
|
if (ScriptContext2_IsEnabled() != 1)
|
||||||
if (sQuestLogIdx >= sNumQuestLogs)
|
gUnknown_203B01A++;
|
||||||
gUnknown_3005E88 = 0;
|
if (sQuestLogIdx >= sNumQuestLogs)
|
||||||
break;
|
gUnknown_3005E88 = 0;
|
||||||
case 3:
|
break;
|
||||||
break;
|
case 3:
|
||||||
case 4:
|
break;
|
||||||
break;
|
case 4:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
@@ -2203,15 +2203,15 @@ u8 sub_8112CAC(void)
|
|||||||
{
|
{
|
||||||
switch (gUnknown_3005E88)
|
switch (gUnknown_3005E88)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
default:
|
default:
|
||||||
return 0;
|
return 0;
|
||||||
case 1:
|
case 1:
|
||||||
case 3:
|
case 3:
|
||||||
return 1;
|
return 1;
|
||||||
case 2:
|
case 2:
|
||||||
case 4:
|
case 4:
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2669,27 +2669,27 @@ void BufferStreakTrainerText(void)
|
|||||||
|
|
||||||
switch (gSpecialVar_0x8004)
|
switch (gSpecialVar_0x8004)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
r2 = 0;
|
r2 = 0;
|
||||||
r3 = 0;
|
r3 = 0;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
case 2:
|
case 2:
|
||||||
case 3:
|
case 3:
|
||||||
case 7:
|
case 7:
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
r2 = 1;
|
r2 = 1;
|
||||||
r3 = 0;
|
r3 = 0;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
r2 = 0;
|
r2 = 0;
|
||||||
r3 = 1;
|
r3 = 1;
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
r2 = 2;
|
r2 = 2;
|
||||||
r3 = 1;
|
r3 = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
sub_8113414(&gSaveBlock2Ptr->linkBattleRecords, r3, r2);
|
sub_8113414(&gSaveBlock2Ptr->linkBattleRecords, r3, r2);
|
||||||
}
|
}
|
||||||
@@ -2702,18 +2702,18 @@ static void sub_8113414(struct LinkBattleRecords * a0, u8 a1, u8 a2)
|
|||||||
{
|
{
|
||||||
switch (a2)
|
switch (a2)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
|
StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
StringCopy(gStringVar1, gUnknown_84178D0); // LT. SURGE
|
StringCopy(gStringVar1, gUnknown_84178D0); // LT. SURGE
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
StringCopy(gStringVar1, gUnknown_84178DA); // KOGA
|
StringCopy(gStringVar1, gUnknown_84178DA); // KOGA
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
|
StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -3703,48 +3703,48 @@ static const u16 *sub_8113FBC(const u16 *a0)
|
|||||||
|
|
||||||
switch (ItemId_GetPocket(r5[0]))
|
switch (ItemId_GetPocket(r5[0]))
|
||||||
{
|
{
|
||||||
case POCKET_ITEMS:
|
case POCKET_ITEMS:
|
||||||
case POCKET_POKE_BALLS:
|
case POCKET_POKE_BALLS:
|
||||||
case POCKET_BERRY_POUCH:
|
case POCKET_BERRY_POUCH:
|
||||||
StringCopy(gStringVar1, ItemId_GetName(r5[0]));
|
StringCopy(gStringVar1, ItemId_GetName(r5[0]));
|
||||||
if (r5[0] == ITEM_ESCAPE_ROPE)
|
if (r5[0] == ITEM_ESCAPE_ROPE)
|
||||||
{
|
{
|
||||||
sub_80C4DF8(gStringVar2, r5[2]);
|
sub_80C4DF8(gStringVar2, r5[2]);
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841AFA6);
|
StringExpandPlaceholders(gStringVar4, gUnknown_841AFA6);
|
||||||
}
|
}
|
||||||
else if (r5[1] != 0xFFFF)
|
else if (r5[1] != 0xFFFF)
|
||||||
{
|
{
|
||||||
QuestLog_AutoGetSpeciesName(r5[1], gStringVar2, 0);
|
QuestLog_AutoGetSpeciesName(r5[1], gStringVar2, 0);
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A1E7);
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A1E7);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A210);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case POCKET_KEY_ITEMS:
|
||||||
|
StringCopy(gStringVar1, ItemId_GetName(r5[0]));
|
||||||
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A220);
|
||||||
|
break;
|
||||||
|
case POCKET_TM_CASE:
|
||||||
|
QuestLog_AutoGetSpeciesName(r5[1], gStringVar1, 0);
|
||||||
|
StringCopy(gStringVar2, gMoveNames[ItemIdToBattleMoveId(r5[0])]);
|
||||||
|
if (r5[2] != 0xFFFF)
|
||||||
|
{
|
||||||
|
StringCopy(gStringVar3, gMoveNames[r5[2]]);
|
||||||
|
if (r5[0] > ITEM_TM50)
|
||||||
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A965);
|
||||||
else
|
else
|
||||||
{
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A277);
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A210);
|
}
|
||||||
}
|
else
|
||||||
break;
|
{
|
||||||
case POCKET_KEY_ITEMS:
|
if (r5[0] > ITEM_TM50)
|
||||||
StringCopy(gStringVar1, ItemId_GetName(r5[0]));
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A938);
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A220);
|
|
||||||
break;
|
|
||||||
case POCKET_TM_CASE:
|
|
||||||
QuestLog_AutoGetSpeciesName(r5[1], gStringVar1, 0);
|
|
||||||
StringCopy(gStringVar2, gMoveNames[ItemIdToBattleMoveId(r5[0])]);
|
|
||||||
if (r5[2] != 0xFFFF)
|
|
||||||
{
|
|
||||||
StringCopy(gStringVar3, gMoveNames[r5[2]]);
|
|
||||||
if (r5[0] > ITEM_TM50)
|
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A965);
|
|
||||||
else
|
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A277);
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
StringExpandPlaceholders(gStringVar4, gUnknown_841A255);
|
||||||
if (r5[0] > ITEM_TM50)
|
}
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A938);
|
break;
|
||||||
else
|
|
||||||
StringExpandPlaceholders(gStringVar4, gUnknown_841A255);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
return r5 + 3;
|
return r5 + 3;
|
||||||
}
|
}
|
||||||
@@ -4442,11 +4442,11 @@ static bool8 sub_8114FBC(u16 a0)
|
|||||||
{
|
{
|
||||||
switch (a0)
|
switch (a0)
|
||||||
{
|
{
|
||||||
case 0x96:
|
case 0x96:
|
||||||
case 0x8F ... 0x92:
|
case 0x8F ... 0x92:
|
||||||
case 0xF9 ... 0xFA:
|
case 0xF9 ... 0xFA:
|
||||||
case 0x19A:
|
case 0x19A:
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@@ -4495,22 +4495,22 @@ static const u16 *sub_81150CC(const u16 *a0)
|
|||||||
|
|
||||||
switch (gUnknown_203B044.unk_2)
|
switch (gUnknown_203B044.unk_2)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock2Ptr->playerName);
|
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock2Ptr->playerName);
|
||||||
DynamicPlaceholderTextUtil_SetPlaceholderPtr(1, gSaveBlock1Ptr->rivalName);
|
DynamicPlaceholderTextUtil_SetPlaceholderPtr(1, gSaveBlock1Ptr->rivalName);
|
||||||
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A2E1);
|
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A2E1);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock1Ptr->rivalName);
|
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock1Ptr->rivalName);
|
||||||
QuestLog_AutoGetSpeciesName(a0[2], NULL, 1);
|
QuestLog_AutoGetSpeciesName(a0[2], NULL, 1);
|
||||||
DynamicPlaceholderTextUtil_SetPlaceholderPtr(2, gSaveBlock2Ptr->playerName);
|
DynamicPlaceholderTextUtil_SetPlaceholderPtr(2, gSaveBlock2Ptr->playerName);
|
||||||
QuestLog_AutoGetSpeciesName(a0[3], NULL, 3);
|
QuestLog_AutoGetSpeciesName(a0[3], NULL, 3);
|
||||||
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A312);
|
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A312);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gUnknown_8456AD8[r5[0]]);
|
DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gUnknown_8456AD8[r5[0]]);
|
||||||
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A349);
|
DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A349);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return (const u16 *)(r5 + 2);
|
return (const u16 *)(r5 + 2);
|
||||||
}
|
}
|
||||||
|
|||||||
+2
-2
@@ -1835,7 +1835,7 @@ bool8 ScrCmd_showmoneybox(struct ScriptContext *ctx)
|
|||||||
u8 y = ScriptReadByte(ctx);
|
u8 y = ScriptReadByte(ctx);
|
||||||
u8 ignore = ScriptReadByte(ctx);
|
u8 ignore = ScriptReadByte(ctx);
|
||||||
|
|
||||||
if (!ignore && sub_81119D4(sub_809D6D4) != TRUE)
|
if (!ignore && QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
DrawMoneyBox(GetMoney(&gSaveBlock1Ptr->money), x, y);
|
DrawMoneyBox(GetMoney(&gSaveBlock1Ptr->money), x, y);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@@ -1865,7 +1865,7 @@ bool8 ScrCmd_showcoinsbox(struct ScriptContext *ctx)
|
|||||||
u8 x = ScriptReadByte(ctx);
|
u8 x = ScriptReadByte(ctx);
|
||||||
u8 y = ScriptReadByte(ctx);
|
u8 y = ScriptReadByte(ctx);
|
||||||
|
|
||||||
if (sub_81119D4(sub_809D6D4) != TRUE)
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
ShowCoinsWindow(GetCoins(), x, y);
|
ShowCoinsWindow(GetCoins(), x, y);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|||||||
+422
-6
@@ -1,7 +1,6 @@
|
|||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "palette.h"
|
#include "palette.h"
|
||||||
#include "text.h"
|
#include "text.h"
|
||||||
#include "list_menu.h"
|
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
#include "task.h"
|
#include "task.h"
|
||||||
#include "sound.h"
|
#include "sound.h"
|
||||||
@@ -11,7 +10,12 @@
|
|||||||
#include "new_menu_helpers.h"
|
#include "new_menu_helpers.h"
|
||||||
#include "event_data.h"
|
#include "event_data.h"
|
||||||
#include "script.h"
|
#include "script.h"
|
||||||
|
#include "strings.h"
|
||||||
|
#include "string_util.h"
|
||||||
|
#include "field_effect.h"
|
||||||
|
#include "event_scripts.h"
|
||||||
#include "constants/songs.h"
|
#include "constants/songs.h"
|
||||||
|
#include "constants/species.h"
|
||||||
|
|
||||||
struct MultichoiceListStruct
|
struct MultichoiceListStruct
|
||||||
{
|
{
|
||||||
@@ -27,6 +31,9 @@ void sub_809CC18(u8 ignoreBpress, u8 count, u8 windowId, u8 mcId);
|
|||||||
void sub_809CC98(u8 taskId);
|
void sub_809CC98(u8 taskId);
|
||||||
void sub_809CD48(u8 mcId);
|
void sub_809CD48(u8 mcId);
|
||||||
void task_yes_no_maybe(u8 taskId);
|
void task_yes_no_maybe(u8 taskId);
|
||||||
|
void sub_809CFDC(u8 taskId);
|
||||||
|
void sub_809D070(void);
|
||||||
|
bool8 sub_809D404(void);
|
||||||
void sub_809D6B0(u8 windowId);
|
void sub_809D6B0(u8 windowId);
|
||||||
u8 CreateWindowFromRect(u8 left, u8 top, u8 width, u8 height);
|
u8 CreateWindowFromRect(u8 left, u8 top, u8 width, u8 height);
|
||||||
|
|
||||||
@@ -34,21 +41,27 @@ extern const u8 *const gUnknown_83E072C[];
|
|||||||
extern const u8 *const gUnknown_83E0738[];
|
extern const u8 *const gUnknown_83E0738[];
|
||||||
extern const u8 *const gUnknown_83E0748[];
|
extern const u8 *const gUnknown_83E0748[];
|
||||||
extern const struct MultichoiceListStruct gUnknown_83E04B0[];
|
extern const struct MultichoiceListStruct gUnknown_83E04B0[];
|
||||||
|
extern const struct SpriteSheet sMuseumKabutopsSprSheets[];
|
||||||
|
extern const u16 sMuseumKabutopsSprPalette[];
|
||||||
|
extern const struct SpriteSheet sMuseumAerodactylSprSheets[];
|
||||||
|
extern const u16 sMuseumAerodactylSprPalette[];
|
||||||
|
extern const struct SpriteTemplate sMuseumFossilSprTemplate;
|
||||||
|
extern const u8 *const gUnknown_83E17E0[];
|
||||||
|
|
||||||
u16 sub_809C954(const u8 *str)
|
u16 sub_809C954(const u8 *str)
|
||||||
{
|
{
|
||||||
return (GetStringWidth(1, str, 0) + 7) / 8;
|
return (GetStringWidth(1, str, 0) + 7) / 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 sub_809C974(const struct ListMenuItem * items, u8 count)
|
u8 sub_809C974(const struct MenuAction * items, u8 count)
|
||||||
{
|
{
|
||||||
u16 i;
|
u16 i;
|
||||||
u8 width = sub_809C954(items[0].label);
|
u8 width = sub_809C954(items[0].text);
|
||||||
u8 tmp;
|
u8 tmp;
|
||||||
|
|
||||||
for (i = 1; i < count; i++)
|
for (i = 1; i < count; i++)
|
||||||
{
|
{
|
||||||
tmp = sub_809C954(items[i].label);
|
tmp = sub_809C954(items[i].text);
|
||||||
if (width < tmp)
|
if (width < tmp)
|
||||||
width = tmp;
|
width = tmp;
|
||||||
}
|
}
|
||||||
@@ -84,7 +97,7 @@ void sub_809CA64(u8 left, u8 top, u8 mcId, u8 ignoreBpress, u8 initPos)
|
|||||||
u8 windowId;
|
u8 windowId;
|
||||||
const struct MenuAction * list;
|
const struct MenuAction * list;
|
||||||
|
|
||||||
if ((ignoreBpress & 2) || sub_81119D4(sub_809D6D4) != TRUE)
|
if ((ignoreBpress & 2) || QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
{
|
{
|
||||||
ignoreBpress &= 1;
|
ignoreBpress &= 1;
|
||||||
count = gUnknown_83E04B0[mcId].count;
|
count = gUnknown_83E04B0[mcId].count;
|
||||||
@@ -218,7 +231,7 @@ bool8 ScriptMenu_YesNo(u8 unused, u8 stuff)
|
|||||||
if (FuncIsActiveTask(task_yes_no_maybe) == TRUE)
|
if (FuncIsActiveTask(task_yes_no_maybe) == TRUE)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
gSpecialVar_Result = 255;
|
gSpecialVar_Result = 255;
|
||||||
if (!sub_81119D4(sub_809D6D4))
|
if (!QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4))
|
||||||
{
|
{
|
||||||
DisplayYesNoMenuDefaultYes();
|
DisplayYesNoMenuDefaultYes();
|
||||||
CreateTask(task_yes_no_maybe, 80);
|
CreateTask(task_yes_no_maybe, 80);
|
||||||
@@ -261,3 +274,406 @@ void task_yes_no_maybe(u8 taskId)
|
|||||||
EnableBothScriptContexts();
|
EnableBothScriptContexts();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool8 ScriptMenu_MultichoiceGrid(u8 left, u8 top, u8 multichoiceId, u8 a4, u8 columnCount)
|
||||||
|
{
|
||||||
|
const struct MenuAction * list;
|
||||||
|
u8 count;
|
||||||
|
u8 width;
|
||||||
|
u8 rowCount;
|
||||||
|
u8 taskId;
|
||||||
|
if (FuncIsActiveTask(sub_809CFDC) == TRUE)
|
||||||
|
return FALSE;
|
||||||
|
gSpecialVar_Result = 255;
|
||||||
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
|
{
|
||||||
|
list = gUnknown_83E04B0[multichoiceId].list;
|
||||||
|
count = gUnknown_83E04B0[multichoiceId].count;
|
||||||
|
width = sub_809C974(list, count) + 1;
|
||||||
|
rowCount = count / columnCount;
|
||||||
|
taskId = CreateTask(sub_809CFDC, 80);
|
||||||
|
gTasks[taskId].data[4] = a4;
|
||||||
|
gTasks[taskId].data[6] = CreateWindowFromRect(left, top, width * columnCount, rowCount * 2);
|
||||||
|
SetStdWindowBorderStyle(gTasks[taskId].data[6], FALSE);
|
||||||
|
MultichoiceGrid_PrintItems(gTasks[taskId].data[6], 1, width * 8, 16, columnCount, rowCount, list);
|
||||||
|
MultichoiceGrid_InitCursor(gTasks[taskId].data[6], 1, 0, 1, width * 8, columnCount, rowCount, 0);
|
||||||
|
ScheduleBgCopyTilemapToVram(0);
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809CFDC(u8 taskId)
|
||||||
|
{
|
||||||
|
s16 *data = gTasks[taskId].data;
|
||||||
|
s8 input = Menu_ProcessInputGridLayout();
|
||||||
|
switch (input)
|
||||||
|
{
|
||||||
|
case -2:
|
||||||
|
return;
|
||||||
|
case -1:
|
||||||
|
if (data[4])
|
||||||
|
return;
|
||||||
|
PlaySE(SE_SELECT);
|
||||||
|
gSpecialVar_Result = 127;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
gSpecialVar_Result = input;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
sub_809D6B0(data[6]);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
EnableBothScriptContexts();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 ScrSpecial_CreatePCMenu(void)
|
||||||
|
{
|
||||||
|
if (FuncIsActiveTask(sub_809CC98) == TRUE)
|
||||||
|
return FALSE;
|
||||||
|
gSpecialVar_Result = 255;
|
||||||
|
sub_809D070();
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D070(void)
|
||||||
|
{
|
||||||
|
u8 cursorWidth = GetMenuCursorDimensionByFont(2, 0);
|
||||||
|
u8 height = GetFontAttribute(2, FONTATTR_MAX_LETTER_HEIGHT);
|
||||||
|
u8 windowWidth;
|
||||||
|
u8 nitems;
|
||||||
|
u8 windowId;
|
||||||
|
switch (sub_809C954(gUnknown_8417BB6))
|
||||||
|
{
|
||||||
|
default:
|
||||||
|
if (FlagGet(FLAG_SYS_POKEDEX_GET))
|
||||||
|
windowWidth = 14;
|
||||||
|
else
|
||||||
|
windowWidth = 13;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
case 10:
|
||||||
|
windowWidth = 14;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (FlagGet(FLAG_SYS_GAME_CLEAR))
|
||||||
|
{
|
||||||
|
nitems = 5;
|
||||||
|
windowId = CreateWindowFromRect(0, 0, windowWidth, 10);
|
||||||
|
SetStdWindowBorderStyle(windowId, FALSE);
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417BD3, cursorWidth, 34, 0xFF, NULL);
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417BBE, cursorWidth, 50, 0xFF, NULL);
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417BCB, cursorWidth, 66, 0xFF, NULL);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (FlagGet(FLAG_SYS_POKEDEX_GET))
|
||||||
|
nitems = 4;
|
||||||
|
else
|
||||||
|
nitems = 3;
|
||||||
|
windowId = CreateWindowFromRect(0, 0, windowWidth, nitems * 2);
|
||||||
|
SetStdWindowBorderStyle(windowId, FALSE);
|
||||||
|
if (FlagGet(FLAG_SYS_POKEDEX_GET))
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417BD3, cursorWidth, 34, 0xFF, NULL);
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417BCB, cursorWidth, 2 + 16 * (nitems - 1), 0xFF, NULL);
|
||||||
|
}
|
||||||
|
if (FlagGet(FLAG_SYS_NOT_SOMEONES_PC))
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417BAC, cursorWidth, 2 , 0xFF, NULL);
|
||||||
|
else
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417B9F, cursorWidth, 2 , 0xFF, NULL);
|
||||||
|
StringExpandPlaceholders(gStringVar4, gUnknown_8417BB6);
|
||||||
|
Menu_PrintFormatIntlPlayerName(windowId, gStringVar4, cursorWidth, 18);
|
||||||
|
Menu_InitCursor(windowId, 2, 0, 2, 16, nitems, 0);
|
||||||
|
sub_809CC18(FALSE, nitems, windowId, 0xFF);
|
||||||
|
ScheduleBgCopyTilemapToVram(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ScriptMenu_DisplayPCStartupPrompt(void)
|
||||||
|
{
|
||||||
|
sub_80F7768(0, TRUE);
|
||||||
|
AddTextPrinterParameterized2(0, 2, gUnknown_81A508A, 0, NULL, 2, 1, 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D288(u8 taskId)
|
||||||
|
{
|
||||||
|
struct Task * task = &gTasks[taskId];
|
||||||
|
switch (task->data[0])
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
task->data[0]++;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
sub_8083A5C(&gSprites[task->data[2]], task->data[2]);
|
||||||
|
task->data[0]++;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
sub_809D6B0(task->data[5]);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 ScriptMenu_ShowPokemonPic(u16 species, u8 x, u8 y)
|
||||||
|
{
|
||||||
|
u8 spriteId;
|
||||||
|
u8 taskId;
|
||||||
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) == TRUE)
|
||||||
|
return TRUE;
|
||||||
|
if (FindTaskIdByFunc(sub_809D288) != 0xFF)
|
||||||
|
return FALSE;
|
||||||
|
spriteId = sub_8083970(species, 8 * x + 40, 8 * y + 40, FALSE);
|
||||||
|
taskId = CreateTask(sub_809D288, 80);
|
||||||
|
gTasks[taskId].data[5] = CreateWindowFromRect(x, y, 8, 8);
|
||||||
|
gTasks[taskId].data[0] = 0;
|
||||||
|
gTasks[taskId].data[1] = species;
|
||||||
|
gTasks[taskId].data[2] = spriteId;
|
||||||
|
gSprites[spriteId].callback = SpriteCallbackDummy;
|
||||||
|
gSprites[spriteId].oam.priority = 0;
|
||||||
|
SetStdWindowBorderStyle(gTasks[taskId].data[5], TRUE);
|
||||||
|
ScheduleBgCopyTilemapToVram(0);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 (*ScriptMenu_GetPicboxWaitFunc(void))(void)
|
||||||
|
{
|
||||||
|
u8 taskId = FindTaskIdByFunc(sub_809D288);
|
||||||
|
if (taskId == 0xFF)
|
||||||
|
return NULL;
|
||||||
|
gTasks[taskId].data[0]++;
|
||||||
|
return sub_809D404;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 sub_809D404(void)
|
||||||
|
{
|
||||||
|
if (FindTaskIdByFunc(sub_809D288) == 0xFF)
|
||||||
|
return TRUE;
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D424(void)
|
||||||
|
{
|
||||||
|
u8 taskId = FindTaskIdByFunc(sub_809D288);
|
||||||
|
struct Task * task;
|
||||||
|
if (taskId != 0xFF)
|
||||||
|
{
|
||||||
|
task = &gTasks[taskId];
|
||||||
|
switch (task->data[0])
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
sub_8083A5C(&gSprites[task->data[2]], task->data[2]);
|
||||||
|
sub_809D6B0(task->data[5]);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
sub_809D6B0(task->data[5]);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D494(u8 taskId)
|
||||||
|
{
|
||||||
|
struct Task * task = &gTasks[taskId];
|
||||||
|
switch (task->data[0])
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
task->data[0]++;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
DestroySprite(&gSprites[task->data[2]]);
|
||||||
|
FreeSpriteTilesByTag(7000);
|
||||||
|
task->data[0]++;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
sub_809D6B0(task->data[5]);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 Special_OpenMuseumFossilPic(void)
|
||||||
|
{
|
||||||
|
u8 spriteId;
|
||||||
|
u8 taskId;
|
||||||
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) == TRUE)
|
||||||
|
return TRUE;
|
||||||
|
if (FindTaskIdByFunc(sub_809D494) != 0xFF)
|
||||||
|
return FALSE;
|
||||||
|
if (gSpecialVar_0x8004 == SPECIES_KABUTOPS)
|
||||||
|
{
|
||||||
|
LoadSpriteSheets(sMuseumKabutopsSprSheets);
|
||||||
|
LoadPalette(sMuseumKabutopsSprPalette, 0x1D0, 0x20);
|
||||||
|
}
|
||||||
|
else if (gSpecialVar_0x8004 == SPECIES_AERODACTYL)
|
||||||
|
{
|
||||||
|
LoadSpriteSheets(sMuseumAerodactylSprSheets);
|
||||||
|
LoadPalette(sMuseumAerodactylSprPalette, 0x1D0, 0x20);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
spriteId = CreateSprite(&sMuseumFossilSprTemplate, gSpecialVar_0x8005 * 8 + 40, gSpecialVar_0x8006 * 8 + 40, 0);
|
||||||
|
gSprites[spriteId].oam.paletteNum = 13;
|
||||||
|
taskId = CreateTask(sub_809D494, 80);
|
||||||
|
gTasks[taskId].data[5] = CreateWindowFromRect(gSpecialVar_0x8005, gSpecialVar_0x8006, 8, 8);
|
||||||
|
gTasks[taskId].data[0] = 0;
|
||||||
|
gTasks[taskId].data[2] = spriteId;
|
||||||
|
SetStdWindowBorderStyle(gTasks[taskId].data[5], TRUE);
|
||||||
|
ScheduleBgCopyTilemapToVram(0);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 Special_CloseMuseumFossilPic(void)
|
||||||
|
{
|
||||||
|
u8 taskId = FindTaskIdByFunc(sub_809D494);
|
||||||
|
if (taskId == 0xFF)
|
||||||
|
return FALSE;
|
||||||
|
gTasks[taskId].data[0]++;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 CreateWindowFromRect(u8 left, u8 top, u8 width, u8 height)
|
||||||
|
{
|
||||||
|
struct WindowTemplate template = SetWindowTemplateFields(0, left + 1, top + 1, width, height, 15, 0x038);
|
||||||
|
u8 windowId = AddWindow(&template);
|
||||||
|
PutWindowTilemap(windowId);
|
||||||
|
return windowId;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D6B0(u8 windowId)
|
||||||
|
{
|
||||||
|
ClearWindowTilemap(windowId);
|
||||||
|
ClearStdWindowAndFrameToTransparent(windowId, TRUE);
|
||||||
|
RemoveWindow(windowId);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D6D4(void)
|
||||||
|
{
|
||||||
|
u8 taskId;
|
||||||
|
s16 *data;
|
||||||
|
ScriptContext1_SetupScript(EventScript_1A7AE0);
|
||||||
|
taskId = FindTaskIdByFunc(sub_809D288);
|
||||||
|
if (taskId != 0xFF)
|
||||||
|
{
|
||||||
|
data = gTasks[taskId].data;
|
||||||
|
if (data[0] < 2)
|
||||||
|
sub_8083A5C(&gSprites[data[2]], data[2]);
|
||||||
|
}
|
||||||
|
taskId = FindTaskIdByFunc(sub_809D494);
|
||||||
|
if (taskId != 0xFF)
|
||||||
|
{
|
||||||
|
data = gTasks[taskId].data;
|
||||||
|
if (data[0] < 2)
|
||||||
|
{
|
||||||
|
DestroySprite(&gSprites[data[2]]);
|
||||||
|
FreeSpriteTilesByTag(7000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_809D764(void)
|
||||||
|
{
|
||||||
|
u8 r4;
|
||||||
|
u8 top;
|
||||||
|
u8 nitems;
|
||||||
|
u8 cursorWidth;
|
||||||
|
u8 fontHeight;
|
||||||
|
u8 windowId;
|
||||||
|
u8 i;
|
||||||
|
gSpecialVar_Result = 255;
|
||||||
|
if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_0x8005 == 1)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_0x8004 < 5)
|
||||||
|
r4 = 5;
|
||||||
|
else
|
||||||
|
r4 = 4;
|
||||||
|
nitems = 5;
|
||||||
|
top = 2;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
r4 = 0;
|
||||||
|
nitems = 6;
|
||||||
|
top = 0;
|
||||||
|
}
|
||||||
|
cursorWidth = GetMenuCursorDimensionByFont(2, 0);
|
||||||
|
fontHeight = GetFontAttribute(2, FONTATTR_MAX_LETTER_HEIGHT);
|
||||||
|
windowId = CreateWindowFromRect(17, top, 11, nitems * 2);
|
||||||
|
SetStdWindowBorderStyle(windowId, FALSE);
|
||||||
|
for (i = 0; i < nitems - 2; i++)
|
||||||
|
{
|
||||||
|
if (r4 != gSpecialVar_0x8004)
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_83E17E0[r4], cursorWidth, i * 16 + 2, 0xFF, NULL);
|
||||||
|
else
|
||||||
|
i--;
|
||||||
|
r4++;
|
||||||
|
if (r4 == 8)
|
||||||
|
r4 = 0;
|
||||||
|
}
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gUnknown_8417DED, cursorWidth, i * 16 + 2, 0xFF, NULL);
|
||||||
|
i++;
|
||||||
|
AddTextPrinterParameterized(windowId, 2, gOtherText_Exit, cursorWidth, i * 16 + 2, 0xFF, NULL);
|
||||||
|
Menu_InitCursor(windowId, 2, 0, 2, 16, nitems, 0);
|
||||||
|
sub_809CC18(FALSE, nitems, windowId, 0xFF);
|
||||||
|
ScheduleBgCopyTilemapToVram(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
u16 sub_809D8C0(void)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_Result == 127)
|
||||||
|
return 127;
|
||||||
|
if (gSpecialVar_0x8005 == 1)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_Result == 3)
|
||||||
|
{
|
||||||
|
return 254;
|
||||||
|
}
|
||||||
|
else if (gSpecialVar_Result == 4)
|
||||||
|
{
|
||||||
|
return 127;
|
||||||
|
}
|
||||||
|
else if (gSpecialVar_Result == 0)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_0x8004 > 4)
|
||||||
|
return 4;
|
||||||
|
else
|
||||||
|
return 5;
|
||||||
|
}
|
||||||
|
else if (gSpecialVar_Result == 1)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_0x8004 > 5)
|
||||||
|
return 5;
|
||||||
|
else
|
||||||
|
return 6;
|
||||||
|
}
|
||||||
|
else if (gSpecialVar_Result == 2)
|
||||||
|
{
|
||||||
|
if (gSpecialVar_0x8004 > 6)
|
||||||
|
return 6;
|
||||||
|
else
|
||||||
|
return 7;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (gSpecialVar_Result == 4)
|
||||||
|
return 254;
|
||||||
|
else if (gSpecialVar_Result == 5)
|
||||||
|
return 127;
|
||||||
|
else if (gSpecialVar_Result >= gSpecialVar_0x8004)
|
||||||
|
return gSpecialVar_Result + 1;
|
||||||
|
else
|
||||||
|
return gSpecialVar_Result;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user