summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2019-10-25 11:10:08 -0400
committerPikalaxALT <pikalaxalt@gmail.com>2019-10-25 11:10:08 -0400
commit0a440d658b2d4a311381b1d297872e7eece7486f (patch)
tree55f03923cd4686d146bdd11f5874a310c344a7a6 /src
parent283084cce49b0bdb65916f35e55654a3b365f452 (diff)
Finish script_menu code decomp
Diffstat (limited to 'src')
-rw-r--r--src/berry_powder.c2
-rw-r--r--src/field_specials.c4
-rw-r--r--src/quest_log.c674
-rw-r--r--src/scrcmd.c4
-rw-r--r--src/script_menu.c428
5 files changed, 764 insertions, 348 deletions
diff --git a/src/berry_powder.c b/src/berry_powder.c
index 992e82522..6adf4a4f9 100644
--- a/src/berry_powder.c
+++ b/src/berry_powder.c
@@ -111,7 +111,7 @@ void sub_815F094(void)
{
struct WindowTemplate template;
- if (sub_81119D4(sub_809D6D4) != TRUE)
+ if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
{
template = SetWindowTemplateFields(0, 1, 1, 8, 3, 15, 32);
gUnknown_203F464 = AddWindow(&template);
diff --git a/src/field_specials.c b/src/field_specials.c
index 867df4b94..d701a9145 100644
--- a/src/field_specials.c
+++ b/src/field_specials.c
@@ -1064,7 +1064,7 @@ void Special_DrawElevatorCurrentFloorWindow(void)
{
const u8 *floorname;
u32 strwidth;
- if (sub_81119D4(sub_809D6D4) != TRUE)
+ if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
{
sElevatorCurrentFloorWindowId = AddWindow(&sElevatorCurrentFloorWindowTemplate);
TextWindow_SetStdFrame0_WithPal(sElevatorCurrentFloorWindowId, 0x21D, 0xD0);
@@ -1137,7 +1137,7 @@ void Special_ListMenu(void)
{
u8 taskId;
struct Task * task;
- if (sub_81119D4(sub_809D6D4) != TRUE)
+ if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
{
taskId = CreateTask(Task_CreateScriptListMenu, 8);
task = &gTasks[taskId];
diff --git a/src/quest_log.c b/src/quest_log.c
index ffced87ee..b5e333688 100644
--- a/src/quest_log.c
+++ b/src/quest_log.c
@@ -813,13 +813,13 @@ static bool8 sub_8110E68(struct UnkStruct_203AE98 * a0)
return FALSE;
switch (a0[i].unk_6)
{
- case 0:
- case 1:
- gUnknown_203AE08 = sub_8113D48(gUnknown_203AE08, &a0[i]);
- break;
- default:
- gUnknown_203AE08 = sub_8113CC8(gUnknown_203AE08, &a0[i]);
- break;
+ case 0:
+ case 1:
+ gUnknown_203AE08 = sub_8113D48(gUnknown_203AE08, &a0[i]);
+ break;
+ default:
+ gUnknown_203AE08 = sub_8113CC8(gUnknown_203AE08, &a0[i]);
+ break;
}
if (gUnknown_203AE08 == NULL)
{
@@ -1176,29 +1176,29 @@ static void sub_811175C(u8 a0, struct UnkStruct_203AE98 * a1)
{
switch (r4[0] & 0xFFF)
{
- case 0:
- r4 = sub_8113D08(r4, &a1[r6]);
- r6++;
- break;
- case 1:
- case 2:
- r4 = sub_8113D94(r4, &a1[r6]);
- r6++;
- break;
- case 39:
- r4 = sub_8113C20(r4, &a1[r6]);
- r6++;
- break;
- case 41:
- r4 = sub_8113C8C(r4, &a1[r6]);
- r6++;
- break;
- default:
- r4 = sub_8113A78(r4, &gUnknown_203AE0C[r9]);
- if (r9 == 0)
- sub_8113ABC(gUnknown_203AE0C[0]);
- r9++;
- break;
+ case 0:
+ r4 = sub_8113D08(r4, &a1[r6]);
+ r6++;
+ break;
+ case 1:
+ case 2:
+ r4 = sub_8113D94(r4, &a1[r6]);
+ r6++;
+ break;
+ case 39:
+ r4 = sub_8113C20(r4, &a1[r6]);
+ r6++;
+ break;
+ case 41:
+ r4 = sub_8113C8C(r4, &a1[r6]);
+ r6++;
+ break;
+ default:
+ r4 = sub_8113A78(r4, &gUnknown_203AE0C[r9]);
+ if (r9 == 0)
+ sub_8113ABC(gUnknown_203AE0C[0]);
+ r9++;
+ break;
}
if (r4 == NULL)
break;
@@ -1246,7 +1246,7 @@ void sub_81119C8(void)
sub_8111914();
}
-bool8 sub_81119D4(void (*a0)(void))
+bool8 QuestLog_ScheduleRoutineIfNotInPlaybackMode(void (*a0)(void))
{
u8 taskId;
@@ -1260,7 +1260,7 @@ bool8 sub_81119D4(void (*a0)(void))
taskId = CreateTask(sub_8111A34, 80);
gTasks[taskId].data[0] = 0;
gTasks[taskId].data[1] = 0;
- SetWordTaskArg(taskId, 14, (u32)a0);
+ SetWordTaskArg(taskId, 14, (uintptr_t)a0);
return TRUE;
}
return FALSE;
@@ -1273,25 +1273,25 @@ static void sub_8111A34(u8 taskId)
switch (data[1])
{
- case 0:
- if (++data[0] == 0x7F)
- {
- BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, 0);
- gUnknown_203AE94.unk_0_6 = 2;
- data[1]++;
- }
- break;
- case 1:
- if (!gPaletteFade.active)
- {
- gUnknown_3005E88 = 0;
- routine = (void (*)(void)) GetWordTaskArg(taskId, 14);
- if (routine != NULL)
- routine();
- DestroyTask(taskId);
- gUnknown_203AE8C = sub_8111914;
- }
- break;
+ case 0:
+ if (++data[0] == 0x7F)
+ {
+ BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, 0);
+ gUnknown_203AE94.unk_0_6 = 2;
+ data[1]++;
+ }
+ break;
+ case 1:
+ if (!gPaletteFade.active)
+ {
+ gUnknown_3005E88 = 0;
+ routine = (void (*)(void)) GetWordTaskArg(taskId, 14);
+ if (routine != NULL)
+ routine();
+ DestroyTask(taskId);
+ gUnknown_203AE8C = sub_8111914;
+ }
+ break;
}
}
@@ -1431,15 +1431,15 @@ static void sub_8111D90(u8 a0)
{
switch (i)
{
- default:
- y = 1;
- break;
- case 0:
- y = 0;
- break;
- case 5:
- y = 2;
- break;
+ default:
+ y = 1;
+ break;
+ case 0:
+ y = 0;
+ break;
+ case 5:
+ y = 2;
+ break;
}
// r6 = y * 32
@@ -1563,46 +1563,46 @@ static void sub_81120AC(u8 taskId)
switch (data[0])
{
- case 0:
- gDisableMapMusicChangeOnMapLoad = 0;
- Overworld_PlaySpecialMapMusic();
- sub_811229C();
- FillWindowPixelRect(gUnknown_203ADFE[0], 0xF, 0, 0, gUnknown_845661C[0].width * 8, gUnknown_845661C[0].height * 8);
- data[0]++;
- break;
- case 1:
- if (sub_81121D8(taskId))
+ case 0:
+ gDisableMapMusicChangeOnMapLoad = 0;
+ Overworld_PlaySpecialMapMusic();
+ sub_811229C();
+ FillWindowPixelRect(gUnknown_203ADFE[0], 0xF, 0, 0, gUnknown_845661C[0].width * 8, gUnknown_845661C[0].height * 8);
+ data[0]++;
+ break;
+ case 1:
+ 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);
- RemoveWindow(gUnknown_203ADFE[i]);
- }
- data[1] = 0;
- data[0]++;
+ ClearWindowTilemap(gUnknown_203ADFE[i]);
+ CopyWindowToVram(gUnknown_203ADFE[i], 1);
+ RemoveWindow(gUnknown_203ADFE[i]);
}
- break;
- case 2:
- if (data[1] < 32)
- data[1]++;
- else
- data[0]++;
- break;
- default:
- if (gUnknown_203AE94.unk_0_6 == 1)
- sub_8098110(1);
- CpuCopy16(gUnknown_203AE90, gPlttBufferUnfaded, 0x400);
- Free(gUnknown_203AE90);
- gUnknown_203AE94 = (struct UnkStruct_203AE94){};
- sub_80696C0();
- ScriptContext2_Disable();
- gTextFlags.autoScroll = FALSE;
- gUnknown_2036E28 = 0;
- sub_8082740(0);
- gHelpSystemEnabled = TRUE;
- DestroyTask(taskId);
- break;
+ data[1] = 0;
+ data[0]++;
+ }
+ break;
+ case 2:
+ if (data[1] < 32)
+ data[1]++;
+ else
+ data[0]++;
+ break;
+ default:
+ if (gUnknown_203AE94.unk_0_6 == 1)
+ sub_8098110(1);
+ CpuCopy16(gUnknown_203AE90, gPlttBufferUnfaded, 0x400);
+ Free(gUnknown_203AE90);
+ gUnknown_203AE94 = (struct UnkStruct_203AE94){};
+ sub_80696C0();
+ ScriptContext2_Disable();
+ gTextFlags.autoScroll = FALSE;
+ gUnknown_2036E28 = 0;
+ sub_8082740(0);
+ gHelpSystemEnabled = TRUE;
+ DestroyTask(taskId);
+ break;
}
}
@@ -1834,14 +1834,14 @@ static void sub_8112888(u8 a0)
{
switch (a0)
{
- case 1:
- if (gUnknown_3005E88 == 1)
- gUnknown_3005E88 = 3;
- break;
- case 2:
- if (gUnknown_3005E88 == 3)
- gUnknown_3005E88 = 1;
- break;
+ case 1:
+ if (gUnknown_3005E88 == 1)
+ gUnknown_3005E88 = 3;
+ break;
+ case 2:
+ if (gUnknown_3005E88 == 3)
+ gUnknown_3005E88 = 1;
+ break;
}
}
@@ -1851,24 +1851,24 @@ void sub_81128BC(u8 a0)
switch (a0)
{
- case 1:
- if (r1 == 1)
- gUnknown_3005E88 = 3;
- else if (r1 == 2)
- {
- gUnknown_3005E94[sQuestLogIdx].unk_4 = gUnknown_203B01A;
- gUnknown_3005E94[sQuestLogIdx].unk_6 = 3;
- sQuestLogIdx++;
- gUnknown_203B01A = 0;
- gUnknown_3005E88 = 4;
- }
- break;
- case 2:
- if (r1 == 1)
- gUnknown_3005E88 = 1;
- else if (r1 == 2)
- gUnknown_3005E88 = 2;
- break;
+ case 1:
+ if (r1 == 1)
+ gUnknown_3005E88 = 3;
+ else if (r1 == 2)
+ {
+ gUnknown_3005E94[sQuestLogIdx].unk_4 = gUnknown_203B01A;
+ gUnknown_3005E94[sQuestLogIdx].unk_6 = 3;
+ sQuestLogIdx++;
+ gUnknown_203B01A = 0;
+ gUnknown_3005E88 = 4;
+ }
+ break;
+ case 2:
+ if (r1 == 1)
+ gUnknown_3005E88 = 1;
+ else if (r1 == 2)
+ gUnknown_3005E88 = 2;
+ break;
}
}
@@ -1878,64 +1878,64 @@ static void sub_8112940(u8 a0, struct UnkStruct_203AE98 *a1, u16 a2)
switch (a0)
{
- default:
- gUnknown_3005E88 = 0;
- break;
+ default:
+ gUnknown_3005E88 = 0;
+ 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:
- 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;
+ gUnknown_3005E94[sQuestLogIdx].unk_3 = 0;
+ break;
+ case 4:
+ gUnknown_3005E94[sQuestLogIdx].unk_3 = 3;
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:
- 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;
+ 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;
}
}
@@ -1944,67 +1944,67 @@ void sub_8112B3C(void)
{
switch (gUnknown_3005E88)
{
- case 0:
- break;
- case 1:
- if (sub_8112CEC())
+ case 0:
+ break;
+ case 1:
+ if (sub_8112CEC())
+ {
+ if (gUnknown_203B01A != 0)
+ gUnknown_203B01A--;
+ else
{
- if (gUnknown_203B01A != 0)
- gUnknown_203B01A--;
- else
+ while (1)
{
- 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;
- break;
- case 1:
- gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][1] = gUnknown_3005E94[sQuestLogIdx].unk_3;
- break;
- case 2:
- *(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));
- break;
- case 3:
- gUnknown_3005E88 = 3;
- break;
- case 0xFE:
- break;
- case 0xFF:
- gUnknown_3005E88 = 0;
- break;
- }
- if (gUnknown_3005E88 == 0)
- break;
- if (++sQuestLogIdx >= sNumQuestLogs)
- {
- gUnknown_3005E88 = 0;
- break;
- }
- gUnknown_203B01A = gUnknown_3005E94[sQuestLogIdx].unk_4;
- if (gUnknown_3005E88 == 3)
- break;
- if (gUnknown_203B01A == 0)
- continue;
- if (gUnknown_203B01A == 0xFFFF)
- break;
- }
+ case 0:
+ gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][0] = gUnknown_3005E94[sQuestLogIdx].unk_3;
+ break;
+ case 1:
+ gUnknown_203AF9A[gUnknown_3005E94[sQuestLogIdx].unk_0][1] = gUnknown_3005E94[sQuestLogIdx].unk_3;
+ break;
+ case 2:
+ *(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));
+ break;
+ case 3:
+ gUnknown_3005E88 = 3;
+ break;
+ case 0xFE:
+ break;
+ case 0xFF:
+ gUnknown_3005E88 = 0;
+ break;
+ }
+ if (gUnknown_3005E88 == 0)
+ break;
+ if (++sQuestLogIdx >= sNumQuestLogs)
+ {
+ gUnknown_3005E88 = 0;
+ break;
+ }
+ gUnknown_203B01A = gUnknown_3005E94[sQuestLogIdx].unk_4;
+ if (gUnknown_3005E88 == 3)
+ break;
+ if (gUnknown_203B01A == 0)
+ continue;
+ if (gUnknown_203B01A == 0xFFFF)
+ break;
}
}
- else if (sQuestLogIdx >= sNumQuestLogs)
- gUnknown_3005E88 = 0;
- break;
- case 2:
- if (ScriptContext2_IsEnabled() != 1)
- gUnknown_203B01A++;
- if (sQuestLogIdx >= sNumQuestLogs)
- gUnknown_3005E88 = 0;
- break;
- case 3:
- break;
- case 4:
- break;
+ }
+ else if (sQuestLogIdx >= sNumQuestLogs)
+ gUnknown_3005E88 = 0;
+ break;
+ case 2:
+ if (ScriptContext2_IsEnabled() != 1)
+ gUnknown_203B01A++;
+ if (sQuestLogIdx >= sNumQuestLogs)
+ gUnknown_3005E88 = 0;
+ break;
+ case 3:
+ break;
+ case 4:
+ break;
}
}
#else
@@ -2203,15 +2203,15 @@ u8 sub_8112CAC(void)
{
switch (gUnknown_3005E88)
{
- case 0:
- default:
- return 0;
- case 1:
- case 3:
- return 1;
- case 2:
- case 4:
- return 2;
+ case 0:
+ default:
+ return 0;
+ case 1:
+ case 3:
+ return 1;
+ case 2:
+ case 4:
+ return 2;
}
}
@@ -2669,27 +2669,27 @@ void BufferStreakTrainerText(void)
switch (gSpecialVar_0x8004)
{
- case 0:
- r2 = 0;
- r3 = 0;
- break;
- case 1:
- case 2:
- case 3:
- case 7:
- break;
- case 4:
- r2 = 1;
- r3 = 0;
- break;
- case 5:
- r2 = 0;
- r3 = 1;
- break;
- case 6:
- r2 = 2;
- r3 = 1;
- break;
+ case 0:
+ r2 = 0;
+ r3 = 0;
+ break;
+ case 1:
+ case 2:
+ case 3:
+ case 7:
+ break;
+ case 4:
+ r2 = 1;
+ r3 = 0;
+ break;
+ case 5:
+ r2 = 0;
+ r3 = 1;
+ break;
+ case 6:
+ r2 = 2;
+ r3 = 1;
+ break;
}
sub_8113414(&gSaveBlock2Ptr->linkBattleRecords, r3, r2);
}
@@ -2702,18 +2702,18 @@ static void sub_8113414(struct LinkBattleRecords * a0, u8 a1, u8 a2)
{
switch (a2)
{
- case 0:
- StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
- break;
- case 1:
- StringCopy(gStringVar1, gUnknown_84178D0); // LT. SURGE
- break;
- case 2:
- StringCopy(gStringVar1, gUnknown_84178DA); // KOGA
- break;
- default:
- StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
- break;
+ case 0:
+ StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
+ break;
+ case 1:
+ StringCopy(gStringVar1, gUnknown_84178D0); // LT. SURGE
+ break;
+ case 2:
+ StringCopy(gStringVar1, gUnknown_84178DA); // KOGA
+ break;
+ default:
+ StringCopy(gStringVar1, gSaveBlock1Ptr->rivalName);
+ break;
}
}
else
@@ -3703,48 +3703,48 @@ static const u16 *sub_8113FBC(const u16 *a0)
switch (ItemId_GetPocket(r5[0]))
{
- case POCKET_ITEMS:
- case POCKET_POKE_BALLS:
- case POCKET_BERRY_POUCH:
- StringCopy(gStringVar1, ItemId_GetName(r5[0]));
- if (r5[0] == ITEM_ESCAPE_ROPE)
- {
- sub_80C4DF8(gStringVar2, r5[2]);
- StringExpandPlaceholders(gStringVar4, gUnknown_841AFA6);
- }
- else if (r5[1] != 0xFFFF)
- {
- QuestLog_AutoGetSpeciesName(r5[1], gStringVar2, 0);
- StringExpandPlaceholders(gStringVar4, gUnknown_841A1E7);
- }
+ case POCKET_ITEMS:
+ case POCKET_POKE_BALLS:
+ case POCKET_BERRY_POUCH:
+ StringCopy(gStringVar1, ItemId_GetName(r5[0]));
+ if (r5[0] == ITEM_ESCAPE_ROPE)
+ {
+ sub_80C4DF8(gStringVar2, r5[2]);
+ StringExpandPlaceholders(gStringVar4, gUnknown_841AFA6);
+ }
+ else if (r5[1] != 0xFFFF)
+ {
+ QuestLog_AutoGetSpeciesName(r5[1], gStringVar2, 0);
+ 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
- {
- 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
- StringExpandPlaceholders(gStringVar4, gUnknown_841A277);
- }
+ StringExpandPlaceholders(gStringVar4, gUnknown_841A277);
+ }
+ else
+ {
+ if (r5[0] > ITEM_TM50)
+ StringExpandPlaceholders(gStringVar4, gUnknown_841A938);
else
- {
- if (r5[0] > ITEM_TM50)
- StringExpandPlaceholders(gStringVar4, gUnknown_841A938);
- else
- StringExpandPlaceholders(gStringVar4, gUnknown_841A255);
- }
- break;
+ StringExpandPlaceholders(gStringVar4, gUnknown_841A255);
+ }
+ break;
}
return r5 + 3;
}
@@ -4442,11 +4442,11 @@ static bool8 sub_8114FBC(u16 a0)
{
switch (a0)
{
- case 0x96:
- case 0x8F ... 0x92:
- case 0xF9 ... 0xFA:
- case 0x19A:
- return TRUE;
+ case 0x96:
+ case 0x8F ... 0x92:
+ case 0xF9 ... 0xFA:
+ case 0x19A:
+ return TRUE;
}
return FALSE;
}
@@ -4495,22 +4495,22 @@ static const u16 *sub_81150CC(const u16 *a0)
switch (gUnknown_203B044.unk_2)
{
- case 0:
- DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock2Ptr->playerName);
- DynamicPlaceholderTextUtil_SetPlaceholderPtr(1, gSaveBlock1Ptr->rivalName);
- DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A2E1);
- break;
- case 1:
- DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock1Ptr->rivalName);
- QuestLog_AutoGetSpeciesName(a0[2], NULL, 1);
- DynamicPlaceholderTextUtil_SetPlaceholderPtr(2, gSaveBlock2Ptr->playerName);
- QuestLog_AutoGetSpeciesName(a0[3], NULL, 3);
- DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A312);
- break;
- case 2:
- DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gUnknown_8456AD8[r5[0]]);
- DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A349);
- break;
+ case 0:
+ DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock2Ptr->playerName);
+ DynamicPlaceholderTextUtil_SetPlaceholderPtr(1, gSaveBlock1Ptr->rivalName);
+ DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A2E1);
+ break;
+ case 1:
+ DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gSaveBlock1Ptr->rivalName);
+ QuestLog_AutoGetSpeciesName(a0[2], NULL, 1);
+ DynamicPlaceholderTextUtil_SetPlaceholderPtr(2, gSaveBlock2Ptr->playerName);
+ QuestLog_AutoGetSpeciesName(a0[3], NULL, 3);
+ DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A312);
+ break;
+ case 2:
+ DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, gUnknown_8456AD8[r5[0]]);
+ DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gUnknown_841A349);
+ break;
}
return (const u16 *)(r5 + 2);
}
diff --git a/src/scrcmd.c b/src/scrcmd.c
index 2a6aff709..b54e08faa 100644
--- a/src/scrcmd.c
+++ b/src/scrcmd.c
@@ -1835,7 +1835,7 @@ bool8 ScrCmd_showmoneybox(struct ScriptContext *ctx)
u8 y = 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);
return FALSE;
}
@@ -1865,7 +1865,7 @@ bool8 ScrCmd_showcoinsbox(struct ScriptContext *ctx)
u8 x = ScriptReadByte(ctx);
u8 y = ScriptReadByte(ctx);
- if (sub_81119D4(sub_809D6D4) != TRUE)
+ if (QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
ShowCoinsWindow(GetCoins(), x, y);
return FALSE;
}
diff --git a/src/script_menu.c b/src/script_menu.c
index d375ece08..4bc7bfec9 100644
--- a/src/script_menu.c
+++ b/src/script_menu.c
@@ -1,7 +1,6 @@
#include "global.h"
#include "palette.h"
#include "text.h"
-#include "list_menu.h"
#include "menu.h"
#include "task.h"
#include "sound.h"
@@ -11,7 +10,12 @@
#include "new_menu_helpers.h"
#include "event_data.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/species.h"
struct MultichoiceListStruct
{
@@ -27,6 +31,9 @@ void sub_809CC18(u8 ignoreBpress, u8 count, u8 windowId, u8 mcId);
void sub_809CC98(u8 taskId);
void sub_809CD48(u8 mcId);
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);
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_83E0748[];
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)
{
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;
- u8 width = sub_809C954(items[0].label);
+ u8 width = sub_809C954(items[0].text);
u8 tmp;
for (i = 1; i < count; i++)
{
- tmp = sub_809C954(items[i].label);
+ tmp = sub_809C954(items[i].text);
if (width < tmp)
width = tmp;
}
@@ -84,7 +97,7 @@ void sub_809CA64(u8 left, u8 top, u8 mcId, u8 ignoreBpress, u8 initPos)
u8 windowId;
const struct MenuAction * list;
- if ((ignoreBpress & 2) || sub_81119D4(sub_809D6D4) != TRUE)
+ if ((ignoreBpress & 2) || QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4) != TRUE)
{
ignoreBpress &= 1;
count = gUnknown_83E04B0[mcId].count;
@@ -218,7 +231,7 @@ bool8 ScriptMenu_YesNo(u8 unused, u8 stuff)
if (FuncIsActiveTask(task_yes_no_maybe) == TRUE)
return FALSE;
gSpecialVar_Result = 255;
- if (!sub_81119D4(sub_809D6D4))
+ if (!QuestLog_ScheduleRoutineIfNotInPlaybackMode(sub_809D6D4))
{
DisplayYesNoMenuDefaultYes();
CreateTask(task_yes_no_maybe, 80);
@@ -261,3 +274,406 @@ void task_yes_no_maybe(u8 taskId)
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;
+}