From ee6b3c1acf4805d6df72b291b8c0f79635e6341a Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Wed, 5 May 2021 13:03:39 -0400 Subject: [PATCH 01/21] Sync berry crush from Emerald --- data/scripts/cable_club.inc | 2 +- data/specials.inc | 2 +- .../unk_846F058.bin => berry_crush/bg.bin} | Bin .../container_cap.bin} | Bin .../crusher_base.png} | Bin .../crusher_top.bin} | Bin .../impact.png} | Bin .../sparkle.png} | Bin .../timer_digits.png} | Bin include/berry.h | 4 +- include/berry_crush.h | 1 + include/digit_obj_util.h | 2 +- include/global.h | 18 + include/graphics.h | 6 +- include/item.h | 2 +- include/link.h | 2 +- include/link_rfu.h | 26 +- include/math_util.h | 12 +- include/new_menu_helpers.h | 2 +- include/palette.h | 4 + include/save.h | 2 +- src/battle_anim_effects_2.c | 14 +- src/battle_interface.c | 3 - src/berry.c | 88 +- src/berry_crush.c | 2838 +++++++++-------- src/digit_obj_util.c | 4 +- src/dodrio_berry_picking.c | 14 +- src/dodrio_berry_picking_2.c | 6 +- src/dodrio_berry_picking_3.c | 8 +- src/graphics.c | 6 +- src/hall_of_fame.c | 2 +- src/item.c | 2 +- src/link.c | 2 +- src/link_rfu_2.c | 86 +- src/math_util.c | 18 +- src/naming_screen.c | 2 +- src/new_menu_helpers.c | 2 +- src/oak_speech.c | 8 +- src/overworld.c | 4 +- src/pokemon_jump.c | 2 +- src/pokemon_jump_2.c | 4 +- src/pokemon_jump_3.c | 8 +- src/pokemon_jump_4.c | 2 +- src/save.c | 2 +- src/start_menu.c | 4 +- src/union_room.c | 18 +- 46 files changed, 1776 insertions(+), 1456 deletions(-) rename graphics/{link_games/unk_846F058.bin => berry_crush/bg.bin} (100%) rename graphics/{link_games/unk_846EEC0.bin => berry_crush/container_cap.bin} (100%) rename graphics/{link_games/unk_846E4D0.png => berry_crush/crusher_base.png} (100%) rename graphics/{link_games/unk_846ED90.bin => berry_crush/crusher_top.bin} (100%) rename graphics/{link_games/unk_846E7FC.png => berry_crush/impact.png} (100%) rename graphics/{link_games/unk_846EB78.png => berry_crush/sparkle.png} (100%) rename graphics/{link_games/unk_846ECC4.png => berry_crush/timer_digits.png} (100%) diff --git a/data/scripts/cable_club.inc b/data/scripts/cable_club.inc index 66cf634e9..e1902c6e4 100644 --- a/data/scripts/cable_club.inc +++ b/data/scripts/cable_club.inc @@ -977,7 +977,7 @@ CableClub_EventScript_WirelessBerryCrush:: @ 81BBD35 msgbox CableClub_Text_UseBerryCrush, MSGBOX_YESNO compare VAR_RESULT, NO goto_if_eq CableClub_EventScript_AbortLink - special CheckHasAtLeastOneBerry + special HasAtLeastOneBerry compare VAR_RESULT, FALSE goto_if_eq CableClub_EventScript_NeedBerryForBerryCrush setvar VAR_0x8004, LINK_GROUP_BERRY_CRUSH diff --git a/data/specials.inc b/data/specials.inc index aa7eced1a..2bc4a2a43 100644 --- a/data/specials.inc +++ b/data/specials.inc @@ -419,7 +419,7 @@ gSpecials:: @ 815FD60 def_special HelpSystem_Disable def_special HelpSystem_Enable def_special SetPostgameFlags - def_special CheckHasAtLeastOneBerry + def_special HasAtLeastOneBerry def_special DisplayBerryPowderVendorMenu def_special RemoveBerryPowderVendorMenu def_special Script_HasEnoughBerryPowder diff --git a/graphics/link_games/unk_846F058.bin b/graphics/berry_crush/bg.bin similarity index 100% rename from graphics/link_games/unk_846F058.bin rename to graphics/berry_crush/bg.bin diff --git a/graphics/link_games/unk_846EEC0.bin b/graphics/berry_crush/container_cap.bin similarity index 100% rename from graphics/link_games/unk_846EEC0.bin rename to graphics/berry_crush/container_cap.bin diff --git a/graphics/link_games/unk_846E4D0.png b/graphics/berry_crush/crusher_base.png similarity index 100% rename from graphics/link_games/unk_846E4D0.png rename to graphics/berry_crush/crusher_base.png diff --git a/graphics/link_games/unk_846ED90.bin b/graphics/berry_crush/crusher_top.bin similarity index 100% rename from graphics/link_games/unk_846ED90.bin rename to graphics/berry_crush/crusher_top.bin diff --git a/graphics/link_games/unk_846E7FC.png b/graphics/berry_crush/impact.png similarity index 100% rename from graphics/link_games/unk_846E7FC.png rename to graphics/berry_crush/impact.png diff --git a/graphics/link_games/unk_846EB78.png b/graphics/berry_crush/sparkle.png similarity index 100% rename from graphics/link_games/unk_846EB78.png rename to graphics/berry_crush/sparkle.png diff --git a/graphics/link_games/unk_846ECC4.png b/graphics/berry_crush/timer_digits.png similarity index 100% rename from graphics/link_games/unk_846ECC4.png rename to graphics/berry_crush/timer_digits.png diff --git a/include/berry.h b/include/berry.h index abbd20fc7..d1efa0abf 100644 --- a/include/berry.h +++ b/include/berry.h @@ -68,10 +68,10 @@ const struct Berry * GetBerryInfo(u8 berryIdx); extern const struct Berry gBerries[]; struct BerryCrushStats { - u8 unk0; + u8 difficulty; u16 powder; }; -extern const struct BerryCrushStats gBerryCrushStats[]; +extern const struct BerryCrushStats gBerryCrush_BerryData[]; #endif // GUARD_BERRY_H diff --git a/include/berry_crush.h b/include/berry_crush.h index a08f1f699..c87029003 100644 --- a/include/berry_crush.h +++ b/include/berry_crush.h @@ -4,5 +4,6 @@ #include "main.h" void StartBerryCrush(MainCallback callback); +void ShowBerryCrushRankings(void); #endif // GUARD_BERRY_CRUSH_H diff --git a/include/digit_obj_util.h b/include/digit_obj_util.h index 1db775d26..5674f201f 100644 --- a/include/digit_obj_util.h +++ b/include/digit_obj_util.h @@ -24,7 +24,7 @@ extern const u32 gUnknown_8479688[]; extern const u32 gUnknown_8479748[]; bool32 DigitObjUtil_Init(u32 count); -void DigitObjUtil_Teardown(void); +void DigitObjUtil_Free(void); bool32 DigitObjUtil_CreatePrinter(u32 id, s32 num, const struct DigitObjUtilTemplate *template); void DigitObjUtil_PrintNumOn(u32 id, s32 num); void DigitObjUtil_DeletePrinter(u32 id); diff --git a/include/global.h b/include/global.h index 04adc82cb..1d12fdae9 100644 --- a/include/global.h +++ b/include/global.h @@ -45,9 +45,27 @@ // Converts a number to Q8.8 fixed-point format #define Q_8_8(n) ((s16)((n) * 256)) +// Converts a number from Q8.8 fixed-point format +#define Q_8_8_TO_INT(n) ((s16)((n) >> 8)) + // Converts a number to Q4.12 fixed-point format #define Q_4_12(n) ((s16)((n) * 4096)) +// Converts a number from Q4.12 fixed-point format +#define Q_4_12_TO_INT(n) ((s16)((n) >> 12)) + +// Converts a number to QN.S fixed-point format (16-bits) +#define Q_N_S(s, n) ((s16)((n) * (1 << (s)))) + +// converts a number from QN.S fixed-point format (16-bits) +#define Q_N_S_TO_INT(s, n) ((s16)((n) >> (s))) + +// Converts a number to Q24.8 fixed-point format +#define Q_24_8(n) ((s32)((n) << 8)) + +// Converts a number from Q24.8 fixed-point format +#define Q_24_8_TO_INT(n) ((s32)((n) >> 8)) + #define min(a, b) ((a) < (b) ? (a) : (b)) #define max(a, b) ((a) >= (b) ? (a) : (b)) diff --git a/include/graphics.h b/include/graphics.h index 6b2c87bad..a92b798ae 100644 --- a/include/graphics.h +++ b/include/graphics.h @@ -4888,9 +4888,9 @@ extern const u32 gFile_graphics_battle_transitions_vs_frame_palette[]; extern const u32 gFile_graphics_battle_transitions_vs_frame_tilemap[]; // berry_crush -extern const u16 gUnknown_8EAFEA0[]; -extern const u32 gUnknown_8EAFFC0[]; -extern const u32 gUnknown_8EB0ADC[]; +extern const u16 gBerryCrush_Crusher_Pal[]; +extern const u32 gBerryCrush_Crusher_Gfx[]; +extern const u32 gBerryCrush_Crusher_Tilemap[]; // easy_chat_3 extern const u32 gEasyChatWindow_Gfx[]; diff --git a/include/item.h b/include/item.h index 2c5852617..92a057f7e 100644 --- a/include/item.h +++ b/include/item.h @@ -79,6 +79,6 @@ void RemovePCItem(u16 itemId, u16 quantity); void SortAndCompactBagPocket(struct BagPocket * pocket); u8 CountItemsInPC(void); void ApplyNewEncryptionKeyToBagItems_(u32 newKey); -bool8 CheckHasAtLeastOneBerry(void); +bool8 HasAtLeastOneBerry(void); #endif // GUARD_ITEM_H diff --git a/include/link.h b/include/link.h index 5ca2297cd..766bba919 100644 --- a/include/link.h +++ b/include/link.h @@ -274,7 +274,7 @@ void LoadWirelessStatusIndicatorSpriteGfx(void); void CreateWirelessStatusIndicatorSprite(u8, u8); void sub_8009FE8(void); void ClearLinkCallback_2(void); -void LinkRfu_SetRfuFuncToSend6600(void); +void Rfu_SetLinkStandbyCallback(void); void IntlConvertLinkPlayerName(struct LinkPlayer * linkPlayer); bool8 IsWirelessAdapterConnected(void); bool8 Link_PrepareCmd0xCCCC_Rfu0xA100(u8 blockRequestType); diff --git a/include/link_rfu.h b/include/link_rfu.h index 550b8225c..80bad0a21 100644 --- a/include/link_rfu.h +++ b/include/link_rfu.h @@ -5,17 +5,17 @@ #include "librfu.h" #include "AgbRfu_LinkManager.h" -#define RFU_COMMAND_0x8800 0x8800 -#define RFU_COMMAND_0x8900 0x8900 -#define RFU_COMMAND_0xa100 0xa100 -#define RFU_COMMAND_0x7700 0x7700 -#define RFU_COMMAND_0x7800 0x7800 -#define RFU_COMMAND_0x6600 0x6600 -#define RFU_COMMAND_0x5f00 0x5f00 -#define RFU_COMMAND_0x2f00 0x2f00 -#define RFU_COMMAND_0xbe00 0xbe00 -#define RFU_COMMAND_0xee00 0xee00 -#define RFU_COMMAND_0xed00 0xed00 +#define RFUCMD_SEND_PACKET 0x2F00 +#define RFUCMD_READY_CLOSE_LINK 0x5f00 +#define RFUCMD_READY_EXIT_STANDBY 0x6600 +#define RFUCMD_0x7700 0x7700 +#define RFUCMD_0x7800 0x7800 +#define RFUCMD_0x8800 0x8800 +#define RFUCMD_0x8900 0x8900 +#define RFUCMD_SEND_BLOCK_REQ 0xa100 +#define RFUCMD_SEND_HELD_KEYS 0xbe00 +#define RFUCMD_0xED00 0xee00 +#define RFUCMD_0xEE00 0xed00 // RfuTgtData.gname is read as these structs. struct GFtgtGnameSub @@ -196,7 +196,7 @@ void DestroyWirelessStatusIndicatorSprite(void); void MEvent_CreateTask_CardOrNewsWithFriend(u32 arg0); void MEvent_CreateTask_CardOrNewsOverWireless(u32 arg0); void MEvent_CreateTask_Leader(u32 arg0); -void RfuPrepareSend0x2f00(void * data); +void Rfu_SendPacket(void * data); u8 CreateTask_ListenToWireless(void); void LinkRfu_DestroyIdleTask(void); void sub_80F86F4(void); @@ -275,7 +275,7 @@ bool32 GetRfuUnkCE8(void); void sub_80FA4A8(void); void sub_80FB9D0(void); void sub_80FB030(u32 a0); -void sub_80FBA44(void); +void ClearRecvCommands(void); #include "mevent_server.h" extern const struct mevent_server_cmd gMEventSrvScript_OtherTrainerCanceled[]; diff --git a/include/math_util.h b/include/math_util.h index 9f9677463..1ccde1ef5 100644 --- a/include/math_util.h +++ b/include/math_util.h @@ -1,11 +1,11 @@ #ifndef GUARD_MATH_UTIL_H #define GUARD_MATH_UTIL_H -s16 MathUtil_Inv16(s16 y); -s16 MathUtil_Mul16(s16 x, s16 y); -s32 MathUtil_Div32(s32 x, s32 y); -s32 MathUtil_Mul32(s32 x, s32 y); -s16 MathUtil_Div16Shift(u8 s, s16 x, s16 y); -s16 MathUtil_Mul16Shift(u8 s, s16 x, s16 y); +s16 invfx16(s16 y); +s16 mulfx16(s16 x, s16 y); +s32 divfx32(s32 x, s32 y); +s32 mulfx32(s32 x, s32 y); +s16 divfxn16(u8 s, s16 x, s16 y); +s16 mulfxn16(u8 s, s16 x, s16 y); #endif //GUARD_MATH_UTIL_H diff --git a/include/new_menu_helpers.h b/include/new_menu_helpers.h index eab3c0830..79bff207a 100644 --- a/include/new_menu_helpers.h +++ b/include/new_menu_helpers.h @@ -20,7 +20,7 @@ void CopyToBufferFromBgTilemap(u8 bgId, u16 *dest, u8 left, u8 top, u8 width, u8 void ResetBgPositions(void); void InitStandardTextBoxWindows(void); void FreeAllOverworldWindowBuffers(void); -void ResetBg0(void); +void InitTextBoxGfxAndPrinters(void); u16 RunTextPrinters_CheckPrinter0Active(void); u16 AddTextPrinterParameterized2(u8 windowId, u8 fontId, const u8 *str, u8 speed, void (*callback)(struct TextPrinterTemplate *, u16), u8 fgColor, u8 bgColor, u8 shadowColor); void AddTextPrinterDiffStyle(bool8 allowSkippingDelayWithButtonPress); diff --git a/include/palette.h b/include/palette.h index 145d6e6b6..55054b63d 100644 --- a/include/palette.h +++ b/include/palette.h @@ -16,6 +16,10 @@ #define PALETTE_FADE_STATUS_DONE 0 #define PALETTE_FADE_STATUS_LOADING 0xFF +#define PALETTES_BG 0x0000FFFF +#define PALETTES_OBJECTS 0xFFFF0000 +#define PALETTES_ALL (PALETTES_BG | PALETTES_OBJECTS) + enum { FAST_FADE_IN_FROM_WHITE, diff --git a/include/save.h b/include/save.h index 3c1962f28..b49442193 100644 --- a/include/save.h +++ b/include/save.h @@ -114,6 +114,6 @@ bool8 sub_80DA4A0(void); u8 Save_LoadGameData(u8 saveType); u32 TryCopySpecialSaveSection(u8 sector, u8* dst); u32 TryWriteSpecialSaveSection(u8 sector, u8* src); -void Task_SaveGame_UpdatedLinkRecords(u8 taskId); +void Task_LinkSave(u8 taskId); #endif // GUARD_SAVE_H diff --git a/src/battle_anim_effects_2.c b/src/battle_anim_effects_2.c index ff9e64cb9..b2342a0c9 100644 --- a/src/battle_anim_effects_2.c +++ b/src/battle_anim_effects_2.c @@ -1532,7 +1532,7 @@ void AnimAirWaveProjectile(struct Sprite *sprite) { sprite->data[0] = 8; task->data[5] = 4; - a = MathUtil_Inv16(0x1000); + a = invfx16(0x1000); sprite->pos1.x += sprite->pos2.x; sprite->pos1.y += sprite->pos2.y; sprite->pos2.y = 0; @@ -1551,8 +1551,8 @@ void AnimAirWaveProjectile(struct Sprite *sprite) sprite->data[1] = 0; sprite->data[6] = 0; sprite->data[5] = 0; - sprite->data[3] = MathUtil_Mul16(MathUtil_Mul16(b, a), MathUtil_Inv16(0x1C0)); - sprite->data[4] = MathUtil_Mul16(MathUtil_Mul16(c, a), MathUtil_Inv16(0x1C0)); + sprite->data[3] = mulfx16(mulfx16(b, a), invfx16(0x1C0)); + sprite->data[4] = mulfx16(mulfx16(c, a), invfx16(0x1C0)); sprite->callback = AnimAirWaveProjectile_Step1; } } @@ -1643,18 +1643,18 @@ void AnimTask_AirCutterProjectile(u8 taskId) else xDiff = attackerX - targetX; - gTasks[taskId].data[5] = MathUtil_Mul16(xDiff, MathUtil_Inv16(gBattleAnimArgs[2] & ~1)); - gTasks[taskId].data[6] = MathUtil_Mul16(gTasks[taskId].data[5], 0x80); + gTasks[taskId].data[5] = mulfx16(xDiff, invfx16(gBattleAnimArgs[2] & ~1)); + gTasks[taskId].data[6] = mulfx16(gTasks[taskId].data[5], 0x80); gTasks[taskId].data[7] = gBattleAnimArgs[2]; if (targetY >= attackerY) { yDiff = targetY - attackerY; - gTasks[taskId].data[8] = MathUtil_Mul16(yDiff, MathUtil_Inv16(gTasks[taskId].data[5])) & ~1; + gTasks[taskId].data[8] = mulfx16(yDiff, invfx16(gTasks[taskId].data[5])) & ~1; } else { yDiff = attackerY - targetY; - gTasks[taskId].data[8] = MathUtil_Mul16(yDiff, MathUtil_Inv16(gTasks[taskId].data[5])) | 1; + gTasks[taskId].data[8] = mulfx16(yDiff, invfx16(gTasks[taskId].data[5])) | 1; } gTasks[taskId].data[3] = gBattleAnimArgs[3]; diff --git a/src/battle_interface.c b/src/battle_interface.c index 4cc39e8aa..23614e4b1 100644 --- a/src/battle_interface.c +++ b/src/battle_interface.c @@ -19,9 +19,6 @@ #undef abs #define abs(a) ((a) < 0 ? -(a) : (a)) -#define Q_24_8(n) ((s32)((n) * 256)) -#define Q_24_8_TO_INT(n) ((int)((n) >> 8)) - struct TestingBar { s32 maxValue; diff --git a/src/berry.c b/src/berry.c index c5b8af7f8..680f21e3d 100644 --- a/src/berry.c +++ b/src/berry.c @@ -867,50 +867,50 @@ const struct Berry gBerries[] = { }; -const struct BerryCrushStats gBerryCrushStats[] = { - { 50, 20}, - { 50, 20}, - { 50, 20}, - { 50, 20}, - { 50, 20}, - { 50, 30}, - { 50, 30}, - { 50, 30}, - { 50, 30}, - { 50, 30}, - { 60, 50}, - { 60, 50}, - { 60, 50}, - { 60, 50}, - { 60, 50}, - { 80, 70}, - { 80, 70}, - { 80, 70}, - { 80, 70}, - { 80, 70}, - {100, 100}, - {100, 100}, - {100, 100}, - {100, 100}, - {100, 100}, - {130, 150}, - {130, 150}, - {130, 150}, - {130, 150}, - {130, 150}, - {160, 250}, - {160, 250}, - {160, 250}, - {160, 250}, - {160, 250}, - {180, 500}, - {180, 500}, - {180, 500}, - {180, 500}, - {180, 500}, - {200, 750}, - {200, 750}, - {150, 200} +const struct BerryCrushStats gBerryCrush_BerryData[] = { + [ITEM_CHERI_BERRY - FIRST_BERRY_INDEX] = { 50, 20}, + [ITEM_CHESTO_BERRY - FIRST_BERRY_INDEX] = { 50, 20}, + [ITEM_PECHA_BERRY - FIRST_BERRY_INDEX] = { 50, 20}, + [ITEM_RAWST_BERRY - FIRST_BERRY_INDEX] = { 50, 20}, + [ITEM_ASPEAR_BERRY - FIRST_BERRY_INDEX] = { 50, 20}, + [ITEM_LEPPA_BERRY - FIRST_BERRY_INDEX] = { 50, 30}, + [ITEM_ORAN_BERRY - FIRST_BERRY_INDEX] = { 50, 30}, + [ITEM_PERSIM_BERRY - FIRST_BERRY_INDEX] = { 50, 30}, + [ITEM_LUM_BERRY - FIRST_BERRY_INDEX] = { 50, 30}, + [ITEM_SITRUS_BERRY - FIRST_BERRY_INDEX] = { 50, 30}, + [ITEM_FIGY_BERRY - FIRST_BERRY_INDEX] = { 60, 50}, + [ITEM_WIKI_BERRY - FIRST_BERRY_INDEX] = { 60, 50}, + [ITEM_MAGO_BERRY - FIRST_BERRY_INDEX] = { 60, 50}, + [ITEM_AGUAV_BERRY - FIRST_BERRY_INDEX] = { 60, 50}, + [ITEM_IAPAPA_BERRY - FIRST_BERRY_INDEX] = { 60, 50}, + [ITEM_RAZZ_BERRY - FIRST_BERRY_INDEX] = { 80, 70}, + [ITEM_BLUK_BERRY - FIRST_BERRY_INDEX] = { 80, 70}, + [ITEM_NANAB_BERRY - FIRST_BERRY_INDEX] = { 80, 70}, + [ITEM_WEPEAR_BERRY - FIRST_BERRY_INDEX] = { 80, 70}, + [ITEM_PINAP_BERRY - FIRST_BERRY_INDEX] = { 80, 70}, + [ITEM_POMEG_BERRY - FIRST_BERRY_INDEX] = {100, 100}, + [ITEM_KELPSY_BERRY - FIRST_BERRY_INDEX] = {100, 100}, + [ITEM_QUALOT_BERRY - FIRST_BERRY_INDEX] = {100, 100}, + [ITEM_HONDEW_BERRY - FIRST_BERRY_INDEX] = {100, 100}, + [ITEM_GREPA_BERRY - FIRST_BERRY_INDEX] = {100, 100}, + [ITEM_TAMATO_BERRY - FIRST_BERRY_INDEX] = {130, 150}, + [ITEM_CORNN_BERRY - FIRST_BERRY_INDEX] = {130, 150}, + [ITEM_MAGOST_BERRY - FIRST_BERRY_INDEX] = {130, 150}, + [ITEM_RABUTA_BERRY - FIRST_BERRY_INDEX] = {130, 150}, + [ITEM_NOMEL_BERRY - FIRST_BERRY_INDEX] = {130, 150}, + [ITEM_SPELON_BERRY - FIRST_BERRY_INDEX] = {160, 250}, + [ITEM_PAMTRE_BERRY - FIRST_BERRY_INDEX] = {160, 250}, + [ITEM_WATMEL_BERRY - FIRST_BERRY_INDEX] = {160, 250}, + [ITEM_DURIN_BERRY - FIRST_BERRY_INDEX] = {160, 250}, + [ITEM_BELUE_BERRY - FIRST_BERRY_INDEX] = {160, 250}, + [ITEM_LIECHI_BERRY - FIRST_BERRY_INDEX] = {180, 500}, + [ITEM_GANLON_BERRY - FIRST_BERRY_INDEX] = {180, 500}, + [ITEM_SALAC_BERRY - FIRST_BERRY_INDEX] = {180, 500}, + [ITEM_PETAYA_BERRY - FIRST_BERRY_INDEX] = {180, 500}, + [ITEM_APICOT_BERRY - FIRST_BERRY_INDEX] = {180, 500}, + [ITEM_LANSAT_BERRY - FIRST_BERRY_INDEX] = {200, 750}, + [ITEM_STARF_BERRY - FIRST_BERRY_INDEX] = {200, 750}, + [ITEM_ENIGMA_BERRY - FIRST_BERRY_INDEX] = {150, 200} }; // Leftover from R/S diff --git a/src/berry_crush.c b/src/berry_crush.c index 05be05802..4b34b054d 100644 --- a/src/berry_crush.c +++ b/src/berry_crush.c @@ -14,6 +14,7 @@ #include "item_menu_icons.h" #include "link.h" #include "link_rfu.h" +#include "list_menu.h" #include "math_util.h" #include "menu.h" #include "minigame_countdown.h" @@ -30,76 +31,190 @@ #include "constants/songs.h" #include "constants/items.h" +#define MAX_TIME (10 * 60 * 60) // Timer can go up to 9:59:59 + +#define TAG_CRUSHER_BASE 1 +#define PALTAG_EFFECT 2 // The next two gfx tags share this pal tag +#define GFXTAG_IMPACT 2 +#define GFXTAG_SPARKLE 3 +#define TAG_TIMER_DIGITS 4 +#define TAG_PLAYER1_BERRY 5 +#define TAG_PLAYER2_BERRY 6 +#define TAG_PLAYER3_BERRY 7 +#define TAG_PLAYER4_BERRY 8 +#define TAG_PLAYER5_BERRY 9 + #define TAG_COUNTDOWN 0x1000 +#define CRUSHER_START_Y (-104) + enum { - BCTEXT_AREYOUREADY, - BCTEXT_WAITFOROTHERS, - BCTEXT_GAINEDPOWDER, - BCTEXT_RECORDINGRESULTS, - BCTEXT_ASKPLAYAGAIN, - BCTEXT_CANCEL_NOBERRIES, - BCTEXT_CANCEL_DROPPEDOUT, - BCTEXT_TIMEUP, - BCTEXT_COMMSTANDBY, + RUN_CMD, + SCHEDULE_CMD, }; enum { - BCCMD_BeginNormalPaletteFade = 1, - BCCMD_WaitPaletteFade, - BCCMD_PrintMessage, - BCCMD_InitGfx, - BCCMD_TeardownGfx, - BCCMD_SignalReadyToBegin, - BCCMD_AskPickBerry, - BCCMD_GoToBerryPouch, - BCCMD_WaitForOthersToPickBerries, - BCCMD_DropBerriesIntoCrusher, - BCCMD_DropLid, - BCCMD_Countdown, - BCCMD_PlayGame_Master, - BCCMD_PlayGame_Slave, - BCCMD_FinishGame, - BCCMD_HandleTimeUp, - BCCMD_TabulateResults, - BCCMD_ShowResults, - BCCMD_SaveTheGame, - BCCMD_AskPlayAgain, - BCCMD_CommunicatePlayAgainResponses, - BCCMD_FadeOutToPlayAgain, - BCCMD_PlayAgainFailureMessage, - BCCMD_GracefulExit, - BCCMD_Quit, + MSG_PICK_BERRY, + MSG_WAIT_PICK, + MSG_POWDER, + MSG_SAVING, + MSG_PLAY_AGAIN, + MSG_NO_BERRIES, + MSG_DROPPED, + MSG_TIMES_UP, + MSG_COMM_STANDBY, }; +enum { + CMD_NONE = 0, + CMD_FADE, + CMD_WAIT_FADE, + CMD_PRINT_MSG, + CMD_SHOW_GAME, + CMD_HIDE_GAME, + CMD_READY_BEGIN, + CMD_ASK_PICK_BERRY, + CMD_PICK_BERRY, + CMD_WAIT_BERRIES, + CMD_DROP_BERRIES, + CMD_DROP_LID, + CMD_COUNTDOWN, + CMD_PLAY_GAME_LEADER, + CMD_PLAY_GAME_MEMBER, + CMD_FINISH_GAME, + CMD_TIMES_UP, + CMD_CALC_RESULTS, + CMD_SHOW_RESULTS, + CMD_SAVE, + CMD_ASK_PLAY_AGAIN, + CMD_COMM_PLAY_AGAIN, + CMD_PLAY_AGAIN_YES, + CMD_PLAY_AGAIN_NO, + CMD_CLOSE_LINK, + CMD_QUIT, +}; +#define F_MSG_CLEAR (1 << 0) +#define F_MSG_EXPAND (1 << 1) + +// Main states for the game. Many are assigned but never checked +enum { + STATE_INIT = 1, + STATE_RESET, + STATE_PICK_BERRY, + STATE_DROP_BERRIES, + STATE_DROP_LID, + STATE_COUNTDOWN, + STATE_PLAYING, + STATE_FINISHED, + STATE_TIMES_UP, + STATE_10, // Unused + STATE_RESULTS_PRESSES, + STATE_RESULTS_RANDOM, + STATE_RESULTS_CRUSHING, + STATE_14, // Unused + STATE_PLAY_AGAIN, +}; + +#define RESULTS_STATE_START STATE_RESULTS_PRESSES +#define RESULTS_STATE_END STATE_RESULTS_CRUSHING + +// IDs for each results page that shows in succession at the game's end. +// Only 3 pages are shown for a given game. Presses and Crushing are always shown 1st and 3rd. +// The 2nd page is random, and can be rankings for either Neatness, Cooperative, or Power. +enum { + RESULTS_PAGE_PRESSES, + RESULTS_PAGE_RANDOM, + RESULTS_PAGE_CRUSHING, + NUM_RESULTS_PAGES, +}; +// Random pages, see above +// "Neatness" is how many of the player's inputs were at a regular interval +// "Cooperative" is how often the player pressed A at the same time as others +// "Power" is how much of the time the player spent pressing A +enum { + RESULTS_PAGE_NEATNESS, + RESULTS_PAGE_COOPERATIVE, + RESULTS_PAGE_POWER, + NUM_RANDOM_RESULTS_PAGES +}; + +#define PLAY_AGAIN_YES 0 +#define PLAY_AGAIN_NO 1 +#define PLAY_AGAIN_NO_BERRIES 3 + +enum { + COLORID_GRAY, + COLORID_BLACK, + COLORID_LIGHT_GRAY, + COLORID_BLUE, + COLORID_GREEN, + COLORID_RED, +}; + +// Flags for the inputFlags field +// Field is 16 bits; 3 bits for each player, last bit is unused +// The first two bits are interchangeable +// Needlessly complicated system, the inputState field is sufficient by itself +#define F_INPUT_HIT_A (1 << 0) +#define F_INPUT_HIT_B (1 << 1) +#define F_INPUT_HIT_SYNC (1 << 2) // Input at same time as another player +#define INPUT_FLAGS_PER_PLAYER 3 +#define INPUT_FLAG_MASK ((1 << INPUT_FLAGS_PER_PLAYER) - 1) + +// Values for the inputState field +enum { + INPUT_STATE_NONE, + INPUT_STATE_HIT, // Hit the crusher + INPUT_STATE_HIT_SYNC, // Hit the crusher at same time as another player +}; + +// No reason for this to be 2 +// Simply a flag for whether a given player has sent their data this round +// Data is only sent if the player is the leader or if they pressed A +#define SEND_GAME_STATE 2 + struct BerryCrushGame_Player { - u8 unk0[PLAYER_NAME_LENGTH + 1 + 4]; - u16 unkC; - u16 unkE; - u16 unk10; - u16 unk12; - u16 unk14; - u16 unk16; - u16 unk18; - u16 unk1A; - u8 unk1B; - u8 unk1C; + u8 name[PLAYER_NAME_LENGTH + 1 + 4]; + u16 berryId; + u16 inputTime; + u16 neatInputStreak; + u16 timeSincePrevInput; + u16 maxNeatInputStreak; + u16 numAPresses; + u16 numSyncedAPresses; + u16 timePressingA; + u8 inputFlags; + u8 inputState; }; -struct BerryCrushGame_4E +struct BerryCrushGame_LocalState { - u16 unk0; - u16 unk2; - u8 unk4_0:1; - u8 unk4_1:1; - u8 unk4_2:1; - u8 unk4_3:5; - s8 unk5; - u16 unk6; - u16 unk8; - u16 unkA; - u16 unkC; + u16 sendFlag; + u8 endGame:1; + u8 bigSparkle:1; + u8 pushedAButton:1; + u8 playerPressedAFlags:5; + s8 vibration; + u16 depth; + u16 timer; + u16 inputFlags; + u16 sparkleAmount; +}; + +struct BerryCrushGame_LinkState +{ + u16 rfuCmd; + u16 sendFlag; + u8 endGame:1; + u8 bigSparkle:1; + u8 pushedAButton:1; + u8 playerPressedAFlags:5; + s8 vibration; + u16 depth; + u16 timer; + u16 inputFlags; + u16 sparkleAmount; }; struct BerryCrushGame_40 @@ -114,252 +229,267 @@ struct BerryCrushGame_40 s16 unkE; }; -struct BerryCrushGame_5C +// Flags for the inputFlags field +// Field is 16 bits; 3 bits for each player, last bit is unused +// The first two bits are interchangeable +// Needlessly complicated system, the inputState field is sufficient by itself +#define F_INPUT_HIT_A (1 << 0) +#define F_INPUT_HIT_B (1 << 1) +#define F_INPUT_HIT_SYNC (1 << 2) // Input at same time as another player +#define INPUT_FLAGS_PER_PLAYER 3 +#define INPUT_FLAG_MASK ((1 << INPUT_FLAGS_PER_PLAYER) - 1) + +struct BerryCrushGame_Results { - u16 unk00; - u8 unk02_0:1; - u8 unk02_1:1; - u8 pushedAButton:1; - u8 unk02_3:5; - s8 unk03; - u16 unk04; - u16 unk06; - u16 unk08; - u16 unk0A; + u32 powder; + u16 time; + u16 targetPressesPerSec; // Never read + u16 silkiness; + u16 totalAPresses; + u16 stats[2][MAX_RFU_PLAYERS]; + u8 playerIdsRanked[2][MAX_RFU_PLAYERS + 3]; }; -struct BerryCrushGame_68 +// playerIdsRanked above has 3 additional elements after the players. +// Only 1 of these 2*3 is ever used, and it stores the id for which +// random results page to show. Its define below is for readability. +#define randomPageId playerIdsRanked[0][7] + +struct BerryCrushPlayerCoords { - u32 unk00; - u16 unk04; - u16 unk06; - u16 unk08; - u16 unk0A; - // 0: Number of A presses - // 1: Neatness - u16 stats[2][5]; - u8 unk20[2][8]; + u8 playerId; + u8 windowGfxX; + u8 windowGfxY; + s16 impactXOffset; + s16 impactYOffset; + s16 berryXOffset; + s16 berryXDest; }; -struct BerryCrushPlayerSeatCoords +struct BerryCrushGame_Gfx { - u8 unk0; - u8 unk1; - u8 unk2; - s16 unk4; - s16 unk6; - s16 unk8; - s16 unkA; -}; - -struct BerryCrushGame_138 -{ - u8 animBerryIdx; - u8 unk1; - u8 unk2; - u8 unk3; + u8 counter; + u8 vibrationIdx; + u8 numVibrations; + bool8 vibrating; s16 minutes; s16 secondsInt; s16 secondsFrac; - const struct BerryCrushPlayerSeatCoords *seatCoords[5]; + const struct BerryCrushPlayerCoords *playerCoords[MAX_RFU_PLAYERS]; struct Sprite *coreSprite; - struct Sprite *impactSprites[5]; - struct Sprite *berrySprites[5]; + struct Sprite *impactSprites[MAX_RFU_PLAYERS]; + struct Sprite *berrySprites[MAX_RFU_PLAYERS]; struct Sprite *sparkleSprites[11]; struct Sprite *timerSprites[2]; - u8 unk80; - u8 filler81; - u8 unk82; - u8 unk83[5]; - u16 bgBuffers[4][0x800]; + u8 resultsState; + u8 unused; + u8 resultsIndowId; + u8 nameWindowIds[MAX_RFU_PLAYERS]; + u16 bgBuffers[4][BG_SCREEN_SIZE]; }; +struct BerryCrushGame; + +typedef u32 (*CmdFunc)(struct BerryCrushGame * game, u8 * args); + struct BerryCrushGame { MainCallback savedCallback; - u32 (*cmdCallback)(struct BerryCrushGame *, u8 *); + CmdFunc cmdCallback; u8 localId; u8 playerCount; u8 mainTask; u8 textSpeed; u8 cmdState; - u8 unkD; + u8 unused; // Never read u8 nextCmd; u8 afterPalFadeCmd; - u16 unk10; + u16 cmdTimer; u16 gameState; - u16 unk14; + u16 playAgainState; u16 pressingSpeed; - s16 unk18; - s16 unk1A; + s16 targetAPresses; + s16 totalAPresses; s32 powder; - s32 unk20; - u8 unk24; - u8 unk25_0:1; - u8 unk25_1:1; - u8 unk25_2:1; - u8 unk25_3:1; - u8 unk25_4:1; - u8 unk25_5:3; - u16 unk26; + s32 targetDepth; + u8 newDepth; + u8 noRoomForPowder:1; // Never read + u8 newRecord:1; + u8 playedSound:1; + u8 endGame:1; + u8 bigSparkle:1; + u8 sparkleAmount:3; + u16 leaderTimer; u16 timer; s16 depth; s16 vibration; - s16 unk2E; - s16 unk30; - s16 unk32; - s16 unk34; - u8 commandParams[0xC]; + s16 bigSparkleCounter; + s16 numBigSparkles; + s16 numBigSparkleChecks; + s16 sparkleCounter; + u8 commandParams[12]; u16 sendCmd[6]; u16 recvCmd[7]; - struct BerryCrushGame_5C localState; - struct BerryCrushGame_68 unk68; - struct BerryCrushGame_Player unk98[5]; - struct BerryCrushGame_138 spritesManager; + struct BerryCrushGame_LocalState localState; + struct BerryCrushGame_Results results; + struct BerryCrushGame_Player players[5]; + struct BerryCrushGame_Gfx gfx; }; -static EWRAM_DATA struct BerryCrushGame *sBerryCrushGamePtr = NULL; +static EWRAM_DATA struct BerryCrushGame *sGame = NULL; -static void BerryCrush_InitPlayerNamesAndTextSpeed(struct BerryCrushGame *game); -static void CB2_ReturnToBerryCrushGameFromBerryPouch(void); -static void VBlankCB_BerryCrush(void); -static void CB2_BerryCrush(void); -static void Task_RunBerryCrushGame(u8 taskId); -static u32 BerryCrushCommand_BeginNormalPaletteFade(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_WaitPaletteFade(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_PrintMessage(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_InitGfx(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_TeardownGfx(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_SignalReadyToBegin(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_AskPickBerry(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_GoToBerryPouch(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_WaitForOthersToPickBerries(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_DropBerriesIntoCrusher(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_DropLid(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_Countdown(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_PlayGame_Master(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_PlayGame_Slave(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_FinishGame(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_HandleTimeUp(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_TabulateResults(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_ShowResults(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_SaveTheGame(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_AskPlayAgain(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_CommunicatePlayAgainResponses(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_FadeOutToPlayAgain(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_PlayAgainFailureMessage(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_GracefulExit(struct BerryCrushGame * game, u8 *params); -static u32 BerryCrushCommand_Quit(struct BerryCrushGame * game, u8 *params); -static void sub_814D4D8(struct BerryCrushGame * game); -static void BerryCrush_SetShowMessageParams(u8 *params, u8 stringId, u8 flags, u16 waitKeys, u8 followupCmd); -static void FramesToMinSec(struct BerryCrushGame_138 * arg0, u16 arg1); +static void SetNamesAndTextSpeed(struct BerryCrushGame *game); +static void GetBerryFromBag(void); +static void VBlankCB(void); +static void MainCB(void); +static void MainTask(u8 taskId); +static u32 Cmd_BeginNormalPaletteFade(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_WaitPaletteFade(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_PrintMessage(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_ShowGameDisplay(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_HideGameDisplay(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_SignalReadyToBegin(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_AskPickBerry(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_GoToBerryPouch(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_WaitForOthersToPickBerries(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_DropBerriesIntoCrusher(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_DropLid(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_Countdown(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_PlayGame_Leader(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_PlayGame_Member(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_FinishGame(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_HandleTimeUp(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_TabulateResults(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_ShowResults(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_SaveGame(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_AskPlayAgain(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_CommunicatePlayAgainResponses(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_PlayAgain(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_StopGame(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_CloseLink(struct BerryCrushGame * game, u8 *args); +static u32 Cmd_Quit(struct BerryCrushGame * game, u8 *args); +static void ResetGame(struct BerryCrushGame * game); +static void SetPrintMessageArgs(u8 *args, u8 stringId, u8 flags, u16 waitKeys, u8 followupCmd); +static void FramesToMinSec(struct BerryCrushGame_Gfx * gfx, u16 frames); static void PrintTextCentered(u8 windowId, u8 left, u8 colorId, const u8 *string); -static void PrintBerryCrushResultWindow(struct BerryCrushGame * sp0C, u8 sp10, u8 sp14, u8 r3); -static void sub_814E32C(struct BerryCrushGame * r8); +static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 y); +static void printCrushingResults(struct BerryCrushGame * game); static void Task_ShowBerryCrushRankings(u8 r4); -static void BerryCrush_PrintTimeOnSprites(struct BerryCrushGame_138 * r4, u16 r1); -static void sub_814EB38(struct BerryCrushGame * r5); -static void sub_814EBB0(struct BerryCrushGame * r6); -static void sub_814EC80(struct BerryCrushGame * r6); -static void sub_814ECE0(struct BerryCrushGame * r6); -static void sub_814EF10(struct BerryCrushGame * r5); -static void SpriteCB_BerryCrushImpact(struct Sprite * sprite); -static void sub_814EFFC(struct Sprite * sprite); -static void sub_814F044(struct Sprite * sprite); -static void sub_814F0D8(struct Sprite * sprite); -struct BerryCrushGame *GetBerryCrushGame(void); -void StartBerryCrush(MainCallback callback); -u32 ExitBerryCrushWithCallback(MainCallback callback); -void CB2_BerryCrush_GoToBerryPouch(void); -void BerryCrush_SetVBlankCallback(void); -void BerryCrush_UnsetVBlankCallback(void); -void BerryCrush_UpdateSav2Records(void); -void BerryCrush_RunOrScheduleCommand(u16 command, u8 runMode, u8 *params); -void BerryCrush_SetPaletteFadeParams(u8 *params, bool8 communicateAfter, u32 selectedPals, s8 delay, u8 startY, u8 targetY, u16 palette); -int sub_814D9CC(struct BerryCrushGame *arg0); -int BerryCrush_InitBgs(void); -int BerryCrush_TeardownBgs(void); -void BerryCrush_CreateBerrySprites(struct BerryCrushGame *arg0, struct BerryCrushGame_138 *arg1); -void BerryCrushFreeBerrySpriteGfx(struct BerryCrushGame *arg0, struct BerryCrushGame_138 *arg1); -void sub_814DC5C(struct BerryCrushGame *arg0, struct BerryCrushGame_138 *arg1); -bool32 sub_814DE50(struct BerryCrushGame *arg0, struct BerryCrushGame_138 *arg1); -bool32 sub_814E644(struct BerryCrushGame *arg0, struct BerryCrushGame_138 *arg1); -void sub_814E80C(struct BerryCrushGame *arg0); -void sub_814DA04(struct BerryCrushGame *arg0); -void BerryCrush_HideTimerSprites(struct BerryCrushGame_138 *arg0); -void SpriteCB_DropBerryIntoCrusher(struct Sprite * sprite); -void ShowBerryCrushRankings(void); +static void PrintTimer(struct BerryCrushGame_Gfx * gfx, u16 frames); +static void CreatePlayerNameWindows(struct BerryCrushGame * game); +static void DrawPlayerNameWindows(struct BerryCrushGame * game); +static void CopyPlayerNameWindowGfxToBg(struct BerryCrushGame * game); +static void CreateGameSprites(struct BerryCrushGame * game); +static void DestroyGameSprites(struct BerryCrushGame * game); +static void SpriteCB_Impact(struct Sprite * sprite); +static void SpriteCB_Sparkle_End(struct Sprite * sprite); +static void SpriteCB_Sparkle(struct Sprite * sprite); +static void SpriteCB_Sparkle_Init(struct Sprite * sprite); +static struct BerryCrushGame *GetBerryCrushGame(void); +static u32 QuitBerryCrush(MainCallback callback); +static void ChooseBerry(void); +static void BerryCrush_SetVBlankCallback(void); +static void BerryCrush_InitVBlankCB(void); +static void SaveResults(void); +static void RunOrScheduleCommand(u16 command, u8 runMode, u8 *args); +static void SetPaletteFadeArgs(u8 *args, bool8 communicateAfter, u32 selectedPals, s8 delay, u8 startY, u8 targetY, u16 palette); +static s32 UpdateGame(struct BerryCrushGame *game); +static s32 ShowGameDisplay(void); +static s32 HideGameDisplay(void); +static void CreateBerrySprites(struct BerryCrushGame *game, struct BerryCrushGame_Gfx *spritesManager); +static void BerryCrushFreeBerrySpriteGfx(struct BerryCrushGame *game, struct BerryCrushGame_Gfx *gfx); +static void UpdateInputEffects(struct BerryCrushGame *game, struct BerryCrushGame_Gfx *gfx); +static bool32 AreEffectsFinished(struct BerryCrushGame *game, struct BerryCrushGame_Gfx *gfx); +static bool32 OpenResultsWindow(struct BerryCrushGame *game, struct BerryCrushGame_Gfx *spriteManager); +static void CloseResultsWindow(struct BerryCrushGame *game); +static void ResetCrusherPos(struct BerryCrushGame *game); +static void HideTimer(struct BerryCrushGame_Gfx *gfx); +static void SpriteCB_DropBerryIntoCrusher(struct Sprite * sprite); -static const u8 gUnknown_846E2E0[] = {0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80}; -static const u8 gUnknown_846E2E8[] = {0x00, 0x01, 0x02, 0x03, 0x05, 0x00, 0x00, 0x00}; - -static const s8 gUnknown_846E2F0[][7] = { - {0x04, 0x01, 0x00, 0xff, 0x00, 0x00, 0x00}, - {0x04, 0x02, 0x00, 0xff, 0x00, 0x00, 0x00}, - {0x04, 0x02, 0x00, 0xfe, 0x00, 0x00, 0x00}, - {0x06, 0x03, 0x01, 0xff, 0xfd, 0xff, 0x00}, - {0x06, 0x04, 0x01, 0xfe, 0xfc, 0xfe, 0x00}, +static const u8 sBitTable[] = { + 1 << 0, + 1 << 1, + 1 << 2, + 1 << 3, + 1 << 4, + 1 << 5, + 1 << 6, + 1 << 7, }; -ALIGNED(4) const u8 gUnknown_846E314[][4] = { - {0x03, 0x02, 0x01, 0x00}, - {0x03, 0x03, 0x01, 0x00}, - {0x03, 0x03, 0x02, 0x00}, - {0x03, 0x04, 0x02, 0x00}, - {0x03, 0x05, 0x03, 0x00} +// Additional A presses are counted depending on the number of players +// The bonus of 5 is unobtainable +static const u8 sSyncPressBonus[MAX_RFU_PLAYERS] = {0, 1, 2, 3, 5 }; + +ALIGNED(4) +static const s8 sIntroOutroVibrationData[][7] = { + { 4, 1, 0, -1, 0, 0, 0}, + { 4, 2, 0, -1, 0, 0, 0}, + { 4, 2, 0, -2, 0, 0, 0}, + { 6, 3, 1, -1, -3, -1, 0}, + { 6, 4, 1, -2, -4, -2, 0}, }; -static const u8 *const sBerryCrushMessages[] = { - gText_BerryCrush_AreYouReady, - gText_BerryCrush_WaitForOthersToChooseBerry, - gText_BerryCrush_GainedXUnitsOfPowder, - gText_BerryCrush_RecordingGameResults, - gText_BerryCrush_WantToPlayAgain, - gText_BerryCrush_NoBerries, - gText_BerryCrush_MemberDroppedOut, - gText_BerryCrush_TimeUp, - gText_BerryCrush_CommunicationStandby +ALIGNED(4) +const u8 sVibrationData[MAX_RFU_PLAYERS][4] = { + { 3, 2, 1, 0}, + { 3, 3, 1, 0}, + { 3, 3, 2, 0}, + { 3, 4, 2, 0}, + { 3, 5, 3, 0} }; -static u32 (*const sBerryCrushCommands[])(struct BerryCrushGame * berryCrushGame, u8 *params) = { - NULL, - BerryCrushCommand_BeginNormalPaletteFade, - BerryCrushCommand_WaitPaletteFade, - BerryCrushCommand_PrintMessage, - BerryCrushCommand_InitGfx, - BerryCrushCommand_TeardownGfx, - BerryCrushCommand_SignalReadyToBegin, - BerryCrushCommand_AskPickBerry, - BerryCrushCommand_GoToBerryPouch, - BerryCrushCommand_WaitForOthersToPickBerries, - BerryCrushCommand_DropBerriesIntoCrusher, - BerryCrushCommand_DropLid, - BerryCrushCommand_Countdown, - BerryCrushCommand_PlayGame_Master, - BerryCrushCommand_PlayGame_Slave, - BerryCrushCommand_FinishGame, - BerryCrushCommand_HandleTimeUp, - BerryCrushCommand_TabulateResults, - BerryCrushCommand_ShowResults, - BerryCrushCommand_SaveTheGame, - BerryCrushCommand_AskPlayAgain, - BerryCrushCommand_CommunicatePlayAgainResponses, - BerryCrushCommand_FadeOutToPlayAgain, - BerryCrushCommand_PlayAgainFailureMessage, - BerryCrushCommand_GracefulExit, - BerryCrushCommand_Quit +static const u8 *const sMessages[] = { + [MSG_PICK_BERRY] = gText_BerryCrush_AreYouReady, + [MSG_WAIT_PICK] = gText_BerryCrush_WaitForOthersToChooseBerry, + [MSG_POWDER] = gText_BerryCrush_GainedXUnitsOfPowder, + [MSG_SAVING] = gText_BerryCrush_RecordingGameResults, + [MSG_PLAY_AGAIN] = gText_BerryCrush_WantToPlayAgain, + [MSG_NO_BERRIES] = gText_BerryCrush_NoBerries, + [MSG_DROPPED] = gText_BerryCrush_MemberDroppedOut, + [MSG_TIMES_UP] = gText_BerryCrush_TimeUp, + [MSG_COMM_STANDBY] = gText_BerryCrush_CommunicationStandby }; -static const u8 gUnknown_846E3B4[][4] = { - {0x02, 0x04, 0x06, 0x07}, - {0x03, 0x05, 0x08, 0x0b}, - {0x03, 0x07, 0x0b, 0x0f}, - {0x04, 0x08, 0x0c, 0x11} +static u32 (*const sBerryCrushCommands[])(struct BerryCrushGame * berryCrushGame, u8 *args) = { + [CMD_NONE] = NULL, + [CMD_FADE] = Cmd_BeginNormalPaletteFade, + [CMD_WAIT_FADE] = Cmd_WaitPaletteFade, + [CMD_PRINT_MSG] = Cmd_PrintMessage, + [CMD_SHOW_GAME] = Cmd_ShowGameDisplay, + [CMD_HIDE_GAME] = Cmd_HideGameDisplay, + [CMD_READY_BEGIN] = Cmd_SignalReadyToBegin, + [CMD_ASK_PICK_BERRY] = Cmd_AskPickBerry, + [CMD_PICK_BERRY] = Cmd_GoToBerryPouch, + [CMD_WAIT_BERRIES] = Cmd_WaitForOthersToPickBerries, + [CMD_DROP_BERRIES] = Cmd_DropBerriesIntoCrusher, + [CMD_DROP_LID] = Cmd_DropLid, + [CMD_COUNTDOWN] = Cmd_Countdown, + [CMD_PLAY_GAME_LEADER] = Cmd_PlayGame_Leader, + [CMD_PLAY_GAME_MEMBER] = Cmd_PlayGame_Member, + [CMD_FINISH_GAME] = Cmd_FinishGame, + [CMD_TIMES_UP] = Cmd_HandleTimeUp, + [CMD_CALC_RESULTS] = Cmd_TabulateResults, + [CMD_SHOW_RESULTS] = Cmd_ShowResults, + [CMD_SAVE] = Cmd_SaveGame, + [CMD_ASK_PLAY_AGAIN] = Cmd_AskPlayAgain, + [CMD_COMM_PLAY_AGAIN] = Cmd_CommunicatePlayAgainResponses, + [CMD_PLAY_AGAIN_YES] = Cmd_PlayAgain, + [CMD_PLAY_AGAIN_NO] = Cmd_StopGame, + [CMD_CLOSE_LINK] = Cmd_CloseLink, + [CMD_QUIT] = Cmd_Quit }; -static const u8 gUnknown_846E3C4[] = {5, 7, 9, 12}; +static const u8 sSparkleThresholds[MAX_RFU_PLAYERS - 1][4] = { + {2, 4, 6, 7}, // 2 players + {3, 5, 8, 11}, // 3 players + {3, 7, 11, 15}, // 4 players + {4, 8, 12, 17}, // 5 players +}; -static const u8 sReceivedPlayerBitmasks[] = {0x03, 0x07, 0x0F, 0x1F}; +static const u8 sBigSparkleThresholds[MAX_RFU_PLAYERS - 1] = {5, 7, 9, 12}; + +static const u8 sReceivedPlayerBitmasks[MAX_RFU_PLAYERS - 1] = {0x03, 0x07, 0x0F, 0x1F}; static const struct BgTemplate sBgTemplates[] = { { @@ -398,31 +528,12 @@ static const struct BgTemplate sBgTemplates[] = { }; static const u8 sBerryCrushTextColorTable[][3] = { - { - TEXT_COLOR_WHITE, - TEXT_COLOR_DARK_GRAY, - TEXT_COLOR_LIGHT_GRAY - }, { - TEXT_COLOR_TRANSPARENT, - TEXT_COLOR_WHITE, - TEXT_COLOR_DARK_GRAY - }, { - TEXT_COLOR_TRANSPARENT, - TEXT_COLOR_LIGHT_GRAY, - TEXT_COLOR_RED - }, { - TEXT_COLOR_WHITE, - TEXT_COLOR_BLUE, - TEXT_COLOR_LIGHT_BLUE - }, { - TEXT_COLOR_WHITE, - TEXT_COLOR_GREEN, - TEXT_COLOR_LIGHT_GREEN - }, { - TEXT_COLOR_WHITE, - TEXT_COLOR_RED, - TEXT_COLOR_LIGHT_RED - } + [COLORID_GRAY] = { TEXT_COLOR_WHITE, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_LIGHT_GRAY }, + [COLORID_BLACK] = { TEXT_COLOR_TRANSPARENT, TEXT_COLOR_WHITE, TEXT_COLOR_DARK_GRAY }, + [COLORID_LIGHT_GRAY] = { TEXT_COLOR_TRANSPARENT, TEXT_COLOR_LIGHT_GRAY, TEXT_COLOR_RED }, + [COLORID_BLUE] = { TEXT_COLOR_WHITE, TEXT_COLOR_BLUE, TEXT_COLOR_LIGHT_BLUE }, + [COLORID_GREEN] = { TEXT_COLOR_WHITE, TEXT_COLOR_GREEN, TEXT_COLOR_LIGHT_GREEN }, + [COLORID_RED] = { TEXT_COLOR_WHITE, TEXT_COLOR_RED, TEXT_COLOR_LIGHT_RED } }; static const struct WindowTemplate sWindowTemplate_BerryCrushRankings = { @@ -435,7 +546,7 @@ static const struct WindowTemplate sWindowTemplate_BerryCrushRankings = { .baseBlock = 0x001 }; -static const struct WindowTemplate gUnknown_846E3F8[] = { +static const struct WindowTemplate sWindowTemplates_PlayerNames[] = { { .bg = 0, .tilemapLeft = 0, @@ -479,8 +590,9 @@ static const struct WindowTemplate gUnknown_846E3F8[] = { }, DUMMY_WIN_TEMPLATE }; -static const struct WindowTemplate gUnknown_846E428[] = { - { +static const struct WindowTemplate sWindowTemplates_Results[] = { + + [STATE_RESULTS_PRESSES - RESULTS_STATE_START] = { .bg = 0, .tilemapLeft = 4, .tilemapTop = 2, @@ -488,7 +600,8 @@ static const struct WindowTemplate gUnknown_846E428[] = { .height = 16, .paletteNum = 0xF, .baseBlock = 0x001 - }, { + }, + [STATE_RESULTS_RANDOM - RESULTS_STATE_START] = { .bg = 0, .tilemapLeft = 4, .tilemapTop = 2, @@ -496,7 +609,8 @@ static const struct WindowTemplate gUnknown_846E428[] = { .height = 16, .paletteNum = 0xF, .baseBlock = 0x001 - }, { + }, + [STATE_RESULTS_CRUSHING - RESULTS_STATE_START] = { .bg = 0, .tilemapLeft = 3, .tilemapTop = 2, @@ -507,14 +621,13 @@ static const struct WindowTemplate gUnknown_846E428[] = { }, DUMMY_WIN_TEMPLATE }; -static const u8 gUnknown_846E448[][4] = { - { 6, 8, 9, 11 }, - { 12, 14, 15, 16} +static const u8 sResultsWindowHeights[][MAX_RFU_PLAYERS - 1] = { + { 6, 8, 9, 11 }, // "Preses" and "Neatness/Cooperative/Power" pages + { 12, 14, 15, 16 }, // "Crushing" page }; static const u32 sPressingSpeedConversionTable[] = { - // Decimal point is vertically aligned with the pixel - // directly between the >< below. + // Hundred-millionths of a second 50000000, // 50 25000000, // 25 12500000, // 12.5 @@ -525,41 +638,83 @@ static const u32 sPressingSpeedConversionTable[] = { 390625 // 0.390625 }; -static const u16 sBerryCrushCorePal[] = INCBIN_U16("graphics/link_games/unk_846E4D0.gbapal"); -static const u16 sBerryCrushImpactAndSparklesPal[] = INCBIN_U16("graphics/link_games/unk_846E7FC.gbapal"); -static const u16 sBerryCrushTImerPal[] = INCBIN_U16("graphics/link_games/unk_846ECC4.gbapal"); +static const u16 sBerryCrushCorePal[] = INCBIN_U16("graphics/berry_crush/crusher_base.gbapal"); +static const u16 sBerryCrushImpactAndSparklesPal[] = INCBIN_U16("graphics/berry_crush/impact.gbapal"); +static const u16 sBerryCrushTimerPal[] = INCBIN_U16("graphics/berry_crush/timer_digits.gbapal"); -static const u32 sBerryCrushCoreTiles[] = INCBIN_U32("graphics/link_games/unk_846E4D0.4bpp.lz"); -static const u32 sBerryCrushImpactTiles[] = INCBIN_U32("graphics/link_games/unk_846E7FC.4bpp.lz"); -static const u32 sBerryCrushPowderSparklesTiles[] = INCBIN_U32("graphics/link_games/unk_846EB78.4bpp.lz"); -static const u32 sBerryCrushTimerTiles[] = INCBIN_U32("graphics/link_games/unk_846ECC4.4bpp.lz"); +static const u32 sBerryCrushCoreTiles[] = INCBIN_U32("graphics/berry_crush/crusher_base.4bpp.lz"); +static const u32 sBerryCrushImpactTiles[] = INCBIN_U32("graphics/berry_crush/impact.4bpp.lz"); +static const u32 sBerryCrushPowderSparklesTiles[] = INCBIN_U32("graphics/berry_crush/sparkle.4bpp.lz"); +static const u32 sBerryCrushTimerTiles[] = INCBIN_U32("graphics/berry_crush/timer_digits.4bpp.lz"); -static const u32 gBerryCrushGrinderTopTilemap[] = INCBIN_U32("graphics/link_games/unk_846ED90.bin.lz"); -static const u32 gBerryCrushContainerCapTilemap[] = INCBIN_U32("graphics/link_games/unk_846EEC0.bin.lz"); -static const u32 gBerryCrushBackgroundTilemap[] = INCBIN_U32("graphics/link_games/unk_846F058.bin.lz"); +static const u32 sCrusherTop_Tilemap[] = INCBIN_U32("graphics/berry_crush/crusher_top.bin.lz"); +static const u32 sContainerCap_Tilemap[] = INCBIN_U32("graphics/berry_crush/container_cap.bin.lz"); +static const u32 sBg_Tilemap[] = INCBIN_U32("graphics/berry_crush/bg.bin.lz"); -static const u8 gUnknown_846F280[][5] = { +// Takes the number of players - 2 and a player id and returns the +// index into sPlayerCoords where that player should be seated +static const u8 gUnknown_846F280[MAX_RFU_PLAYERS - 1][MAX_RFU_PLAYERS] = { {1, 3}, {0, 1, 3}, {1, 3, 2, 4}, {0, 1, 3, 2, 4} }; -static const struct BerryCrushPlayerSeatCoords gUnknown_846F294[] = { - {0, 0, 0, 0, -16, 0, 0}, - {1, 0, 3, -28, -4, -24, 16}, - {2, 0, 6, -16, 20, -8, 16}, - {3, 20, 3, 28, -4, 32, -8}, - {4, 20, 6, 16, 20, 16, -8} +static const struct BerryCrushPlayerCoords sPlayerCoords[] = { + { + .playerId = 0, + .windowGfxX = 0, + .windowGfxY = 0, + .impactXOffset = 0, + .impactYOffset = -16, + .berryXOffset = 0, + .berryXDest = 0 + }, + { + .playerId = 1, + .windowGfxX = 0, + .windowGfxY = 3, + .impactXOffset = -28, + .impactYOffset = -4, + .berryXOffset = -24, + .berryXDest = 16 + }, + { + .playerId = 2, + .windowGfxX = 0, + .windowGfxY = 6, + .impactXOffset = -16, + .impactYOffset = 20, + .berryXOffset = -8, + .berryXDest = 16 + }, + { + .playerId = 3, + .windowGfxX = 20, + .windowGfxY = 3, + .impactXOffset = 28, + .impactYOffset = -4, + .berryXOffset = 32, + .berryXDest = -8 + }, + { + .playerId = 4, + .windowGfxX = 20, + .windowGfxY = 6, + .impactXOffset = 16, + .impactYOffset = 20, + .berryXOffset = 16, + .berryXDest = -8 + }, }; -static const s8 gUnknown_846F2D0[][2] = { +static const s8 sImpactCoords[][2] = { { 0, 0}, {-1, 0}, { 1, 1} }; -static const s8 gUnknown_846F2D6[][2] = { +static const s8 sSparkleCoords[][2] = { { 0, 0}, {-16, -4}, { 16, -4}, @@ -574,37 +729,41 @@ static const s8 gUnknown_846F2D6[][2] = { }; static const u16 sPlayerBerrySpriteTags[] = { - 5, 6, 7, 8, 9 + TAG_PLAYER1_BERRY, + TAG_PLAYER2_BERRY, + TAG_PLAYER3_BERRY, + TAG_PLAYER4_BERRY, + TAG_PLAYER5_BERRY, }; static const struct CompressedSpriteSheet sSpriteSheets[] = { - {sBerryCrushCoreTiles, 0x0800, 1}, - {sBerryCrushImpactTiles, 0x0e00, 2}, - {sBerryCrushPowderSparklesTiles, 0x0700, 3}, - {sBerryCrushTimerTiles, 0x02c0, 4}, + {sBerryCrushCoreTiles, 0x0800, TAG_CRUSHER_BASE}, + {sBerryCrushImpactTiles, 0x0e00, GFXTAG_IMPACT}, + {sBerryCrushPowderSparklesTiles, 0x0700, GFXTAG_SPARKLE}, + {sBerryCrushTimerTiles, 0x02c0, TAG_TIMER_DIGITS}, {} }; static const struct SpritePalette sSpritePals[] = { - {sBerryCrushCorePal, 1}, - {sBerryCrushImpactAndSparklesPal, 2}, - {sBerryCrushTImerPal, 4}, + {sBerryCrushCorePal, TAG_CRUSHER_BASE}, + {sBerryCrushImpactAndSparklesPal, PALTAG_EFFECT}, + {sBerryCrushTimerPal, TAG_TIMER_DIGITS}, {} }; -static const union AnimCmd gUnknown_846F340[] = { +static const union AnimCmd sAnim_CrusherBase[] = { ANIMCMD_FRAME(0x00, 0), ANIMCMD_END }; -static const union AnimCmd gUnknown_846F348[] = { +static const union AnimCmd sAnim_Impact_Small[] = { ANIMCMD_FRAME(0x00, 4), ANIMCMD_FRAME(0x10, 4), ANIMCMD_FRAME(0x20, 4), ANIMCMD_END }; -static const union AnimCmd gUnknown_846F358[] = { +static const union AnimCmd sAnim_Impact_Big[] = { ANIMCMD_FRAME(0x30, 2), ANIMCMD_FRAME(0x40, 2), ANIMCMD_FRAME(0x50, 2), @@ -612,7 +771,7 @@ static const union AnimCmd gUnknown_846F358[] = { ANIMCMD_END }; -static const union AnimCmd gUnknown_846F36C[] = { +static const union AnimCmd sAnim_Sparkle_Small[] = { ANIMCMD_FRAME(0x00, 2), ANIMCMD_FRAME(0x04, 2), ANIMCMD_FRAME(0x08, 2), @@ -622,7 +781,7 @@ static const union AnimCmd gUnknown_846F36C[] = { ANIMCMD_JUMP(0) }; -static const union AnimCmd gUnknown_846F388[] = { +static const union AnimCmd sAnim_Sparkle_Big[] = { ANIMCMD_FRAME(0x18, 4), ANIMCMD_FRAME(0x1c, 4), ANIMCMD_FRAME(0x20, 4), @@ -634,59 +793,59 @@ static const union AnimCmd gUnknown_846F388[] = { ANIMCMD_JUMP(0) }; -static const union AnimCmd gUnknown_846F3AC[] = { +static const union AnimCmd sAnim_Timer[] = { ANIMCMD_FRAME(0x14, 0), ANIMCMD_END }; -static const union AnimCmd gUnknown_846F3B4[] = { +static const union AnimCmd sAnim_PlayerBerry[] = { ANIMCMD_FRAME(0x00, 0), ANIMCMD_END }; -static const union AffineAnimCmd gUnknown_846F3BC[] = { - AFFINEANIMCMD_FRAME(256, 256, 0, 0), +static const union AffineAnimCmd sAffineAnim_PlayerBerry_0[] = { + AFFINEANIMCMD_FRAME(Q_8_8(1.0), Q_8_8(1.0), 0, 0), AFFINEANIMCMD_FRAME(0, 0, 2, 1), AFFINEANIMCMD_JUMP(1) }; -static const union AffineAnimCmd gUnknown_846F3D4[] = { - AFFINEANIMCMD_FRAME(256, 256, 0, 0), +static const union AffineAnimCmd sAffineAnim_PlayerBerry_1[] = { + AFFINEANIMCMD_FRAME(Q_8_8(1.0), Q_8_8(1.0), 0, 0), AFFINEANIMCMD_FRAME(0, 0, -2, 1), AFFINEANIMCMD_JUMP(1) }; static const union AnimCmd *const sAnimTable_BerryCrushCore[] = { - gUnknown_846F340 + sAnim_CrusherBase }; static const union AnimCmd *const sAnimTable_BerryCrushImpact[] = { - gUnknown_846F348, - gUnknown_846F358 + sAnim_Impact_Small, + sAnim_Impact_Big }; static const union AnimCmd *const sAnimTable_BerryCrushPowderSparkles[] = { - gUnknown_846F36C, - gUnknown_846F388 + sAnim_Sparkle_Small, + sAnim_Sparkle_Big }; static const union AnimCmd *const sAnimTable_BerryCrushTimer[] = { - gUnknown_846F3AC + sAnim_Timer }; -static const union AnimCmd *const gUnknown_846F404[] = { - gUnknown_846F3B4 +static const union AnimCmd *const sAnimTable_PlayerBerry[] = { + sAnim_PlayerBerry }; -static const union AffineAnimCmd *const gUnknown_846F408[] = { - gUnknown_846F3BC, - gUnknown_846F3D4 +static const union AffineAnimCmd *const sAffineAnimTable_PlayerBerry[] = { + sAffineAnim_PlayerBerry_0, + sAffineAnim_PlayerBerry_1 }; static const struct SpriteTemplate sSpriteTemplate_BerryCrushCore = { - .tileTag = 1, - .paletteTag = 1, + .tileTag = TAG_CRUSHER_BASE, + .paletteTag = TAG_CRUSHER_BASE, .oam = &gOamData_AffineOff_ObjNormal_64x64, .anims = sAnimTable_BerryCrushCore, .affineAnims = gDummySpriteAffineAnimTable, @@ -694,17 +853,17 @@ static const struct SpriteTemplate sSpriteTemplate_BerryCrushCore = { }; static const struct SpriteTemplate sSpriteTemplate_BerryCrushImpact = { - .tileTag = 2, - .paletteTag = 2, + .tileTag = GFXTAG_IMPACT, + .paletteTag = PALTAG_EFFECT, .oam = &gOamData_AffineOff_ObjNormal_32x32, .anims = sAnimTable_BerryCrushImpact, .affineAnims = gDummySpriteAffineAnimTable, - .callback = SpriteCB_BerryCrushImpact + .callback = SpriteCB_Impact }; static const struct SpriteTemplate sSpriteTemplate_BerryCrushPowderSparkles = { - .tileTag = 3, - .paletteTag = 2, + .tileTag = GFXTAG_SPARKLE, + .paletteTag = PALTAG_EFFECT, .oam = &gOamData_AffineOff_ObjNormal_16x16, .anims = sAnimTable_BerryCrushPowderSparkles, .affineAnims = gDummySpriteAffineAnimTable, @@ -712,8 +871,8 @@ static const struct SpriteTemplate sSpriteTemplate_BerryCrushPowderSparkles = { }; static const struct SpriteTemplate sSpriteTemplate_BerryCrushTimer = { - .tileTag = 4, - .paletteTag = 4, + .tileTag = TAG_TIMER_DIGITS, + .paletteTag = TAG_TIMER_DIGITS, .oam = &gOamData_AffineOff_ObjNormal_8x16, .anims = sAnimTable_BerryCrushTimer, .affineAnims = gDummySpriteAffineAnimTable, @@ -721,11 +880,11 @@ static const struct SpriteTemplate sSpriteTemplate_BerryCrushTimer = { }; static const struct SpriteTemplate sSpriteTemplate_PlayerBerry = { - .tileTag = 5, - .paletteTag = 5, + .tileTag = TAG_PLAYER1_BERRY, + .paletteTag = TAG_PLAYER1_BERRY, .oam = &gOamData_AffineDouble_ObjNormal_32x32, - .anims = gUnknown_846F404, - .affineAnims = gUnknown_846F408, + .anims = sAnimTable_PlayerBerry, + .affineAnims = sAffineAnimTable_PlayerBerry, .callback = SpriteCallbackDummy }; @@ -767,29 +926,30 @@ static const struct DigitObjUtilTemplate sDigitObjTemplates[] = { }; static const u8 *const sBCRankingHeaders[] = { - gText_SpaceTimes, - gText_XDotY, - gText_StrVar1Berry, - gText_NeatnessRankings, - gText_CooperativeRankings, - gText_PressingPowerRankings + [RESULTS_PAGE_PRESSES] = gText_SpaceTimes, + [RESULTS_PAGE_RANDOM] = gText_XDotY, + [RESULTS_PAGE_CRUSHING] = gText_StrVar1Berry, + + [RESULTS_PAGE_NEATNESS + NUM_RESULTS_PAGES] = gText_NeatnessRankings, + [RESULTS_PAGE_COOPERATIVE + NUM_RESULTS_PAGES] = gText_CooperativeRankings, + [RESULTS_PAGE_POWER + NUM_RESULTS_PAGES] = gText_PressingPowerRankings }; -struct BerryCrushGame *GetBerryCrushGame(void) +static struct BerryCrushGame *GetBerryCrushGame(void) { - return sBerryCrushGamePtr; + return sGame; } -u32 ExitBerryCrushWithCallback(MainCallback callback) +static u32 QuitBerryCrush(MainCallback callback) { - if (sBerryCrushGamePtr == NULL) + if (sGame == NULL) return 2; if (callback == NULL) - callback = sBerryCrushGamePtr->savedCallback; + callback = sGame->savedCallback; - DestroyTask(sBerryCrushGamePtr->mainTask); - FREE_AND_SET_NULL(sBerryCrushGamePtr); + DestroyTask(sGame->mainTask); + FREE_AND_SET_NULL(sGame); SetMainCallback2(callback); if (callback == CB2_ReturnToField) { @@ -800,6 +960,15 @@ u32 ExitBerryCrushWithCallback(MainCallback callback) return 0; } +#define ERROR_EXIT(exitCallback) \ + { \ + SetMainCallback2(exitCallback); \ + Rfu.linkman_param[0] = 0; \ + Rfu.linkman_param[1] = 0; \ + Rfu.errorState = 1; \ + } + + void StartBerryCrush(MainCallback callback) { u8 playerCount = 0; @@ -807,10 +976,7 @@ void StartBerryCrush(MainCallback callback) if (!gReceivedRemoteLinkPlayers || gWirelessCommType == 0) { - SetMainCallback2(callback); - Rfu.linkman_param[0] = 0; - Rfu.linkman_param[1] = 0; - Rfu.errorState = 1; + ERROR_EXIT(callback); return; } @@ -818,126 +984,121 @@ void StartBerryCrush(MainCallback callback) multiplayerId = GetMultiplayerId(); if (playerCount < 2 || multiplayerId >= playerCount) { - SetMainCallback2(callback); - Rfu.linkman_param[0] = 0; - Rfu.linkman_param[1] = 0; - Rfu.errorState = 1; + ERROR_EXIT(callback); return; } - sBerryCrushGamePtr = AllocZeroed(sizeof(struct BerryCrushGame)); - if (!sBerryCrushGamePtr) + sGame = AllocZeroed(sizeof(struct BerryCrushGame)); + if (!sGame) { - SetMainCallback2(callback); - Rfu.linkman_param[0] = 0; - Rfu.linkman_param[1] = 0; - Rfu.errorState = 1; + ERROR_EXIT(callback); return; } - sBerryCrushGamePtr->savedCallback = callback; - sBerryCrushGamePtr->localId = multiplayerId; - sBerryCrushGamePtr->playerCount = playerCount; - BerryCrush_InitPlayerNamesAndTextSpeed(sBerryCrushGamePtr); - sBerryCrushGamePtr->gameState = 1; - sBerryCrushGamePtr->nextCmd = BCCMD_BeginNormalPaletteFade; - sBerryCrushGamePtr->afterPalFadeCmd = BCCMD_SignalReadyToBegin; - BerryCrush_SetPaletteFadeParams(sBerryCrushGamePtr->commandParams, TRUE, 0xFFFFFFFF, 0, 16, 0, RGB_BLACK); - BerryCrush_RunOrScheduleCommand(BCCMD_InitGfx, 1, sBerryCrushGamePtr->commandParams); - SetMainCallback2(CB2_BerryCrush); - sBerryCrushGamePtr->mainTask = CreateTask(Task_RunBerryCrushGame, 8); + sGame->savedCallback = callback; + sGame->localId = multiplayerId; + sGame->playerCount = playerCount; + SetNamesAndTextSpeed(sGame); + sGame->gameState = STATE_INIT; + sGame->nextCmd = CMD_FADE; + sGame->afterPalFadeCmd = CMD_READY_BEGIN; + SetPaletteFadeArgs(sGame->commandParams, TRUE, PALETTES_ALL, 0, 16, 0, RGB_BLACK); + RunOrScheduleCommand(CMD_SHOW_GAME, SCHEDULE_CMD, sGame->commandParams); + SetMainCallback2(MainCB); + sGame->mainTask = CreateTask(MainTask, 8); } -static void CB2_ReturnToBerryCrushGameFromBerryPouch(void) +static void GetBerryFromBag(void) { if (gSpecialVar_ItemId < FIRST_BERRY_INDEX || gSpecialVar_ItemId > LAST_BERRY_INDEX + 1) gSpecialVar_ItemId = FIRST_BERRY_INDEX; else RemoveBagItem(gSpecialVar_ItemId, 1); - sBerryCrushGamePtr->unk98[sBerryCrushGamePtr->localId].unkC = gSpecialVar_ItemId - FIRST_BERRY_INDEX; - sBerryCrushGamePtr->nextCmd = BCCMD_BeginNormalPaletteFade; - sBerryCrushGamePtr->afterPalFadeCmd = BCCMD_WaitForOthersToPickBerries; - BerryCrush_SetPaletteFadeParams(sBerryCrushGamePtr->commandParams, FALSE, 0xFFFFFFFF, 0, 16, 0, RGB_BLACK); - BerryCrush_RunOrScheduleCommand(BCCMD_InitGfx, 1, sBerryCrushGamePtr->commandParams); - sBerryCrushGamePtr->mainTask = CreateTask(Task_RunBerryCrushGame, 8); - SetMainCallback2(CB2_BerryCrush); + sGame->players[sGame->localId].berryId = gSpecialVar_ItemId - FIRST_BERRY_INDEX; + sGame->nextCmd = CMD_FADE; + sGame->afterPalFadeCmd = CMD_WAIT_BERRIES; + SetPaletteFadeArgs(sGame->commandParams, FALSE, PALETTES_ALL, 0, 16, 0, RGB_BLACK); + RunOrScheduleCommand(CMD_SHOW_GAME, SCHEDULE_CMD, sGame->commandParams); + sGame->mainTask = CreateTask(MainTask, 8); + SetMainCallback2(MainCB); } -void CB2_BerryCrush_GoToBerryPouch(void) +static void ChooseBerry(void) { - DestroyTask(sBerryCrushGamePtr->mainTask); - InitBerryPouch(BERRYPOUCH_FROMBERRYCRUSH, CB2_ReturnToBerryCrushGameFromBerryPouch, FALSE); + DestroyTask(sGame->mainTask); + InitBerryPouch(BERRYPOUCH_FROMBERRYCRUSH, GetBerryFromBag, FALSE); } -void BerryCrush_SetVBlankCallback(void) +static void BerryCrush_SetVBlankCallback(void) { - SetVBlankCallback(VBlankCB_BerryCrush); + SetVBlankCallback(VBlankCB); } -void BerryCrush_UnsetVBlankCallback(void) +static void BerryCrush_InitVBlankCB(void) { SetVBlankCallback(NULL); } -void BerryCrush_UpdateSav2Records(void) +static void SaveResults(void) { - u32 var0, var1; + u32 time, presses; - var0 = sBerryCrushGamePtr->unk68.unk04; - var0 <<= 8; - var0 = MathUtil_Div32(var0, 60 << 8); - var1 = sBerryCrushGamePtr->unk68.unk0A; - var1 <<= 8; - var1 = MathUtil_Div32(var1, var0) & 0xFFFF; - sBerryCrushGamePtr->pressingSpeed = var1; - switch (sBerryCrushGamePtr->playerCount) + time = sGame->results.time; + time = Q_24_8(time); + time = divfx32(time, Q_24_8(60)); + presses = sGame->results.totalAPresses; + presses = Q_24_8(presses); + presses = divfx32(presses, time) & 0xFFFF; + sGame->pressingSpeed = presses; + + switch (sGame->playerCount) { case 2: - if (sBerryCrushGamePtr->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[0]) + if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[0]) { - sBerryCrushGamePtr->unk25_1 = 1; - gSaveBlock2Ptr->berryCrush.berryCrushResults[0] = sBerryCrushGamePtr->pressingSpeed; + sGame->newRecord = 1; + gSaveBlock2Ptr->berryCrush.berryCrushResults[0] = sGame->pressingSpeed; } break; case 3: - if (sBerryCrushGamePtr->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[1]) + if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[1]) { - sBerryCrushGamePtr->unk25_1 = 1; - gSaveBlock2Ptr->berryCrush.berryCrushResults[1] = sBerryCrushGamePtr->pressingSpeed; + sGame->newRecord = 1; + gSaveBlock2Ptr->berryCrush.berryCrushResults[1] = sGame->pressingSpeed; } break; case 4: - if (sBerryCrushGamePtr->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[2]) + if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[2]) { - sBerryCrushGamePtr->unk25_1 = 1; - gSaveBlock2Ptr->berryCrush.berryCrushResults[2] = sBerryCrushGamePtr->pressingSpeed; + sGame->newRecord = 1; + gSaveBlock2Ptr->berryCrush.berryCrushResults[2] = sGame->pressingSpeed; } break; case 5: - if (sBerryCrushGamePtr->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[3]) + if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[3]) { - sBerryCrushGamePtr->unk25_1 = 1; - gSaveBlock2Ptr->berryCrush.berryCrushResults[3] = sBerryCrushGamePtr->pressingSpeed; + sGame->newRecord = 1; + gSaveBlock2Ptr->berryCrush.berryCrushResults[3] = sGame->pressingSpeed; } break; } - sBerryCrushGamePtr->powder = sBerryCrushGamePtr->unk68.unk00; - if (GiveBerryPowder(sBerryCrushGamePtr->powder)) + sGame->powder = sGame->results.powder; + if (GiveBerryPowder(sGame->powder)) return; - sBerryCrushGamePtr->unk25_0 = 1; + sGame->noRoomForPowder = TRUE; } -static void VBlankCB_BerryCrush(void) +static void VBlankCB(void) { TransferPlttBuffer(); LoadOam(); ProcessSpriteCopyRequests(); } -static void CB2_BerryCrush(void) +static void MainCB(void) { RunTasks(); RunTextPrinters(); @@ -945,27 +1106,27 @@ static void CB2_BerryCrush(void) BuildOamBuffer(); } -static void Task_RunBerryCrushGame(u8 taskId) +static void MainTask(u8 taskId) { - if (sBerryCrushGamePtr->cmdCallback != NULL) - sBerryCrushGamePtr->cmdCallback(sBerryCrushGamePtr, sBerryCrushGamePtr->commandParams); + if (sGame->cmdCallback != NULL) + sGame->cmdCallback(sGame, sGame->commandParams); - sub_814D9CC(sBerryCrushGamePtr); + UpdateGame(sGame); } -void BerryCrush_InitPlayerNamesAndTextSpeed(struct BerryCrushGame *game) +static void SetNamesAndTextSpeed(struct BerryCrushGame *game) { u8 i; for (i = 0; i < game->playerCount; i++) { - StringCopy(game->unk98[i].unk0, gLinkPlayers[i].name); - game->unk98[i].unk0[PLAYER_NAME_LENGTH] = EOS; + StringCopy(game->players[i].name, gLinkPlayers[i].name); + game->players[i].name[PLAYER_NAME_LENGTH] = EOS; } for (; i < 5; i++) { - memset(game->unk98[i].unk0, 1, PLAYER_NAME_LENGTH); - game->unk98[i].unk0[PLAYER_NAME_LENGTH] = EOS; + memset(game->players[i].name, 1, PLAYER_NAME_LENGTH); + game->players[i].name[PLAYER_NAME_LENGTH] = EOS; } switch (gSaveBlock2Ptr->optionsTextSpeed) @@ -982,32 +1143,34 @@ void BerryCrush_InitPlayerNamesAndTextSpeed(struct BerryCrushGame *game) } } -void BerryCrush_RunOrScheduleCommand(u16 command, u8 runMode, u8 *params) +// GF file break + +static void RunOrScheduleCommand(u16 command, u8 runMode, u8 *args) { struct BerryCrushGame * game = GetBerryCrushGame(); if (command >= NELEMS(sBerryCrushCommands)) - command = 0; + command = CMD_NONE; switch (runMode) { - case 0: + case RUN_CMD: // Call now and set followup to game->nextCmd - if (command != 0) - sBerryCrushCommands[command](game, params); + if (command != CMD_NONE) + sBerryCrushCommands[command](game, args); if (game->nextCmd >= NELEMS(sBerryCrushCommands)) game->nextCmd = 0; game->cmdCallback = sBerryCrushCommands[game->nextCmd]; break; - case 1: + case SCHEDULE_CMD: // Schedule for next frame game->cmdCallback = sBerryCrushCommands[command]; break; } } -static u32 BerryCrushCommand_BeginNormalPaletteFade(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_BeginNormalPaletteFade(struct BerryCrushGame * game, u8 *args) { - // params points to packed values: + // args points to packed values: // bytes 0-3: selectedPals (bitfield) // byte 4: delay // byte 5: startY @@ -1018,46 +1181,47 @@ static u32 BerryCrushCommand_BeginNormalPaletteFade(struct BerryCrushGame * game u16 color; u32 selectedPals[2]; - selectedPals[0] = (u32)params[0]; - selectedPals[1] = (u32)params[1]; + selectedPals[0] = (u32)args[0]; + + selectedPals[1] = (u32)args[1]; selectedPals[1] <<= 8; - selectedPals[0] |= selectedPals[1]; - selectedPals[1] = (u32)params[2]; + + selectedPals[1] = (u32)args[2]; selectedPals[1] <<= 16; - selectedPals[0] |= selectedPals[1]; - selectedPals[1] = (u32)params[3]; + + selectedPals[1] = (u32)args[3]; selectedPals[1] <<= 24; - selectedPals[0] |= selectedPals[1]; - params[0] = params[9]; - color = params[8]; + args[0] = args[9]; + + color = args[8]; color <<= 8; - color |= params[7]; + color |= args[7]; gPaletteFade.bufferTransferDisabled = FALSE; - BeginNormalPaletteFade(selectedPals[0], params[4], params[5], params[6], color); + BeginNormalPaletteFade(selectedPals[0], args[4], args[5], args[6], color); UpdatePaletteFade(); - game->nextCmd = BCCMD_WaitPaletteFade; + game->nextCmd = CMD_WAIT_FADE; return 0; } -static u32 BerryCrushCommand_WaitPaletteFade(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_WaitPaletteFade(struct BerryCrushGame * game, u8 *args) { switch (game->cmdState) { case 0: if (UpdatePaletteFade()) return 0; - if(params[0] != 0) + if(args[0] != 0) ++game->cmdState; else game->cmdState = 3; return 0; case 1: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); ++game->cmdState; return 0; case 2: @@ -1068,7 +1232,7 @@ static u32 BerryCrushCommand_WaitPaletteFade(struct BerryCrushGame * game, u8 *p } return 0; case 3: - BerryCrush_RunOrScheduleCommand(game->afterPalFadeCmd, 1, NULL); + RunOrScheduleCommand(game->afterPalFadeCmd, SCHEDULE_CMD, NULL); game->cmdState = 0; return 0; default: @@ -1077,78 +1241,85 @@ static u32 BerryCrushCommand_WaitPaletteFade(struct BerryCrushGame * game, u8 *p } } -static u32 BerryCrushCommand_PrintMessage(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_PrintMessage(struct BerryCrushGame * game, u8 *args) { - u16 waitKeys; + // args[0]: msg id + // args[1]: flags + // args[2]: keys lo + // args[3]: keys hi + // args[4]: follow-up cmd state + + u16 keys; + + keys = args[3]; + keys <<= 8; + keys |= args[2] << 0; - waitKeys = params[3]; - waitKeys <<= 8; - waitKeys |= params[2] << 0; switch (game->cmdState) { case 0: DrawDialogueFrame(0, FALSE); - if (params[1] & 2) + if (args[1] & F_MSG_EXPAND) { - StringExpandPlaceholders(gStringVar4, sBerryCrushMessages[params[0]]); + StringExpandPlaceholders(gStringVar4, sMessages[args[0]]); AddTextPrinterParameterized2(0, 2, gStringVar4, game->textSpeed, 0, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); } else { - AddTextPrinterParameterized2(0, 2, sBerryCrushMessages[params[0]], game->textSpeed, NULL, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); + AddTextPrinterParameterized2(0, 2, sMessages[args[0]], game->textSpeed, NULL, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); } CopyWindowToVram(0, COPYWIN_BOTH); break; case 1: if (!IsTextPrinterActive(0)) { - if (waitKeys == 0) + if (keys == 0) ++game->cmdState; break; } return 0; case 2: - if (!(waitKeys & gMain.newKeys)) + if (!JOY_NEW(keys)) return 0; break; case 3: - if (params[1] & 1) + if (args[1] & F_MSG_CLEAR) ClearDialogWindowAndFrame(0, TRUE); - BerryCrush_RunOrScheduleCommand(game->nextCmd, 1, NULL); - game->cmdState = params[4]; + RunOrScheduleCommand(game->nextCmd, SCHEDULE_CMD, NULL); + game->cmdState = args[4]; return 0; } ++game->cmdState; return 0; } -static u32 BerryCrushCommand_InitGfx(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_ShowGameDisplay(struct BerryCrushGame * game, UNUSED u8 *args) { - if (BerryCrush_InitBgs() != 0) - BerryCrush_RunOrScheduleCommand(game->nextCmd, 0, game->commandParams); + if (ShowGameDisplay()) + RunOrScheduleCommand(game->nextCmd, RUN_CMD, game->commandParams); return 0; } -static u32 BerryCrushCommand_TeardownGfx(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_HideGameDisplay(struct BerryCrushGame * game, UNUSED u8 *args) { - if (BerryCrush_TeardownBgs() != 0) - BerryCrush_RunOrScheduleCommand(game->nextCmd, 0, game->commandParams); + if (HideGameDisplay()) + RunOrScheduleCommand(game->nextCmd, RUN_CMD, game->commandParams); return 0; } -static u32 BerryCrushCommand_SignalReadyToBegin(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_SignalReadyToBegin(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { case 0: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 1: if (IsLinkTaskFinished()) { PlayNewMapMusic(MUS_GAME_CORNER); - BerryCrush_RunOrScheduleCommand(BCCMD_AskPickBerry, 1, NULL); - game->gameState = 3; + RunOrScheduleCommand(CMD_ASK_PICK_BERRY, SCHEDULE_CMD, NULL); + game->gameState = STATE_PICK_BERRY; game->cmdState = 0; } return 0; @@ -1157,7 +1328,7 @@ static u32 BerryCrushCommand_SignalReadyToBegin(struct BerryCrushGame * game, UN return 0; } -static u32 BerryCrushCommand_AskPickBerry(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_AskPickBerry(struct BerryCrushGame * game, u8 *args) { switch (game->cmdState) { @@ -1165,72 +1336,72 @@ static u32 BerryCrushCommand_AskPickBerry(struct BerryCrushGame * game, u8 *para ++game->cmdState; break; case 0: - sub_814D4D8(game); - BerryCrush_SetShowMessageParams(params, BCTEXT_AREYOUREADY, 1, 0, BCCMD_BeginNormalPaletteFade); - game->nextCmd = BCCMD_AskPickBerry; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); + ResetGame(game); + SetPrintMessageArgs(args, MSG_PICK_BERRY, F_MSG_CLEAR, 0, CMD_FADE); + game->nextCmd = CMD_ASK_PICK_BERRY; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); break; case 1: - game->nextCmd = BCCMD_GoToBerryPouch; - BerryCrush_RunOrScheduleCommand(BCCMD_TeardownGfx, 1, NULL); + game->nextCmd = CMD_PICK_BERRY; + RunOrScheduleCommand(CMD_HIDE_GAME, SCHEDULE_CMD, NULL); game->cmdState = 2; break; } return 0; } -static u32 BerryCrushCommand_GoToBerryPouch(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_GoToBerryPouch(struct BerryCrushGame * game, UNUSED u8 *args) { game->cmdCallback = NULL; - SetMainCallback2(CB2_BerryCrush_GoToBerryPouch); + SetMainCallback2(ChooseBerry); return 0; } -static u32 BerryCrushCommand_WaitForOthersToPickBerries(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_WaitForOthersToPickBerries(struct BerryCrushGame * game, u8 *args) { u8 i; switch (game->cmdState) { case 0: - BerryCrush_SetShowMessageParams(params, BCTEXT_WAITFOROTHERS, 0, 0, BCCMD_BeginNormalPaletteFade); - game->nextCmd = BCCMD_WaitForOthersToPickBerries; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); + SetPrintMessageArgs(args, MSG_WAIT_PICK, 0, 0, CMD_FADE); + game->nextCmd = CMD_WAIT_BERRIES; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); return 0; case 1: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 2: if (!IsLinkTaskFinished()) return 0; memset(game->sendCmd, 0, sizeof(game->sendCmd)); - game->sendCmd[0] = game->unk98[game->localId].unkC; + game->sendCmd[0] = game->players[game->localId].berryId; SendBlock(0, game->sendCmd, 2); break; case 3: if (!IsLinkTaskFinished()) return 0; - game->unk10 = 0; + game->cmdTimer = 0; break; case 4: if (GetBlockReceivedStatus() != sReceivedPlayerBitmasks[game->playerCount - 2]) return 0; for (i = 0; i < game->playerCount; ++i) { - game->unk98[i].unkC = gBlockRecvBuffer[i][0]; - if (game->unk98[i].unkC > 0xB0) - game->unk98[i].unkC = 0; - game->unk18 += gBerryCrushStats[game->unk98[i].unkC].unk0; - game->powder += gBerryCrushStats[game->unk98[i].unkC].powder; + game->players[i].berryId = gBlockRecvBuffer[i][0]; + if (game->players[i].berryId > LAST_BERRY_INDEX + 1) + game->players[i].berryId = 0; + game->targetAPresses += gBerryCrush_BerryData[game->players[i].berryId].difficulty; + game->powder += gBerryCrush_BerryData[game->players[i].berryId].powder; } - game->unk10 = 0; + game->cmdTimer = 0; ResetBlockReceivedFlags(); - game->unk20 = MathUtil_Div32(game->unk18 << 8, 0x2000); + game->targetDepth = divfx32(Q_24_8(game->targetAPresses), Q_24_8(32)); break; case 5: ClearDialogWindowAndFrame(0, TRUE); - BerryCrush_RunOrScheduleCommand(BCCMD_DropBerriesIntoCrusher, 1, NULL); - game->gameState = 4; + RunOrScheduleCommand(CMD_DROP_BERRIES, SCHEDULE_CMD, NULL); + game->gameState = STATE_DROP_BERRIES; game->cmdState = 0; return 0; } @@ -1238,54 +1409,54 @@ static u32 BerryCrushCommand_WaitForOthersToPickBerries(struct BerryCrushGame * return 0; } -static u32 BerryCrushCommand_DropBerriesIntoCrusher(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_DropBerriesIntoCrusher(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { case 0: - BerryCrush_CreateBerrySprites(game, &game->spritesManager); - LinkRfu_SetRfuFuncToSend6600(); + CreateBerrySprites(game, &game->gfx); + Rfu_SetLinkStandbyCallback(); break; case 1: if (!IsLinkTaskFinished()) return 0; - game->spritesManager.animBerryIdx = 0; - game->spritesManager.unk1 = 0; - game->spritesManager.unk2 = 0; - game->spritesManager.unk3 = 0; + game->gfx.counter = 0; + game->gfx.vibrationIdx = 0; + game->gfx.numVibrations = 0; + game->gfx.vibrating = 0; break; case 2: - game->spritesManager.berrySprites[game->spritesManager.animBerryIdx]->callback = SpriteCB_DropBerryIntoCrusher; - game->spritesManager.berrySprites[game->spritesManager.animBerryIdx]->affineAnimPaused = FALSE; + game->gfx.berrySprites[game->gfx.counter]->callback = SpriteCB_DropBerryIntoCrusher; + game->gfx.berrySprites[game->gfx.counter]->affineAnimPaused = FALSE; PlaySE(SE_BALL_THROW); break; case 3: - if (game->spritesManager.berrySprites[game->spritesManager.animBerryIdx]->callback == SpriteCB_DropBerryIntoCrusher) + if (game->gfx.berrySprites[game->gfx.counter]->callback == SpriteCB_DropBerryIntoCrusher) return 0; - game->spritesManager.berrySprites[game->spritesManager.animBerryIdx] = NULL; - ++game->spritesManager.animBerryIdx; - LinkRfu_SetRfuFuncToSend6600(); + game->gfx.berrySprites[game->gfx.counter] = NULL; + ++game->gfx.counter; + Rfu_SetLinkStandbyCallback(); break; case 4: if (!IsLinkTaskFinished()) return 0; - if (game->spritesManager.animBerryIdx < game->playerCount) + if (game->gfx.counter < game->playerCount) { game->cmdState = 2; return 0; } - game->spritesManager.animBerryIdx = 0; + game->gfx.counter = 0; break; case 5: - BerryCrushFreeBerrySpriteGfx(game, &game->spritesManager); - LinkRfu_SetRfuFuncToSend6600(); + BerryCrushFreeBerrySpriteGfx(game, &game->gfx); + Rfu_SetLinkStandbyCallback(); break; case 6: if (!IsLinkTaskFinished()) return 0; PlaySE(SE_FALL); - BerryCrush_RunOrScheduleCommand(BCCMD_DropLid, 1, NULL); - game->gameState = 5; + RunOrScheduleCommand(CMD_DROP_LID, SCHEDULE_CMD, NULL); + game->gameState = STATE_DROP_LID; game->cmdState = 0; return 0; } @@ -1293,7 +1464,7 @@ static u32 BerryCrushCommand_DropBerriesIntoCrusher(struct BerryCrushGame * game return 0; } -static u32 BerryCrushCommand_DropLid(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_DropLid(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { @@ -1302,37 +1473,37 @@ static u32 BerryCrushCommand_DropLid(struct BerryCrushGame * game, UNUSED u8 *p if (game->depth < 0) return 0; game->depth = 0; - game->spritesManager.unk1 = 4; - game->spritesManager.animBerryIdx = 0; - game->spritesManager.unk2 = gUnknown_846E2F0[game->spritesManager.unk1][0]; + game->gfx.vibrationIdx = 4; + game->gfx.counter = 0; + game->gfx.numVibrations = sIntroOutroVibrationData[game->gfx.vibrationIdx][0]; PlaySE(SE_M_STRENGTH); break; case 1: - game->vibration = gUnknown_846E2F0[game->spritesManager.unk1][game->spritesManager.animBerryIdx]; + game->vibration = sIntroOutroVibrationData[game->gfx.vibrationIdx][game->gfx.counter]; SetGpuReg(REG_OFFSET_BG0VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG2VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG3VOFS, -game->vibration); - ++game->spritesManager.animBerryIdx; - if (game->spritesManager.animBerryIdx < game->spritesManager.unk2) + ++game->gfx.counter; + if (game->gfx.counter < game->gfx.numVibrations) return 0; - if (game->spritesManager.unk1 == 0) + if (game->gfx.vibrationIdx == 0) break; - --game->spritesManager.unk1; - game->spritesManager.unk2 = gUnknown_846E2F0[game->spritesManager.unk1][0]; - game->spritesManager.animBerryIdx = 0; + --game->gfx.vibrationIdx; + game->gfx.numVibrations = sIntroOutroVibrationData[game->gfx.vibrationIdx][0]; + game->gfx.counter = 0; return 0; case 2: game->vibration = 0; SetGpuReg(REG_OFFSET_BG0VOFS, 0); SetGpuReg(REG_OFFSET_BG2VOFS, 0); SetGpuReg(REG_OFFSET_BG3VOFS, 0); - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 3: if (!IsLinkTaskFinished()) return 0; - BerryCrush_RunOrScheduleCommand(BCCMD_Countdown, 1, NULL); - game->gameState = 6; + RunOrScheduleCommand(CMD_COUNTDOWN, SCHEDULE_CMD, NULL); + game->gameState = STATE_COUNTDOWN; game->cmdState = 0; return 0; } @@ -1340,12 +1511,12 @@ static u32 BerryCrushCommand_DropLid(struct BerryCrushGame * game, UNUSED u8 *p return 0; } -static u32 BerryCrushCommand_Countdown(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_Countdown(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game-> cmdState) { case 0: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 1: if (!IsLinkTaskFinished()) @@ -1355,21 +1526,21 @@ static u32 BerryCrushCommand_Countdown(struct BerryCrushGame * game, UNUSED u8 case 2: if (IsMinigameCountdownRunning()) return 0; - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 3: if (!IsLinkTaskFinished()) return 0; - game->spritesManager.animBerryIdx = 0; - game->spritesManager.unk1 = 0; - game->spritesManager.unk2 = 0; - game->spritesManager.unk3 = 0; - game->unk10 = 0; + game->gfx.counter = 0; + game->gfx.vibrationIdx = 0; + game->gfx.numVibrations = 0; + game->gfx.vibrating = FALSE; + game->cmdTimer = 0; if (game->localId == 0) - BerryCrush_RunOrScheduleCommand(BCCMD_PlayGame_Master, 1, NULL); + RunOrScheduleCommand(CMD_PLAY_GAME_LEADER, SCHEDULE_CMD, NULL); else - BerryCrush_RunOrScheduleCommand(BCCMD_PlayGame_Slave, 1, NULL); - game->gameState = 7; + RunOrScheduleCommand(CMD_PLAY_GAME_MEMBER, SCHEDULE_CMD, NULL); + game->gameState = STATE_PLAYING; game->cmdState = 0; return 0; } @@ -1377,333 +1548,368 @@ static u32 BerryCrushCommand_Countdown(struct BerryCrushGame * game, UNUSED u8 return 0; } -static void BerryCrush_ProcessGamePartnerInput(struct BerryCrushGame * game) +static void HandlePartnerInput(struct BerryCrushGame * game) { - u8 numPressedA = 0; - u16 r3; - u16 *curRecvCmd; + u8 numPlayersPressed = 0; u8 i = 0; - s32 r2_ = 0; - s32 r0; + u16 timeDiff; + s32 temp = 0; + struct BerryCrushGame_LinkState *linkState; for (i = 0; i < game->playerCount; ++i) { - curRecvCmd = gRecvCmds[i]; - if ((curRecvCmd[0] & 0xFF00) == 0x2F00 - && curRecvCmd[1] == 2) + linkState = (struct BerryCrushGame_LinkState *)gRecvCmds[i]; + + if ((linkState->rfuCmd & 0xFF00) != RFUCMD_SEND_PACKET) + continue; + if (linkState->sendFlag != SEND_GAME_STATE) + continue; + + if (linkState->pushedAButton) { - if ((u8)curRecvCmd[2] & 4) // pushedAButton + game->localState.playerPressedAFlags |= sBitTable[i]; + game->players[i].inputState = 1; + ++game->players[i].numAPresses; + ++numPlayersPressed; + timeDiff = game->timer - game->players[i].inputTime; + + // If the interval between inputs is regular, the input is considered "neat" + // This counts toward the player's neatness score + if (timeDiff >= game->players[i].timeSincePrevInput - 1 + && timeDiff <= game->players[i].timeSincePrevInput + 1) { - game->localState.unk02_3 |= gUnknown_846E2E0[i]; - game->unk98[i].unk1C = 1; - ++game->unk98[i].unk16; - ++numPressedA; - r3 = game->timer - game->unk98[i].unkE; - if (r3 >= game->unk98[i].unk12 - 1 && r3 <= game->unk98[i].unk12 + 1) - { - ++game->unk98[i].unk10; - game->unk98[i].unk12 = r3; - if (game->unk98[i].unk10 > game->unk98[i].unk14) - game->unk98[i].unk14 = game->unk98[i].unk10; - } - else - { - game->unk98[i].unk10 = 0; - game->unk98[i].unk12 = r3; - } - game->unk98[i].unkE = game->timer; - if (++game->unk98[i].unk1B > 2) - game->unk98[i].unk1B = 0; + // On neat input streak + ++game->players[i].neatInputStreak; + game->players[i].timeSincePrevInput = timeDiff; + if (game->players[i].neatInputStreak > game->players[i].maxNeatInputStreak) + game->players[i].maxNeatInputStreak = game->players[i].neatInputStreak; } else { - game->unk98[i].unk1C = 0; + // End neat input streak + game->players[i].neatInputStreak = 0; + game->players[i].timeSincePrevInput = timeDiff; } - } - } - if (numPressedA > 1) - { - for (i = 0; i < game->playerCount; ++i) - { - if (game->unk98[i].unk1C != 0) - { - game->unk98[i].unk1C |= 2; - ++game->unk98[i].unk18; - } - } - } - if (numPressedA != 0) - { - game->unk2E += numPressedA; - numPressedA += gUnknown_846E2E8[numPressedA - 1]; - game->unk34 += numPressedA; - game->unk1A += numPressedA; - r0 = game->unk18; - r2_ = game->unk1A; - if (r0 - r2_ > 0) - { - r2_ <<= 8; - r2_ = MathUtil_Div32(r2_, game->unk20); - r2_ >>= 8; - game->unk24 = r2_; + + game->players[i].inputTime = game->timer; + ++game->players[i].inputFlags; + if (game->players[i].inputFlags > F_INPUT_HIT_B) + game->players[i].inputFlags = 0; } else { - game->unk24 = 32; - game->localState.unk02_0 = 1; + game->players[i].inputState = INPUT_STATE_NONE; } } + if (numPlayersPressed > 1) + { + // For each player that pressed A, flag their input as synchronous + // This is used to change their impact sprite to a big impact + for (i = 0; i < game->playerCount; ++i) + { + if (game->players[i].inputState == INPUT_STATE_NONE) + continue; + game->players[i].inputState |= INPUT_STATE_HIT_SYNC; + ++game->players[i].numSyncedAPresses; + } + } + if (numPlayersPressed == 0) + return; + + game->bigSparkleCounter += numPlayersPressed; + numPlayersPressed += sSyncPressBonus[numPlayersPressed - 1]; + game->sparkleCounter += numPlayersPressed; + game->totalAPresses += numPlayersPressed; + if (game->targetAPresses - game->totalAPresses > 0) + { + temp = game->totalAPresses; + temp = Q_24_8(temp); + temp = divfx32(temp, game->targetDepth); + temp = Q_24_8_TO_INT(temp); + game->newDepth = (u8)temp; + return; + } + + // Target number of A presses has been reached, game is complete + game->newDepth = 32; + game->localState.endGame = TRUE; } static void BerryCrush_BuildLocalState(struct BerryCrushGame * game) { - u8 count = 0; + u8 numPlayersPressed = 0; u16 r1 = 0; u8 i = 0; for (i = 0; i < game->playerCount; ++i) { - if (game->unk98[i].unk1C != 0) + if (game->players[i].inputState != 0) { - ++count; - r1 = game->unk98[i].unk1B + 1; - if (game->unk98[i].unk1C & 2) + ++numPlayersPressed; + r1 = game->players[i].inputFlags + 1; + if (game->players[i].inputState & 2) r1 |= 4; r1 <<= 3 * i; - game->localState.unk08 |= r1; + game->localState.inputFlags |= r1; } } - game->localState.unk04 = game->unk24; - if (count == 0) + game->localState.depth = game->newDepth; + if (numPlayersPressed == 0) { - if (game->spritesManager.unk3 != 0) - ++game->spritesManager.animBerryIdx; + if (game->gfx.vibrating != 0) + ++game->gfx.counter; } - else if (game->spritesManager.unk3 != 0) + else if (game->gfx.vibrating != 0) { - if (count != game->spritesManager.unk1) + if (numPlayersPressed != game->gfx.vibrationIdx) { - game->spritesManager.unk1 = count - 1; - game->spritesManager.unk2 = gUnknown_846E314[count - 1][0]; + game->gfx.vibrationIdx = numPlayersPressed - 1; + game->gfx.numVibrations = sVibrationData[numPlayersPressed - 1][0]; } else { - ++game->spritesManager.animBerryIdx; + ++game->gfx.counter; } } else { - game->spritesManager.animBerryIdx = 0; - game->spritesManager.unk1 = count - 1; - game->spritesManager.unk2 = gUnknown_846E314[count - 1][0]; - game->spritesManager.unk3 = 1; + game->gfx.counter = 0; + game->gfx.vibrationIdx = numPlayersPressed - 1; + game->gfx.numVibrations = sVibrationData[numPlayersPressed - 1][0]; + game->gfx.vibrating = 1; } - if (game->spritesManager.unk3 != 0) + if (game->gfx.vibrating != 0) { - if (game->spritesManager.animBerryIdx >= game->spritesManager.unk2) + if (game->gfx.counter >= game->gfx.numVibrations) { - game->spritesManager.animBerryIdx = 0; - game->spritesManager.unk1 = 0; - game->spritesManager.unk2 = 0; - game->spritesManager.unk3 = 0; + game->gfx.counter = 0; + game->gfx.vibrationIdx = 0; + game->gfx.numVibrations = 0; + game->gfx.vibrating = 0; r1 = 0; } else { - r1 = gUnknown_846E314[game->spritesManager.unk1][game->spritesManager.animBerryIdx + 1]; + r1 = sVibrationData[game->gfx.vibrationIdx][game->gfx.counter + 1]; } - game->localState.unk03 = r1; + game->localState.vibration = r1; } else { - game->localState.unk03 = 0; + game->localState.vibration = 0; } - game->localState.unk06 = game->unk26; + game->localState.timer = game->leaderTimer; } -static void BerryCrush_HandlePlayerInput(struct BerryCrushGame * game) +static void HandlePlayerInput(struct BerryCrushGame * game) { if (JOY_NEW(A_BUTTON)) game->localState.pushedAButton = TRUE; + if (JOY_HELD(A_BUTTON)) { - if (game->unk98[game->localId].unk1A < game->timer) - ++game->unk98[game->localId].unk1A; + if (game->players[game->localId].timePressingA < game->timer) + ++game->players[game->localId].timePressingA; } + + // Only send data to other players if you are the leader or you pressed A if (game->localId != 0 && !game->localState.pushedAButton) return; - game->localState.unk00 = 2; + game->localState.sendFlag = SEND_GAME_STATE; + + // Every 30 frames, check whether the sparkles produced should be big, + // depending on how many A presses there were in that time if (game->timer % 30 == 0) { - if (game->unk2E > gUnknown_846E3C4[game->playerCount - 2]) + if (game->bigSparkleCounter > sBigSparkleThresholds[game->playerCount - 2]) { - ++game->unk30; - game->unk25_4 = 1; + ++game->numBigSparkles; + game->bigSparkle = TRUE; } else { - game->unk25_4 = 0; + game->bigSparkle = FALSE; } - game->unk2E = 0; - ++game->unk32; + game->bigSparkleCounter = 0; + ++game->numBigSparkleChecks; } + + // Every 15 frames, update the amount of sparkles that should be produced, + // depending on how many A presses there were in that time (including the bonus) if (game->timer % 15 == 0) { - if (game->unk34 < gUnknown_846E3B4[game->playerCount - 2][0]) - game->unk25_5 = 0; - else if (game->unk34 < gUnknown_846E3B4[game->playerCount - 2][1]) - game->unk25_5 = 1; - else if (game->unk34 < gUnknown_846E3B4[game->playerCount - 2][2]) - game->unk34 = 2; // typo since game->unk34 will be reset? - else if (game->unk34 < gUnknown_846E3B4[game->playerCount - 2][3]) - game->unk34 = 3; // typo since game->unk34 will be reset? + // BUG: The wrong field is used twice below + // As a result, only a sparkleAmount of 0, 1, or 4 is attainable +#ifdef BUGFIX +#define field sparkleAmount +#else +#define field sparkleCounter +#endif + if (game->sparkleCounter < sSparkleThresholds[game->playerCount - 2][0]) + game->sparkleAmount = 0; + else if (game->sparkleCounter < sSparkleThresholds[game->playerCount - 2][1]) + game->sparkleAmount = 1; + else if (game->sparkleCounter < sSparkleThresholds[game->playerCount - 2][2]) + game->field = 2; + else if (game->sparkleCounter < sSparkleThresholds[game->playerCount - 2][3]) + game->field = 3; else - game->unk25_5 = 4; - game->unk34 = 0; + game->sparkleAmount = 4; + game->sparkleCounter = 0; +#undef field } else { - ++game->unk10; - if (game->unk10 > 60) + ++game->cmdTimer; + if (game->cmdTimer > 60) { - if (game->unk10 > 70) + if (game->cmdTimer > 70) { - sub_80FBA44(); - game->unk10 = 0; + ClearRecvCommands(); + game->cmdTimer = 0; } - else if (game->localState.unk02_3 == 0) + else if (game->localState.playerPressedAFlags == 0) { - sub_80FBA44(); - game->unk10 = 0; + ClearRecvCommands(); + game->cmdTimer = 0; } } } - if (game->timer >= 36000) - game->localState.unk02_0 = 1; - game->localState.unk02_1 = game->unk25_4; - game->localState.unk0A = game->unk25_5; + if (game->timer >= MAX_TIME) + game->localState.endGame = TRUE; + game->localState.bigSparkle = game->bigSparkle; + game->localState.sparkleAmount = game->sparkleAmount; memcpy(&game->sendCmd, &game->localState, sizeof(game->sendCmd)); - RfuPrepareSend0x2f00(game->sendCmd); + Rfu_SendPacket(game->sendCmd); } -static void BerryCrush_UpdateGameState(struct BerryCrushGame * game) +static void RecvLinkData(struct BerryCrushGame * game) { u8 i = 0; - struct BerryCrushGame_4E * r4_ = NULL; + struct BerryCrushGame_LinkState * linkState = NULL; for (i = 0; i < game->playerCount; ++i) - game->unk98[i].unk1C = 0; - if ((gRecvCmds[0][0] & 0xFF00) != 0x2F00 || gRecvCmds[0][1] != 2) + game->players[i].inputState = INPUT_STATE_NONE; + + if ((gRecvCmds[0][0] & 0xFF00) != RFUCMD_SEND_PACKET) { - game->unk25_2 = 0; + game->playedSound = FALSE; return; } - memcpy(game->recvCmd, gRecvCmds[0], 14); - r4_ = (struct BerryCrushGame_4E *)&game->recvCmd; - game->depth = r4_->unk6; - game->vibration = r4_->unk5; - game->timer = r4_->unk8; - sub_814DC5C(game, &game->spritesManager); - if (r4_->unk4_0) - game->unk25_3 = 1; + if (gRecvCmds[0][1] != SEND_GAME_STATE) + { + game->playedSound = FALSE; + return; + } + + memcpy(game->recvCmd, gRecvCmds[0], sizeof(game->recvCmd)); + linkState = (struct BerryCrushGame_LinkState *)&game->recvCmd; + game->depth = linkState->depth; + game->vibration = linkState->vibration; + game->timer = linkState->timer; + UpdateInputEffects(game, &game->gfx); + + if (linkState->endGame) + game->endGame = TRUE; } -static u32 BerryCrushCommand_PlayGame_Master(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_PlayGame_Leader(struct BerryCrushGame * game, UNUSED u8 *args) { memset(&game->localState, 0, sizeof(game->localState)); memset(&game->recvCmd, 0, sizeof(game->recvCmd)); - BerryCrush_UpdateGameState(game); + RecvLinkData(game); SetGpuReg(REG_OFFSET_BG0VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG2VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG3VOFS, -game->vibration); - if (game->unk25_3) + if (game->endGame) { - if (game->timer >= 36000) + if (game->timer >= MAX_TIME) { - game->timer = 36000; - BerryCrush_RunOrScheduleCommand(BCCMD_HandleTimeUp, 1, NULL); + game->timer = MAX_TIME; + RunOrScheduleCommand(CMD_TIMES_UP, SCHEDULE_CMD, NULL); } else { - BerryCrush_RunOrScheduleCommand(BCCMD_FinishGame, 1, NULL); + RunOrScheduleCommand(CMD_FINISH_GAME, SCHEDULE_CMD, NULL); } - game->unk10 = 0; + game->cmdTimer = 0; game->cmdState = 0; return 0; } else { - ++game->unk26; - BerryCrush_ProcessGamePartnerInput(game); + ++game->leaderTimer; + HandlePartnerInput(game); BerryCrush_BuildLocalState(game); - BerryCrush_HandlePlayerInput(game); + HandlePlayerInput(game); return 0; } } -static u32 BerryCrushCommand_PlayGame_Slave(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_PlayGame_Member(struct BerryCrushGame * game, UNUSED u8 *args) { memset(&game->localState, 0, sizeof(game->localState)); memset(&game->recvCmd, 0, sizeof(game->recvCmd)); - BerryCrush_UpdateGameState(game); + RecvLinkData(game); SetGpuReg(REG_OFFSET_BG0VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG2VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG3VOFS, -game->vibration); - if (game->unk25_3) + if (game->endGame) { - if (game->timer >= 36000) + if (game->timer >= MAX_TIME) { - game->timer = 36000; - BerryCrush_RunOrScheduleCommand(BCCMD_HandleTimeUp, 1, NULL); + game->timer = MAX_TIME; + RunOrScheduleCommand(CMD_TIMES_UP, SCHEDULE_CMD, NULL); } else { - BerryCrush_RunOrScheduleCommand(BCCMD_FinishGame, 1, NULL); + RunOrScheduleCommand(CMD_FINISH_GAME, SCHEDULE_CMD, NULL); } - game->unk10 = 0; + game->cmdTimer = 0; game->cmdState = 0; return 0; } else { - BerryCrush_HandlePlayerInput(game); + HandlePlayerInput(game); return 0; } } -static u32 BerryCrushCommand_FinishGame(struct BerryCrushGame * game, UNUSED u8 *params) +// Game was 'won', crusher was pushed down fully before time was up +static u32 Cmd_FinishGame(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { case 0: - game->gameState = 8; + game->gameState = STATE_FINISHED; PlaySE(SE_M_STRENGTH); - BlendPalettes(0xFFFFFFFF, 8, RGB(31, 31, 0)); - game->spritesManager.animBerryIdx = 2; + BlendPalettes(PALETTES_ALL, 8, RGB(31, 31, 0)); + game->gfx.counter = 2; break; case 1: - if (--game->spritesManager.animBerryIdx != 255) + if (--game->gfx.counter != UINT8_MAX) return 0; - BlendPalettes(0xFFFFFFFF, 0, RGB(31, 31, 0)); - game->spritesManager.unk1 = 4; - game->spritesManager.animBerryIdx = 0; - game->spritesManager.unk2 = gUnknown_846E2F0[game->spritesManager.unk1][0]; + BlendPalettes(PALETTES_ALL, 0, RGB(31, 31, 0)); + game->gfx.vibrationIdx = 4; + game->gfx.counter = 0; + game->gfx.numVibrations = sIntroOutroVibrationData[game->gfx.vibrationIdx][0]; break; case 2: - game->vibration = gUnknown_846E2F0[game->spritesManager.unk1][game->spritesManager.animBerryIdx]; + game->vibration = sIntroOutroVibrationData[game->gfx.vibrationIdx][game->gfx.counter]; SetGpuReg(REG_OFFSET_BG0VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG2VOFS, -game->vibration); SetGpuReg(REG_OFFSET_BG3VOFS, -game->vibration); - if (++game->spritesManager.animBerryIdx < game->spritesManager.unk2) + if (++game->gfx.counter < game->gfx.numVibrations) return 0; - if (game->spritesManager.unk1 != 0) + if (game->gfx.vibrationIdx != 0) { - --game->spritesManager.unk1; - game->spritesManager.unk2 = gUnknown_846E2F0[game->spritesManager.unk1][0]; - game->spritesManager.animBerryIdx = 0; + --game->gfx.vibrationIdx; + game->gfx.numVibrations = sIntroOutroVibrationData[game->gfx.vibrationIdx][0]; + game->gfx.counter = 0; return 0; } break; @@ -1714,16 +1920,16 @@ static u32 BerryCrushCommand_FinishGame(struct BerryCrushGame * game, UNUSED u8 SetGpuReg(REG_OFFSET_BG3VOFS, 0); break; case 4: - if (!sub_814DE50(game, &game->spritesManager)) + if (!AreEffectsFinished(game, &game->gfx)) return 0; - LinkRfu_SetRfuFuncToSend6600(); - game->unk10 = 0; + Rfu_SetLinkStandbyCallback(); + game->cmdTimer = 0; break; case 5: if (!IsLinkTaskFinished()) return 0; - BerryCrush_RunOrScheduleCommand(BCCMD_TabulateResults, 1, NULL); - game->unk10 = 0; + RunOrScheduleCommand(CMD_CALC_RESULTS, SCHEDULE_CMD, NULL); + game->cmdTimer = 0; game->cmdState = 0; return 0; } @@ -1731,27 +1937,27 @@ static u32 BerryCrushCommand_FinishGame(struct BerryCrushGame * game, UNUSED u8 return 0; } -static u32 BerryCrushCommand_HandleTimeUp(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_HandleTimeUp(struct BerryCrushGame * game, u8 *args) { switch (game->cmdState) { case 0: - game->gameState = 9; + game->gameState = STATE_TIMES_UP; PlaySE(SE_FAILURE); - BlendPalettes(0xFFFFFFFF, 8, RGB(31, 0, 0)); - game->spritesManager.animBerryIdx = 4; + BlendPalettes(PALETTES_ALL, 8, RGB(31, 0, 0)); + game->gfx.counter = 4; break; case 1: - if (--game->spritesManager.animBerryIdx != 255) + if (--game->gfx.counter != UINT8_MAX) return 0; - BlendPalettes(0xFFFFFFFF, 0, RGB(31, 0, 0)); - game->spritesManager.animBerryIdx = 0; + BlendPalettes(PALETTES_ALL, 0, RGB(31, 0, 0)); + game->gfx.counter = 0; break; case 2: - if (!sub_814DE50(game, &game->spritesManager)) + if (!AreEffectsFinished(game, &game->gfx)) return 0; - LinkRfu_SetRfuFuncToSend6600(); - game->unk10 = 0; + Rfu_SetLinkStandbyCallback(); + game->cmdTimer = 0; SetGpuReg(REG_OFFSET_BG0VOFS, 0); SetGpuReg(REG_OFFSET_BG2VOFS, 0); SetGpuReg(REG_OFFSET_BG3VOFS, 0); @@ -1760,10 +1966,10 @@ static u32 BerryCrushCommand_HandleTimeUp(struct BerryCrushGame * game, u8 *para if (!IsLinkTaskFinished()) return 0; ConvertIntToDecimalStringN(gStringVar1, game->powder, STR_CONV_MODE_LEFT_ALIGN, 6); - BerryCrush_SetShowMessageParams(params, BCTEXT_TIMEUP, 1, 0, 0); - game->nextCmd = BCCMD_SaveTheGame; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); - game->unk10 = 0; + SetPrintMessageArgs(args, MSG_TIMES_UP, F_MSG_CLEAR, 0, CMD_NONE); + game->nextCmd = CMD_SAVE; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); + game->cmdTimer = 0; game->cmdState = 0; return 0; } @@ -1771,116 +1977,136 @@ static u32 BerryCrushCommand_HandleTimeUp(struct BerryCrushGame * game, u8 *para return 0; } -static u32 BerryCrushCommand_TabulateResults(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_TabulateResults(struct BerryCrushGame * game, UNUSED u8 *args) { - u8 i, j, r3; - s32 r2; - s32 r4; - u16 r6; + u8 i, j, tempPlayerId; + s32 temp1, temp2; + u16 tempStat; switch (game->cmdState) { case 0: memset(game->sendCmd, 0, 2 * sizeof(u16)); - if (game->unk98[game->localId].unk1A > game->timer) - game->unk98[game->localId].unk1A = game->timer; - game->sendCmd[0] = game->unk98[game->localId].unk1A; + if (game->players[game->localId].timePressingA > game->timer) + game->players[game->localId].timePressingA = game->timer; + game->sendCmd[0] = game->players[game->localId].timePressingA; SendBlock(0, game->sendCmd, 2); break; case 1: if (!IsLinkTaskFinished()) return 0; - game->unk10 = 0; + game->cmdTimer = 0; break; case 2: if (GetBlockReceivedStatus() != sReceivedPlayerBitmasks[game->playerCount - 2]) return 0; for (i = 0; i < game->playerCount; ++i) - game->unk98[i].unk1A = gBlockRecvBuffer[i][0]; - game->unk10 = 0; + game->players[i].timePressingA = gBlockRecvBuffer[i][0]; + game->cmdTimer = 0; game->sendCmd[0] = 0; ResetBlockReceivedFlags(); + + // If player is not leader, skip the steps + // where the results are calculated and sent. + // Group members just read the results sent + // to them by the leader. if (game->localId == 0) game->cmdState = 3; else game->cmdState = 6; return 0; case 3: - memset(&game->unk68, 0, sizeof(struct BerryCrushGame_68)); - game->unk68.unk04 = game->timer; - game->unk68.unk06 = game->unk18 / (game->timer / 60); - // (unk30 * 50 / unk32) + 50 - r2 = MathUtil_Mul32(game->unk30 << 8, 50 << 8); - r2 = MathUtil_Div32(r2, game->unk32 << 8) + (50 << 8); - r2 >>= 8; - game->unk68.unk08 = r2 & 0x7F; - // powder + playerCount * (r2 / 100) - r2 <<= 8; - r2 = MathUtil_Div32(r2, 100 << 8); - r4 = (game->powder * game->playerCount) << 8; - r4 = MathUtil_Mul32(r4, r2); - game->unk68.unk00 = r4 >> 8; - game->unk68.unk20[0][7] = Random() % 3; + memset(&game->results, 0, sizeof(struct BerryCrushGame_Results)); + game->results.time = game->timer; + game->results.targetPressesPerSec = game->targetAPresses / (game->timer / 60); + + // Calculate silkiness + // Silkiness is the percentage of times big sparkles were produced when possible, + // which itself depends on the number of A presses every 30 frames + // (numBigSparkles * 50 / numBigSparkleChecks) + 50 + temp1 = mulfx32(Q_24_8(game->numBigSparkles), Q_24_8(50)); + temp1 = divfx32(temp1, Q_24_8(game->numBigSparkleChecks)) + Q_24_8(50); + temp1 = Q_24_8_TO_INT(temp1); + game->results.silkiness = temp1 & 0x7F; + + // Calculate amount of powder + temp1 = Q_24_8(temp1); + temp1 = divfx32(temp1, Q_24_8(100)); + temp2 = Q_24_8(game->powder * game->playerCount); + temp2 = mulfx32(temp2, temp1); + game->results.powder = Q_24_8_TO_INT(temp2); + + // Choose random second results page + game->results.randomPageId = Random() % NUM_RANDOM_RESULTS_PAGES; for (i = 0; i < game->playerCount; ++i) { - game->unk68.unk20[0][i] = i; - game->unk68.unk20[1][i] = i; - game->unk68.stats[0][i] = game->unk98[i].unk16; - game->unk68.unk0A += game->unk68.stats[0][i]; - switch (game->unk68.unk20[0][7]) + game->results.playerIdsRanked[0][i] = i; + game->results.playerIdsRanked[1][i] = i; + game->results.stats[RESULTS_PAGE_PRESSES][i] = game->players[i].numAPresses; + game->results.totalAPresses += game->results.stats[RESULTS_PAGE_PRESSES][i]; + + // Calculate value for random second results page + switch (game->results.randomPageId) { - case 0: - if (game->unk98[i].unk16 != 0) + case RESULTS_PAGE_NEATNESS: + if (game->players[i].numAPresses != 0) { - r2 = game->unk98[i].unk14; - r2 <<= 8; - r2 = MathUtil_Mul32(r2, 0x6400); - r4 = game->unk98[i].unk16; - r4 <<= 8; - r4 = MathUtil_Div32(r2, r4); + // Calculate percentage of inputs that were in largest "neat" streak + // "Neat" inputs are those done at a regular interval + temp1 = game->players[i].maxNeatInputStreak; + temp1 = Q_24_8(temp1); + temp1 = mulfx32(temp1, Q_24_8(100)); + temp2 = game->players[i].numAPresses; + temp2 = Q_24_8(temp2); + temp2 = divfx32(temp1, temp2); } else { - r4 = 0; + temp2 = 0; } break; - case 1: - if (game->unk98[i].unk16 != 0) + case RESULTS_PAGE_COOPERATIVE: + if (game->players[i].numAPresses != 0) { - r2 = game->unk98[i].unk18; - r2 <<= 8; - r2 = MathUtil_Mul32(r2, 0x6400); - r4 = game->unk98[i].unk16; - r4 <<= 8; - r4 = MathUtil_Div32(r2, r4); + // Calculate percentage of inputs that were + // done at the same time as another player + temp1 = game->players[i].numSyncedAPresses; + temp1 = Q_24_8(temp1); + temp1 = mulfx32(temp1, Q_24_8(100)); + temp2 = game->players[i].numAPresses; + temp2 = Q_24_8(temp2); + temp2 = divfx32(temp1, temp2); } else { - r4 = 0; + temp2 = 0; } break; - case 2: - if (game->unk98[i].unk16 == 0) + case RESULTS_PAGE_POWER: + if (game->players[i].numAPresses == 0) { - r4 = 0; + temp2 = 0; } - else if (game->unk98[i].unk1A >= game->timer) + else if (game->players[i].timePressingA >= game->timer) { - r4 = 0x6400; + // Spent 100% of the time pressing A + temp2 = Q_24_8(100); } else { - r2 = game->unk98[i].unk1A; - r2 <<= 8; - r2 = MathUtil_Mul32(r2, 0x6400); - r4 = game->timer; - r4 <<= 8; - r4 = MathUtil_Div32(r2, r4); + // Calculate percentage of time the + // player spent pressing A + temp1 = game->players[i].timePressingA; + temp1 = Q_24_8(temp1); + temp1 = mulfx32(temp1, Q_24_8(100)); + temp2 = game->timer; + temp2 = Q_24_8(temp2); + temp2 = divfx32(temp1, temp2); } break; } - r4 >>= 4; - game->unk68.stats[1][i] = r4; + temp2 >>= 4; + game->results.stats[RESULTS_PAGE_RANDOM][i] = temp2; } break; case 4: @@ -1888,78 +2114,70 @@ static u32 BerryCrushCommand_TabulateResults(struct BerryCrushGame * game, UNUSE { for (j = game->playerCount - 1; j > i; --j) { - if (game->unk68.stats[0][j - 1] < game->unk68.stats[0][j]) + if (game->results.stats[RESULTS_PAGE_PRESSES][j - 1] < game->results.stats[RESULTS_PAGE_PRESSES][j]) { - r6 = game->unk68.stats[0][j]; - game->unk68.stats[0][j] = game->unk68.stats[0][j - 1]; - game->unk68.stats[0][j - 1] = r6; - r3 = game->unk68.unk20[0][j]; - game->unk68.unk20[0][j] = game->unk68.unk20[0][j - 1]; - game->unk68.unk20[0][j - 1] = r3; + SWAP(game->results.stats[RESULTS_PAGE_PRESSES][j], game->results.stats[RESULTS_PAGE_PRESSES][j - 1], tempStat); + SWAP(game->results.playerIdsRanked[0][j], game->results.playerIdsRanked[0][j - 1], tempPlayerId); } - if (game->unk68.stats[1][j - 1] < game->unk68.stats[1][j]) + if (game->results.stats[RESULTS_PAGE_RANDOM][j - 1] < game->results.stats[RESULTS_PAGE_RANDOM][j]) { - r6 = game->unk68.stats[1][j]; - game->unk68.stats[1][j] = game->unk68.stats[1][j - 1]; - game->unk68.stats[1][j - 1] = r6; - r3 = game->unk68.unk20[1][j]; - game->unk68.unk20[1][j] = game->unk68.unk20[1][j - 1]; - game->unk68.unk20[1][j - 1] = r3; + SWAP(game->results.stats[RESULTS_PAGE_RANDOM][j], game->results.stats[RESULTS_PAGE_RANDOM][j - 1], tempStat); + SWAP(game->results.playerIdsRanked[1][j], game->results.playerIdsRanked[1][j - 1], tempPlayerId); } } } - SendBlock(0, &game->unk68, sizeof(struct BerryCrushGame_68)); + SendBlock(0, &game->results, sizeof(struct BerryCrushGame_Results)); break; case 5: if (!IsLinkTaskFinished()) return 0; - game->unk10 = 0; + game->cmdTimer = 0; break; case 6: if (GetBlockReceivedStatus() != 1) return 0; - memset(&game->unk68, 0, sizeof(struct BerryCrushGame_68)); - memcpy(&game->unk68, gBlockRecvBuffer, sizeof(struct BerryCrushGame_68)); + memset(&game->results, 0, sizeof(struct BerryCrushGame_Results)); + memcpy(&game->results, gBlockRecvBuffer, sizeof(struct BerryCrushGame_Results)); ResetBlockReceivedFlags(); - game->unk10 = 0; + game->cmdTimer = 0; break; case 7: - BerryCrush_UpdateSav2Records(); - BerryCrush_RunOrScheduleCommand(BCCMD_ShowResults, 1, NULL); - game->gameState = 11; + SaveResults(); + RunOrScheduleCommand(CMD_SHOW_RESULTS, SCHEDULE_CMD, NULL); + game->gameState = STATE_RESULTS_PRESSES; game->cmdState = 0; - game->unk24 = 0; + game->newDepth = 0; return 0; } ++game->cmdState; return 0; } -static u32 BerryCrushCommand_ShowResults(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_ShowResults(struct BerryCrushGame * game, u8 *args) { switch (game->cmdState) { case 0: - if (!sub_814E644(game, &game->spritesManager)) + if (!OpenResultsWindow(game, &game->gfx)) return 0; break; case 1: CopyBgTilemapBufferToVram(0); - game->spritesManager.animBerryIdx = 30; + game->gfx.counter = 30; break; case 2: - if (game->spritesManager.animBerryIdx != 0) + if (game->gfx.counter != 0) { - --game->spritesManager.animBerryIdx; + --game->gfx.counter; return 0; } if (!JOY_NEW(A_BUTTON)) return 0; PlaySE(SE_SELECT); - sub_814E80C(game); + CloseResultsWindow(game); break; case 3: - if (game->gameState <= 12) + if (game->gameState <= STATE_RESULTS_RANDOM) { ++game->gameState; game->cmdState = 0; @@ -1969,9 +2187,9 @@ static u32 BerryCrushCommand_ShowResults(struct BerryCrushGame * game, u8 *param case 4: ConvertIntToDecimalStringN(gStringVar1, game->powder, STR_CONV_MODE_LEFT_ALIGN, 6); ConvertIntToDecimalStringN(gStringVar2, GetBerryPowder(), STR_CONV_MODE_LEFT_ALIGN, 6); - BerryCrush_SetShowMessageParams(params, BCTEXT_GAINEDPOWDER, 3, 0, 0); - game->nextCmd = BCCMD_SaveTheGame; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); + SetPrintMessageArgs(args, MSG_POWDER, F_MSG_CLEAR | F_MSG_EXPAND, 0, CMD_NONE); + game->nextCmd = CMD_SAVE; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); game->cmdState = 0; return 0; } @@ -1979,36 +2197,36 @@ static u32 BerryCrushCommand_ShowResults(struct BerryCrushGame * game, u8 *param return 0; } -static u32 BerryCrushCommand_SaveTheGame(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_SaveGame(struct BerryCrushGame * game, u8 *args) { switch (game->cmdState) { case 0: - if (game->timer >= 36000) - BerryCrush_HideTimerSprites(&game->spritesManager); - BerryCrush_SetShowMessageParams(params, BCTEXT_COMMSTANDBY, 0, 0, BCCMD_BeginNormalPaletteFade); - game->nextCmd = BCCMD_SaveTheGame; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); + if (game->timer >= MAX_TIME) + HideTimer(&game->gfx); + SetPrintMessageArgs(args, MSG_COMM_STANDBY, 0, 0, CMD_FADE); + game->nextCmd = CMD_SAVE; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); game->cmdState = 0; return 0; case 1: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 2: if (!IsLinkTaskFinished()) return 0; DrawDialogueFrame(0, FALSE); - AddTextPrinterParameterized2(0, 2, gText_SavingDontTurnOffThePower2, 0, NULL, 2, 1, 3); + AddTextPrinterParameterized2(0, 2, gText_SavingDontTurnOffThePower2, 0, NULL, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); CopyWindowToVram(0, COPYWIN_BOTH); - CreateTask(Task_SaveGame_UpdatedLinkRecords, 0); + CreateTask(Task_LinkSave, 0); break; case 3: - if (FuncIsActiveTask(Task_SaveGame_UpdatedLinkRecords)) + if (FuncIsActiveTask(Task_LinkSave)) return 0; break; case 4: - BerryCrush_RunOrScheduleCommand(BCCMD_AskPlayAgain, 1, NULL); - game->gameState = 15; + RunOrScheduleCommand(CMD_ASK_PLAY_AGAIN, SCHEDULE_CMD, NULL); + game->gameState = STATE_PLAY_AGAIN; game->cmdState = 0; return 0; } @@ -2016,41 +2234,41 @@ static u32 BerryCrushCommand_SaveTheGame(struct BerryCrushGame * game, u8 *param return 0; } -static u32 BerryCrushCommand_AskPlayAgain(struct BerryCrushGame * game, u8 *params) +static u32 Cmd_AskPlayAgain(struct BerryCrushGame * game, u8 *args) { - s8 r4 = 0; + s8 input = 0; switch (game->cmdState) { case 0: - BerryCrush_SetShowMessageParams(params, BCTEXT_ASKPLAYAGAIN, 0, 0, BCCMD_BeginNormalPaletteFade); - game->nextCmd = BCCMD_AskPlayAgain; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); - game->cmdState = 0; // dunno what it's doing because it's already in case 0 + SetPrintMessageArgs(args, MSG_PLAY_AGAIN, 0, 0, CMD_FADE); + game->nextCmd = CMD_ASK_PLAY_AGAIN; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); + game->cmdState = 0; // State is progressed by CMD_PRINT_MSG return 0; case 1: DisplayYesNoMenuDefaultYes(); break; case 2: - r4 = Menu_ProcessInputNoWrapClearOnChoose(); - if (r4 != -2) + input = Menu_ProcessInputNoWrapClearOnChoose(); + if (input != LIST_CANCEL) { memset(game->sendCmd, 0, sizeof(game->sendCmd)); - if (r4 == 0) + if (input == 0) { - if (CheckHasAtLeastOneBerry()) - game->unk14 = 0; + if (HasAtLeastOneBerry()) + game->playAgainState = PLAY_AGAIN_YES; else - game->unk14 = 3; + game->playAgainState = PLAY_AGAIN_NO_BERRIES; } else { - game->unk14 = 1; + game->playAgainState = PLAY_AGAIN_NO; } ClearDialogWindowAndFrame(0, TRUE); - BerryCrush_SetShowMessageParams(params, BCTEXT_COMMSTANDBY, 0, 0, 0); - game->nextCmd = BCCMD_CommunicatePlayAgainResponses; - BerryCrush_RunOrScheduleCommand(BCCMD_PrintMessage, 1, NULL); + SetPrintMessageArgs(args, MSG_COMM_STANDBY, 0, 0, CMD_NONE); + game->nextCmd = CMD_COMM_PLAY_AGAIN; + RunOrScheduleCommand(CMD_PRINT_MSG, SCHEDULE_CMD, NULL); game->cmdState = 0; } return 0; @@ -2059,40 +2277,46 @@ static u32 BerryCrushCommand_AskPlayAgain(struct BerryCrushGame * game, u8 *para return 0; } -static u32 BerryCrushCommand_CommunicatePlayAgainResponses(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_CommunicatePlayAgainResponses(struct BerryCrushGame * game, UNUSED u8 *args) { u8 i = 0; switch (game->cmdState) { case 0: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 1: if (!IsLinkTaskFinished()) return 0; - game->sendCmd[0] = game->unk14; + + // Send player's Yes/No response to partners + game->sendCmd[0] = game->playAgainState; game->recvCmd[0] = 0; SendBlock(0, game->sendCmd, sizeof(u16)); break; case 2: if (!IsLinkTaskFinished()) return 0; - game->unk10 = 0; + game->cmdTimer = 0; break; case 3: + // Wait for partners responses if (GetBlockReceivedStatus() != sReceivedPlayerBitmasks[game->playerCount - 2]) return 0; - for (; i < game->playerCount; ++i) + + // Read partners responses + for (i = 0; i < game->playerCount; ++i) game->recvCmd[0] += gBlockRecvBuffer[i][0]; - if (game->recvCmd[0] != 0) - BerryCrush_RunOrScheduleCommand(BCCMD_PlayAgainFailureMessage, 1, NULL); + + if (game->recvCmd[0] != PLAY_AGAIN_YES) + RunOrScheduleCommand(CMD_PLAY_AGAIN_NO, SCHEDULE_CMD, NULL); else - BerryCrush_RunOrScheduleCommand(BCCMD_FadeOutToPlayAgain, 1, NULL); + RunOrScheduleCommand(CMD_PLAY_AGAIN_YES, SCHEDULE_CMD, NULL); ResetBlockReceivedFlags(); game->sendCmd[0] = 0; game->recvCmd[0] = 0; - game->unk10 = 0; + game->cmdTimer = 0; game->cmdState = 0; return 0; } @@ -2100,12 +2324,12 @@ static u32 BerryCrushCommand_CommunicatePlayAgainResponses(struct BerryCrushGame return 0; } -static u32 BerryCrushCommand_FadeOutToPlayAgain(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_PlayAgain(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { case 0: - BeginNormalPaletteFade(0xFFFFFFFF, 1, 0, 0x10, RGB_BLACK); + BeginNormalPaletteFade(PALETTES_ALL, 1, 0, 0x10, RGB_BLACK); UpdatePaletteFade(); break; case 1: @@ -2114,15 +2338,15 @@ static u32 BerryCrushCommand_FadeOutToPlayAgain(struct BerryCrushGame * game, UN break; case 2: ClearDialogWindowAndFrame(0, TRUE); - sub_814DA04(game); - BeginNormalPaletteFade(0xFFFFFFFF, 0, 0x10, 0, RGB_BLACK); + ResetCrusherPos(game); + BeginNormalPaletteFade(PALETTES_ALL, 0, 16, 0, RGB_BLACK); UpdatePaletteFade(); break; case 3: if (UpdatePaletteFade()) return 0; - BerryCrush_RunOrScheduleCommand(BCCMD_AskPickBerry, 1, NULL); - game->gameState = 3; + RunOrScheduleCommand(CMD_ASK_PICK_BERRY, SCHEDULE_CMD, NULL); + game->gameState = STATE_PICK_BERRY; game->cmdState = 0; return 0; } @@ -2130,29 +2354,29 @@ static u32 BerryCrushCommand_FadeOutToPlayAgain(struct BerryCrushGame * game, UN return 0; } -static u32 BerryCrushCommand_PlayAgainFailureMessage(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_StopGame(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { case 0: DrawDialogueFrame(0, FALSE); - if (game->unk14 == 3) - AddTextPrinterParameterized2(0, 2, sBerryCrushMessages[BCTEXT_CANCEL_NOBERRIES], game->textSpeed, NULL, 2, 1, 3); + if (game->playAgainState == PLAY_AGAIN_NO_BERRIES) + AddTextPrinterParameterized2(0, 2, sMessages[MSG_NO_BERRIES], game->textSpeed, NULL, 2, 1, 3); else - AddTextPrinterParameterized2(0, 2, sBerryCrushMessages[BCTEXT_CANCEL_DROPPEDOUT], game->textSpeed, NULL, 2, 1, 3); + AddTextPrinterParameterized2(0, 2, sMessages[MSG_DROPPED], game->textSpeed, NULL, 2, 1, 3); CopyWindowToVram(0, COPYWIN_BOTH); break; case 1: if (IsTextPrinterActive(0)) return 0; - game->spritesManager.animBerryIdx = 120; + game->gfx.counter = 120; break; case 2: - if (game->spritesManager.animBerryIdx != 0) - --game->spritesManager.animBerryIdx; + if (game->gfx.counter != 0) + --game->gfx.counter; else { - BerryCrush_RunOrScheduleCommand(BCCMD_GracefulExit, 1, NULL); + RunOrScheduleCommand(CMD_CLOSE_LINK, SCHEDULE_CMD, NULL); game->cmdState = 0; } return 0; @@ -2161,12 +2385,12 @@ static u32 BerryCrushCommand_PlayAgainFailureMessage(struct BerryCrushGame * gam return 0; } -static u32 BerryCrushCommand_GracefulExit(struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_CloseLink(struct BerryCrushGame * game, UNUSED u8 *args) { switch (game->cmdState) { case 0: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 1: if (!IsLinkTaskFinished()) @@ -2176,8 +2400,8 @@ static u32 BerryCrushCommand_GracefulExit(struct BerryCrushGame * game, UNUSED u case 2: if (gReceivedRemoteLinkPlayers) return 0; - game->nextCmd = BCCMD_Quit; - BerryCrush_RunOrScheduleCommand(BCCMD_TeardownGfx, 1, NULL); + game->nextCmd = CMD_QUIT; + RunOrScheduleCommand(CMD_HIDE_GAME, SCHEDULE_CMD, NULL); game->cmdState = 2; // ??? return 0; } @@ -2185,77 +2409,79 @@ static u32 BerryCrushCommand_GracefulExit(struct BerryCrushGame * game, UNUSED u return 0; } -static u32 BerryCrushCommand_Quit(UNUSED struct BerryCrushGame * game, UNUSED u8 *params) +static u32 Cmd_Quit(UNUSED struct BerryCrushGame * game, UNUSED u8 *args) { - ExitBerryCrushWithCallback(NULL); + QuitBerryCrush(NULL); return 0; } -static void sub_814D4D8(struct BerryCrushGame * game) +static void ResetGame(struct BerryCrushGame * game) { - u8 r5 = 0; + u8 i = 0; IncrementGameStat(GAME_STAT_BERRY_CRUSH_POINTS); - game->unkD = 0; - game->unk10 = 0; - game->gameState = 2; - game->unk14 = 0; + game->unused = 0; + game->cmdTimer = 0; + game->gameState = STATE_RESET; + game->playAgainState = 0; game->powder = 0; - game->unk18 = 0; - game->unk1A = 0; - game->unk20 = 0; - game->unk24 = 0; - game->unk25_0 = 0; - game->unk25_1 = 0; - game->unk25_2 = 0; - game->unk25_3 = FALSE; - game->unk25_4 = 0; - game->unk25_5 = 0; - game->unk26 = 0; + game->targetAPresses = 0; + game->totalAPresses = 0; + game->targetDepth = 0; + game->newDepth = 0; + game->noRoomForPowder = FALSE; + game->newRecord = FALSE; + game->playedSound = FALSE; + game->endGame = FALSE; + game->bigSparkle = FALSE; + game->sparkleAmount = 0; + game->leaderTimer = 0; game->timer = 0; - game->unk2E = 0; - game->unk32 = -1; - game->unk30 = 0; - game->unk34 = 0; - for (; r5 < 5; ++r5) + game->bigSparkleCounter = 0; + game->numBigSparkleChecks = -1; + game->numBigSparkles = 0; + game->sparkleCounter = 0; + for (i = 0; i < 5; ++i) { - game->unk98[r5].unkC = -1; - game->unk98[r5].unkE = 0; - game->unk98[r5].unk10 = 0; - game->unk98[r5].unk12 = 1; - game->unk98[r5].unk14 = 0; - game->unk98[r5].unk16 = 0; - game->unk98[r5].unk18 = 0; - game->unk98[r5].unk1A = 0; - game->unk98[r5].unk1B = 0; - game->unk98[r5].unk1C = 0; + game->players[i].berryId = -1; + game->players[i].inputTime = 0; + game->players[i].neatInputStreak = 0; + game->players[i].timeSincePrevInput = 1; + game->players[i].maxNeatInputStreak = 0; + game->players[i].numAPresses = 0; + game->players[i].numSyncedAPresses = 0; + game->players[i].timePressingA = 0; + game->players[i].inputFlags = 0; + game->players[i].inputState = INPUT_STATE_NONE; } } -void BerryCrush_SetPaletteFadeParams(u8 *params, bool8 communicateAfter, u32 selectedPals, s8 delay, u8 startY, u8 targetY, u16 palette) +static void SetPaletteFadeArgs(u8 *args, bool8 communicateAfter, u32 selectedPals, s8 delay, u8 startY, u8 targetY, u16 palette) { - params[0] = ((u8 *)&selectedPals)[0]; - params[1] = ((u8 *)&selectedPals)[1]; - params[2] = ((u8 *)&selectedPals)[2]; - params[3] = ((u8 *)&selectedPals)[3]; - params[4] = delay; - params[5] = startY; - params[6] = targetY; - params[7] = ((u8 *)&palette)[0]; - params[8] = ((u8 *)&palette)[1]; - params[9] = communicateAfter; + args[0] = ((u8 *)&selectedPals)[0]; + args[1] = ((u8 *)&selectedPals)[1]; + args[2] = ((u8 *)&selectedPals)[2]; + args[3] = ((u8 *)&selectedPals)[3]; + args[4] = delay; + args[5] = startY; + args[6] = targetY; + args[7] = ((u8 *)&palette)[0]; + args[8] = ((u8 *)&palette)[1]; + args[9] = communicateAfter; } -void BerryCrush_SetShowMessageParams(u8 *params, u8 stringId, u8 flags, u16 waitKeys, u8 followupCmd) +static void SetPrintMessageArgs(u8 *args, u8 stringId, u8 flags, u16 waitKeys, u8 followupCmd) { - params[0] = stringId; - params[1] = flags; - params[2] = ((u8 *)&waitKeys)[0]; - params[3] = ((u8 *)&waitKeys)[1]; - params[4] = followupCmd; + args[0] = stringId; + args[1] = flags; + args[2] = ((u8 *)&waitKeys)[0]; + args[3] = ((u8 *)&waitKeys)[1]; + args[4] = followupCmd; } -int BerryCrush_InitBgs(void) +// GF file break + +static s32 ShowGameDisplay(void) { struct BerryCrushGame * game = GetBerryCrushGame(); if (game == NULL) @@ -2283,9 +2509,9 @@ int BerryCrush_InitBgs(void) case 3: ResetBgsAndClearDma3BusyFlags(FALSE); InitBgsFromTemplates(0, sBgTemplates, NELEMS(sBgTemplates)); - SetBgTilemapBuffer(1, game->spritesManager.bgBuffers[0]); - SetBgTilemapBuffer(2, game->spritesManager.bgBuffers[2]); - SetBgTilemapBuffer(3, game->spritesManager.bgBuffers[3]); + SetBgTilemapBuffer(1, game->gfx.bgBuffers[0]); + SetBgTilemapBuffer(2, game->gfx.bgBuffers[2]); + SetBgTilemapBuffer(3, game->gfx.bgBuffers[3]); ChangeBgX(0, 0, 0); ChangeBgY(0, 0, 0); ChangeBgX(2, 0, 0); @@ -2306,24 +2532,24 @@ int BerryCrush_InitBgs(void) CopyBgTilemapBufferToVram(1); CopyBgTilemapBufferToVram(2); CopyBgTilemapBufferToVram(3); - DecompressAndCopyTileDataToVram(1, gUnknown_8EAFFC0, 0, 0, 0); + DecompressAndCopyTileDataToVram(1, gBerryCrush_Crusher_Gfx, 0, 0, 0); break; case 6: if (FreeTempTileDataBuffersIfPossible()) return 0; InitStandardTextBoxWindows(); - ResetBg0(); - sub_814EB38(game); - sub_814EBB0(game); + InitTextBoxGfxAndPrinters(); + CreatePlayerNameWindows(game); + DrawPlayerNameWindows(game); gPaletteFade.bufferTransferDisabled = TRUE; break; case 7: - LoadPalette(gUnknown_8EAFEA0, 0, 0x180); - CopyToBgTilemapBuffer(1, gBerryCrushGrinderTopTilemap, 0, 0); - CopyToBgTilemapBuffer(2, gBerryCrushContainerCapTilemap, 0, 0); - CopyToBgTilemapBuffer(3, gBerryCrushBackgroundTilemap, 0, 0); - sub_814EC80(game); + LoadPalette(gBerryCrush_Crusher_Pal, 0, 0x180); + CopyToBgTilemapBuffer(1, sCrusherTop_Tilemap, 0, 0); + CopyToBgTilemapBuffer(2, sContainerCap_Tilemap, 0, 0); + CopyToBgTilemapBuffer(3, sBg_Tilemap, 0, 0); + CopyPlayerNameWindowGfxToBg(game); CopyBgTilemapBufferToVram(1); CopyBgTilemapBufferToVram(2); CopyBgTilemapBufferToVram(3); @@ -2331,14 +2557,14 @@ int BerryCrush_InitBgs(void) case 8: LoadWirelessStatusIndicatorSpriteGfx(); CreateWirelessStatusIndicatorSprite(0, 0); - sub_814ECE0(game); + CreateGameSprites(game); SetGpuReg(REG_OFFSET_BG1VOFS, -gSpriteCoordOffsetY); ChangeBgX(1, 0, 0); ChangeBgY(1, 0, 0); break; case 9: gPaletteFade.bufferTransferDisabled = FALSE; - BlendPalettes(0xFFFFFFFF, 16, RGB_BLACK); + BlendPalettes(PALETTES_ALL, 16, RGB_BLACK); ShowBg(0); ShowBg(1); ShowBg(2); @@ -2353,16 +2579,16 @@ int BerryCrush_InitBgs(void) return 0; } -int BerryCrush_TeardownBgs(void) +static s32 HideGameDisplay(void) { - struct BerryCrushGame * var0 = GetBerryCrushGame(); - if (!var0) + struct BerryCrushGame * game = GetBerryCrushGame(); + if (!game) return -1; - switch (var0->cmdState) + switch (game->cmdState) { case 0: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); break; case 1: if (!IsLinkTaskFinished()) @@ -2370,7 +2596,7 @@ int BerryCrush_TeardownBgs(void) // fall through. The original author forgot to use "break" here // because this will call BeginNormalPaletteFade() twice. case 2: - BeginNormalPaletteFade(0xFFFFFFFF, 0, 0, 16, RGB_BLACK); + BeginNormalPaletteFade(PALETTES_ALL, 0, 0, 16, RGB_BLACK); UpdatePaletteFade(); break; case 3: @@ -2401,47 +2627,62 @@ int BerryCrush_TeardownBgs(void) break; case 6: DestroyWirelessStatusIndicatorSprite(); - sub_814EF10(var0); - DigitObjUtil_Teardown(); + DestroyGameSprites(game); + DigitObjUtil_Free(); break; case 7: - var0->cmdState = 0; + game->cmdState = 0; return 1; } - var0->cmdState++; + game->cmdState++; return 0; } -int sub_814D9CC(struct BerryCrushGame * game) +static s32 UpdateGame(struct BerryCrushGame * game) { gSpriteCoordOffsetY = game->depth + game->vibration; SetGpuReg(REG_OFFSET_BG1VOFS, -gSpriteCoordOffsetY); - if (game->gameState == 7) + if (game->gameState == STATE_PLAYING) { - BerryCrush_PrintTimeOnSprites(&game->spritesManager, game->timer); + PrintTimer(&game->gfx, game->timer); } return 0; } -void sub_814DA04(struct BerryCrushGame * game) +static void ResetCrusherPos(struct BerryCrushGame * game) { - game->depth = -104; + game->depth = CRUSHER_START_Y; game->vibration = 0; gSpriteCoordOffsetX = 0; - gSpriteCoordOffsetY = -104; + gSpriteCoordOffsetY = CRUSHER_START_Y; } -void BerryCrush_CreateBerrySprites(struct BerryCrushGame * game, struct BerryCrushGame_138 * spritesManager) +// Sprite data for berry sprites. Identical to fields for sparkle sprites +#define sX data[0] +#define sYSpeed data[1] +#define sYAccel data[2] +#define sXSpeed data[3] +#define sSinIdx data[4] +#define sSinSpeed data[5] +#define sAmplitude data[6] +// The last element (data[7]) is a bitfield. +// The first 15 bits are the y coord to stop at. +// The last bit is a flag for whether or not to move horizontally too +#define sBitfield data[7] +#define MASK_TARGET_Y 0x7FFF +#define F_MOVE_HORIZ 0x8000 + +static void CreateBerrySprites(struct BerryCrushGame * game, struct BerryCrushGame_Gfx * spritesManager) { u8 i; u8 spriteId; - s16 var0, var1; + s16 distance, var1; s16 *data; - int var3; - s16 var5; - u32 var6; + s32 amplitude; + s16 speed; + u32 var2; for (i = 0; i < game->playerCount; i++) { @@ -2449,58 +2690,58 @@ void BerryCrush_CreateBerrySprites(struct BerryCrushGame * game, struct BerryCru &sSpriteTemplate_PlayerBerry, sPlayerBerrySpriteTags[i], sPlayerBerrySpriteTags[i], - game->unk98[i].unkC + FIRST_BERRY_INDEX); + game->players[i].berryId + FIRST_BERRY_INDEX); spritesManager->berrySprites[i] = &gSprites[spriteId]; spritesManager->berrySprites[i]->oam.priority = 3; spritesManager->berrySprites[i]->affineAnimPaused = TRUE; - spritesManager->berrySprites[i]->pos1.x = spritesManager->seatCoords[i]->unk8 + 120; + spritesManager->berrySprites[i]->pos1.x = spritesManager->playerCoords[i]->berryXOffset + 120; spritesManager->berrySprites[i]->pos1.y = -16; data = spritesManager->berrySprites[i]->data; - var5 = 512; - data[1] = var5; - data[2] = 32; - data[7] = 112; - var0 = spritesManager->seatCoords[i]->unkA - spritesManager->seatCoords[i]->unk8; - var3 = var0; - if (var0 < 0) - var3 += 3; + speed = Q_8_8(2.0); + sYSpeed = speed; + sYAccel = Q_8_8(0.125); + sBitfield = 112; // Setting bits in MASK_TARGET_Y + distance = spritesManager->playerCoords[i]->berryXDest - spritesManager->playerCoords[i]->berryXOffset; + amplitude = distance; + if (distance < 0) + amplitude += 3; - data[6] = var3 >> 2; - var0 *= 128; - var6 = var5 + 32; - var6 = var6 / 2; - var1 = MathUtil_Div16Shift(7, 0x3F80, var6); - data[0] = (u16)spritesManager->berrySprites[i]->pos1.x * 128; - data[3] = MathUtil_Div16Shift(7, var0, var1); - var1 = MathUtil_Mul16Shift(7, var1, 85); - data[4] = 0; - data[5] = MathUtil_Div16Shift(7, 0x3F80, var1); - data[7] |= 0x8000; - if (spritesManager->seatCoords[i]->unk8 < 0) + sAmplitude = amplitude >> 2; + distance = Q_N_S(7, distance); + var2 = speed + Q_8_8(0.125); + var2 = var2 / 2; // go from Q8.8 to Q9.7 + var1 = divfxn16(7, Q_N_S(7, 127), var2); + sX = Q_N_S(7, (u16)spritesManager->berrySprites[i]->pos1.x); + sXSpeed = divfxn16(7, distance, var1); + var1 = mulfxn16(7, var1, Q_N_S(7, 0.666666667)); + sSinIdx = 0; + sSinSpeed = divfxn16(7, Q_N_S(7, 127), var1); + sBitfield |= F_MOVE_HORIZ; + if (spritesManager->playerCoords[i]->berryXOffset < 0) StartSpriteAffineAnim(spritesManager->berrySprites[i], 1); } } -void SpriteCB_DropBerryIntoCrusher(struct Sprite * sprite) +static void SpriteCB_DropBerryIntoCrusher(struct Sprite * sprite) { s16 *data = sprite->data; - data[1] += data[2]; - sprite->pos2.y += data[1] >> 8; - if (data[7] & 0x8000) + sYSpeed += sYAccel; + sprite->pos2.y += Q_8_8_TO_INT(sYSpeed); + if (sBitfield & F_MOVE_HORIZ) { - sprite->data[0] += data[3]; - data[4] += data[5]; - sprite->pos2.x = Sin(data[4] >> 7, data[6]); - if ((data[7] & 0x8000) && (data[4] >> 7) > 126) + sprite->sX += sXSpeed; + sSinIdx += sSinSpeed; + sprite->pos2.x = Sin(Q_N_S_TO_INT(7, sSinIdx), sAmplitude); + if ((sBitfield & F_MOVE_HORIZ) && Q_N_S_TO_INT(7, sSinIdx) > 126) { sprite->pos2.x = 0; - data[7] &= 0x7FFF; + sBitfield &= MASK_TARGET_Y; } } - sprite->pos1.x = data[0] >> 7; - if (sprite->pos1.y + sprite->pos2.y >= (data[7] & 0x7FFF)) + sprite->pos1.x = Q_N_S_TO_INT(7, sX); + if (sprite->pos1.y + sprite->pos2.y >= (sBitfield & MASK_TARGET_Y)) { sprite->callback = SpriteCallbackDummy; FreeSpriteOamMatrix(sprite); @@ -2508,127 +2749,143 @@ void SpriteCB_DropBerryIntoCrusher(struct Sprite * sprite) } } -void BerryCrushFreeBerrySpriteGfx(struct BerryCrushGame * arg0, UNUSED struct BerryCrushGame_138 * arg1) +#undef sX +#undef sYSpeed +#undef sYAccel +#undef sXSpeed +#undef sSinIdx +#undef sSinSpeed +#undef sAmplitude +#undef sBitfield +#undef MASK_TARGET_Y +#undef F_MOVE_HORIZ + +static void BerryCrushFreeBerrySpriteGfx(struct BerryCrushGame * game, UNUSED struct BerryCrushGame_Gfx * gfx) { u8 i; - for (i = 0; i < arg0->playerCount; i++) + for (i = 0; i < game->playerCount; i++) { FreeSpritePaletteByTag(sPlayerBerrySpriteTags[i]); FreeSpriteTilesByTag(sPlayerBerrySpriteTags[i]); } } -void sub_814DC5C(struct BerryCrushGame * game, struct BerryCrushGame_138 * manager) +static void UpdateInputEffects(struct BerryCrushGame * game, struct BerryCrushGame_Gfx * gfx) { - u8 sp4; - struct BerryCrushGame_4E * var4E; + u8 numPlayersPressed; + struct BerryCrushGame_LinkState * linkState; u8 i; - u16 var, var2; + u16 temp1, xModifier; - sp4 = 0; - var4E = (struct BerryCrushGame_4E *)&game->recvCmd; + numPlayersPressed = 0; + linkState = (struct BerryCrushGame_LinkState *)&game->recvCmd; for (i = 0; i < game->playerCount; i++) { - var = var4E->unkA >> (i * 3); - var &= 7; - if (var) +#define flags temp1 + flags = linkState->inputFlags >> (i * INPUT_FLAGS_PER_PLAYER); + flags &= INPUT_FLAG_MASK; + if (flags) { - sp4++; - if (var & 0x4) - StartSpriteAnim(manager->impactSprites[i], 1); + numPlayersPressed++; + if (flags & F_INPUT_HIT_SYNC) + StartSpriteAnim(gfx->impactSprites[i], 1); else - StartSpriteAnim(manager->impactSprites[i], 0); + StartSpriteAnim(gfx->impactSprites[i], 0); - manager->impactSprites[i]->invisible = FALSE; - manager->impactSprites[i]->animPaused = FALSE; - manager->impactSprites[i]->pos2.x = gUnknown_846F2D0[(var % 4) - 1][0]; - manager->impactSprites[i]->pos2.y = gUnknown_846F2D0[(var % 4) - 1][1]; + gfx->impactSprites[i]->invisible = FALSE; + gfx->impactSprites[i]->animPaused = FALSE; + gfx->impactSprites[i]->pos2.x = sImpactCoords[(flags % (NELEMS(sImpactCoords) + 1)) - 1][0]; + gfx->impactSprites[i]->pos2.y = sImpactCoords[(flags % (NELEMS(sImpactCoords) + 1)) - 1][1]; +#undef flags } } - if (sp4 == 0) + if (numPlayersPressed == 0) { - game->unk25_2 = 0; + game->playedSound = FALSE; } else { - var = (u8)(game->timer % 3); - var2 = var; - for (i = 0; i < var4E->unkC * 2 + 3; i++) +#define yModifier temp1 + yModifier = (u8)(game->timer % 3); + xModifier = yModifier; + for (i = 0; i < linkState->sparkleAmount * 2 + 3; i++) { - if (manager->sparkleSprites[i]->invisible) + if (gfx->sparkleSprites[i]->invisible) { - manager->sparkleSprites[i]->callback = sub_814F0D8; - manager->sparkleSprites[i]->pos1.x = gUnknown_846F2D6[i][0] + 120; - manager->sparkleSprites[i]->pos1.y = gUnknown_846F2D6[i][1] + 136 - (var * 4); - manager->sparkleSprites[i]->pos2.x = gUnknown_846F2D6[i][0] + (gUnknown_846F2D6[i][0] / (var2 * 4)); - manager->sparkleSprites[i]->pos2.y = gUnknown_846F2D6[i][1]; - if (var4E->unk4_1) - StartSpriteAnim(manager->sparkleSprites[i], 1); + gfx->sparkleSprites[i]->callback = SpriteCB_Sparkle_Init; + gfx->sparkleSprites[i]->pos1.x = sSparkleCoords[i][0] + 120; + gfx->sparkleSprites[i]->pos1.y = sSparkleCoords[i][1] + 136 - (temp1 * 4); + gfx->sparkleSprites[i]->pos2.x = sSparkleCoords[i][0] + (sSparkleCoords[i][0] / (xModifier * 4)); + gfx->sparkleSprites[i]->pos2.y = sSparkleCoords[i][1]; + if (linkState->bigSparkle) + StartSpriteAnim(gfx->sparkleSprites[i], 1); else - StartSpriteAnim(manager->sparkleSprites[i], 0); + StartSpriteAnim(gfx->sparkleSprites[i], 0); - var++; - if (var > 3) - var = 0; + yModifier++; + if (yModifier > 3) + yModifier = 0; } } - if (game->unk25_2) +#undef yModifier + + if (game->playedSound) { - game->unk25_2 = 0; + game->playedSound = FALSE; } else { - if (sp4 == 1) + if (numPlayersPressed == 1) PlaySE(SE_MUD_BALL); else PlaySE(SE_BREAKABLE_DOOR); - game->unk25_2 = 1; + game->playedSound = TRUE; } } } -bool32 sub_814DE50(struct BerryCrushGame * arg0, struct BerryCrushGame_138 * arg1) +static bool32 AreEffectsFinished(struct BerryCrushGame * game, struct BerryCrushGame_Gfx * gfx) { u8 i; - for (i = 0; i < arg0->playerCount; i++) + for (i = 0; i < game->playerCount; i++) { - if (!arg1->impactSprites[i]->invisible) + if (!gfx->impactSprites[i]->invisible) return FALSE; } - for (i = 0; i < 11; i++) + for (i = 0; i < NELEMS(gfx->sparkleSprites); i++) { - if (!arg1->sparkleSprites[i]->invisible) + if (!gfx->sparkleSprites[i]->invisible) return FALSE; } - if (arg0->vibration != 0) - arg0->vibration = 0; + if (game->vibration != 0) + game->vibration = 0; return TRUE; } -static void FramesToMinSec(struct BerryCrushGame_138 * manager, u16 frames) +static void FramesToMinSec(struct BerryCrushGame_Gfx * gfx, u16 frames) { u8 i = 0; u32 fractionalFrames = 0; - s16 r3 = 0; + s16 frac_secs = 0; - manager->minutes = frames / 3600; - manager->secondsInt = (frames % 3600) / 60; - r3 = MathUtil_Mul16((frames % 60) << 8, 4); + gfx->minutes = frames / 3600; + gfx->secondsInt = (frames % 3600) / 60; + frac_secs = mulfx16(Q_8_8(frames % 60), Q_8_8(0.016666667)); for (i = 0; i < 8; i++) { - if ((r3 >> (7 - i)) & 1) + if ((frac_secs >> (7 - i)) & 1) fractionalFrames += sPressingSpeedConversionTable[i]; } - manager->secondsFrac = fractionalFrames / 1000000; + gfx->secondsFrac = fractionalFrames / 1000000; } static void PrintTextCentered(u8 windowId, u8 left, u8 colorId, const u8 *string) @@ -2637,7 +2894,7 @@ static void PrintTextCentered(u8 windowId, u8 left, u8 colorId, const u8 *string AddTextPrinterParameterized3(windowId, 2, left, 0, sBerryCrushTextColorTable[colorId], 0, string); } -static void PrintBerryCrushResultWindow(struct BerryCrushGame * game, u8 command, u8 x, u8 y) +static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 y) { u8 i = 0; u8 linkPlayerId = 0; @@ -2645,27 +2902,27 @@ static void PrintBerryCrushResultWindow(struct BerryCrushGame * game, u8 command u8 j; s32 score; u8 realX; - struct BerryCrushGame_68 * bcPlayers = &game->unk68; + struct BerryCrushGame_Results * bcPlayers = &game->results; s32 realX2; - for (; i < game->playerCount; i++) + for (i = 0; i < game->playerCount; i++) { DynamicPlaceholderTextUtil_Reset(); switch (command) { - case 0: + case RESULTS_PAGE_PRESSES: // Number of presses - linkPlayerId = bcPlayers->unk20[command][i]; + linkPlayerId = bcPlayers->playerIdsRanked[command][i]; if (i != 0 && bcPlayers->stats[command][i] != bcPlayers->stats[command][i - 1]) linkIdToPrint = i; ConvertIntToDecimalStringN(gStringVar1, bcPlayers->stats[command][i], STR_CONV_MODE_RIGHT_ALIGN, 4); realX = x - GetStringWidth(2, sBCRankingHeaders[command], -1) - 4; - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, realX, y + 14 * i, sBerryCrushTextColorTable[0], 0, sBCRankingHeaders[command]); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, realX - 24, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar1); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX, y + 14 * i, sBerryCrushTextColorTable[0], 0, sBCRankingHeaders[command]); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX - 24, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar1); break; - case 1: + case RESULTS_PAGE_RANDOM: // Neatness - linkPlayerId = bcPlayers->unk20[command][i]; + linkPlayerId = bcPlayers->playerIdsRanked[command][i]; if (i != 0 && bcPlayers->stats[command][i] != bcPlayers->stats[command][i - 1]) linkIdToPrint = i; ConvertIntToDecimalStringN(gStringVar1, bcPlayers->stats[command][i] >> 4, STR_CONV_MODE_RIGHT_ALIGN, 3); @@ -2680,18 +2937,18 @@ static void PrintBerryCrushResultWindow(struct BerryCrushGame * game, u8 command ConvertIntToDecimalStringN(gStringVar2, realX, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, sBCRankingHeaders[command]); realX2 = x - 4; - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, realX2 - GetStringWidth(2, gStringVar4, 0), y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX2 - GetStringWidth(2, gStringVar4, 0), y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); break; - case 2: + case RESULTS_PAGE_CRUSHING: // Berry names linkPlayerId = i; linkIdToPrint = i; - j = game->unk98[i].unkC; + j = game->players[i].berryId; if (j >= LAST_BERRY_INDEX - FIRST_BERRY_INDEX + 2) j = 0; StringCopy(gStringVar1, gBerries[j].name); StringExpandPlaceholders(gStringVar4, sBCRankingHeaders[command]); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x - GetStringWidth(2, gStringVar4, -1) - 4, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x - GetStringWidth(2, gStringVar4, -1) - 4, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); break; } if (linkPlayerId == game->localId) @@ -2699,45 +2956,45 @@ static void PrintBerryCrushResultWindow(struct BerryCrushGame * game, u8 command else StringCopy(gStringVar3, gText_1_Dynamic0); gStringVar3[0] = linkIdToPrint + CHAR_1; - DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, game->unk98[linkPlayerId].unk0); + DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, game->players[linkPlayerId].name); DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gStringVar3); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, 4, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 4, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); } } -static void sub_814E32C(struct BerryCrushGame * game) +static void printCrushingResults(struct BerryCrushGame * game) { u8 i = 0; u8 x = 0; u32 score = 0; - struct BerryCrushGame_68 *players = &game->unk68; - u8 y = GetWindowAttribute(game->spritesManager.unk82, WINDOW_HEIGHT) * 8 - 42; + struct BerryCrushGame_Results *players = &game->results; + u8 y = GetWindowAttribute(game->gfx.resultsIndowId, WINDOW_HEIGHT) * 8 - 42; - FramesToMinSec(&game->spritesManager, players->unk04); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_TimeColon); + FramesToMinSec(&game->gfx, players->time); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_TimeColon); x = 190 - (u8)GetStringWidth(2, gText_SpaceSec, 0); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[0], 0, gText_SpaceSec); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gText_SpaceSec); x -= 32; - ConvertIntToDecimalStringN(gStringVar1, game->spritesManager.secondsInt, STR_CONV_MODE_LEADING_ZEROS, 2); - ConvertIntToDecimalStringN(gStringVar2, game->spritesManager.secondsFrac, STR_CONV_MODE_LEADING_ZEROS, 2); + ConvertIntToDecimalStringN(gStringVar1, game->gfx.secondsInt, STR_CONV_MODE_LEADING_ZEROS, 2); + ConvertIntToDecimalStringN(gStringVar2, game->gfx.secondsFrac, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, gText_XDotY2); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); x -= (u8)GetStringWidth(2, gText_SpaceMin, 0) + 3; - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[0], 0, gText_SpaceMin); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gText_SpaceMin); x -= 9; - ConvertIntToDecimalStringN(gStringVar1, game->spritesManager.minutes, STR_CONV_MODE_LEADING_ZEROS, 1); + ConvertIntToDecimalStringN(gStringVar1, game->gfx.minutes, STR_CONV_MODE_LEADING_ZEROS, 1); StringExpandPlaceholders(gStringVar4, gText_StrVar1); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); y += 14; - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_PressingSpeed); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_PressingSpeed); x = 190 - (u8)GetStringWidth(2, gText_TimesPerSec, 0); - AddTextPrinterParameterized3(game->spritesManager.unk82, 3, x, y, sBerryCrushTextColorTable[0], 0, gText_TimesPerSec); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 3, x, y, sBerryCrushTextColorTable[0], 0, gText_TimesPerSec); for (i = 0; i < 8; ++i) if (((u8)game->pressingSpeed >> (7 - i)) & 1) @@ -2746,84 +3003,89 @@ static void sub_814E32C(struct BerryCrushGame * game) ConvertIntToDecimalStringN(gStringVar2, score / 1000000, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, gText_XDotY3); x -= 38; - if (game->unk25_1) - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[5], 0, gStringVar4); + if (game->newRecord) + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[5], 0, gStringVar4); else - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); y += 14; - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_Silkiness); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_Silkiness); - ConvertIntToDecimalStringN(gStringVar1, players->unk08, STR_CONV_MODE_RIGHT_ALIGN, 3); + ConvertIntToDecimalStringN(gStringVar1, players->silkiness, STR_CONV_MODE_RIGHT_ALIGN, 3); StringExpandPlaceholders(gStringVar4, gText_Var1Percent); x = 190 - (u8)GetStringWidth(2, gStringVar4, 0); - AddTextPrinterParameterized3(game->spritesManager.unk82, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); } -bool32 sub_814E644(struct BerryCrushGame * game, struct BerryCrushGame_138 * spriteManager) +static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushGame_Gfx * spriteManager) { u8 playerCountMinus2; struct WindowTemplate template; - switch (spriteManager->unk80) + switch (spriteManager->resultsState) { case 0: playerCountMinus2 = game->playerCount - 2; - BerryCrush_HideTimerSprites(spriteManager); - memcpy(&template, &gUnknown_846E428[game->gameState - 11], sizeof(struct WindowTemplate)); - if (game->gameState == 13) - template.height = gUnknown_846E448[1][playerCountMinus2]; + HideTimer(spriteManager); +// template = sWindowTemplates_Results[game->gameState - STATE_RESULTS_PRESSES]; + memcpy(&template, &sWindowTemplates_Results[game->gameState - STATE_RESULTS_PRESSES], sizeof(struct WindowTemplate)); + if (game->gameState == STATE_RESULTS_CRUSHING) + template.height = sResultsWindowHeights[1][playerCountMinus2]; else - template.height = gUnknown_846E448[0][playerCountMinus2]; - spriteManager->unk82 = AddWindow(&template); + template.height = sResultsWindowHeights[0][playerCountMinus2]; + spriteManager->resultsIndowId = AddWindow(&template); break; case 1: - PutWindowTilemap(spriteManager->unk82); - FillWindowPixelBuffer(spriteManager->unk82, PIXEL_FILL(0)); + PutWindowTilemap(spriteManager->resultsIndowId); + FillWindowPixelBuffer(spriteManager->resultsIndowId, PIXEL_FILL(0)); break; case 2: - TextWindow_SetStdFrame0_WithPal(spriteManager->unk82, 0x21D, 0xD0); - DrawStdFrameWithCustomTileAndPalette(spriteManager->unk82, FALSE, 541, 13); + TextWindow_SetStdFrame0_WithPal(spriteManager->resultsIndowId, 0x21D, 0xD0); + DrawStdFrameWithCustomTileAndPalette(spriteManager->resultsIndowId, FALSE, 541, 13); break; case 3: playerCountMinus2 = game->playerCount - 2; switch (game->gameState) { - case 11: - PrintTextCentered(spriteManager->unk82, 22, 3, gText_PressesRankings); - PrintBerryCrushResultWindow(game, 0, 0xB0, 8 * gUnknown_846E448[0][playerCountMinus2] - game->playerCount * 14); - spriteManager->unk80 = 5; + case STATE_RESULTS_PRESSES: + PrintTextCentered(spriteManager->resultsIndowId, 22, 3, gText_PressesRankings); + PrintResultsText(game, RESULTS_PAGE_PRESSES, 0xB0, 8 * sResultsWindowHeights[0][playerCountMinus2] - game->playerCount * 14); + spriteManager->resultsState = 5; return FALSE; - case 12: - PrintTextCentered(spriteManager->unk82, 22, 4, sBCRankingHeaders[game->unk68.unk20[0][7] + 3]); - PrintBerryCrushResultWindow(game, 1, 0xB0, 8 * gUnknown_846E448[0][playerCountMinus2] - game->playerCount * 14); - spriteManager->unk80 = 5; + case STATE_RESULTS_RANDOM: + PrintTextCentered(spriteManager->resultsIndowId, 22, 4, sBCRankingHeaders[game->results.playerIdsRanked[0][7] + 3]); + PrintResultsText(game, RESULTS_PAGE_RANDOM, 0xB0, 8 * sResultsWindowHeights[0][playerCountMinus2] - game->playerCount * 14); + spriteManager->resultsState = 5; return FALSE; - case 13: - PrintTextCentered(spriteManager->unk82, 24, 3, gText_CrushingResults); - PrintBerryCrushResultWindow(game, 2, 0xC0, 0x10); + case STATE_RESULTS_CRUSHING: + PrintTextCentered(spriteManager->resultsIndowId, 24, 3, gText_CrushingResults); + PrintResultsText(game, RESULTS_PAGE_CRUSHING, 0xC0, 0x10); break; } break; case 4: - sub_814E32C(game); + printCrushingResults(game); break; case 5: - CopyWindowToVram(spriteManager->unk82, COPYWIN_BOTH); - spriteManager->unk80 = 0; + CopyWindowToVram(spriteManager->resultsIndowId, COPYWIN_BOTH); + spriteManager->resultsState = 0; return TRUE; } - ++spriteManager->unk80; + ++spriteManager->resultsState; return FALSE; } -void sub_814E80C(struct BerryCrushGame * game) +static void CloseResultsWindow(struct BerryCrushGame * game) { - ClearStdWindowAndFrameToTransparent(game->spritesManager.unk82, 1); - RemoveWindow(game->spritesManager.unk82); - sub_814EBB0(game); + ClearStdWindowAndFrameToTransparent(game->gfx.resultsIndowId, 1); + RemoveWindow(game->gfx.resultsIndowId); + DrawPlayerNameWindows(game); } +#define tState data[0] +#define tWindowId data[1] +#define tPressingSpeeds(i) data[2 + (i)] // data[2]-[5], for different group sizes + static void Task_ShowBerryCrushRankings(u8 taskId) { u8 i = 0, j, xPos, yPos; @@ -2831,19 +3093,19 @@ static void Task_ShowBerryCrushRankings(u8 taskId) s16 *data = gTasks[taskId].data; u8 *str; - switch (data[0]) + switch (tState) { case 0: - data[1] = AddWindow(&sWindowTemplate_BerryCrushRankings); - PutWindowTilemap(data[1]); - FillWindowPixelBuffer(data[1], PIXEL_FILL(0)); - TextWindow_SetStdFrame0_WithPal(data[1], 0x21D, 0xD0); - DrawStdFrameWithCustomTileAndPalette(data[1], 0, 0x21D, 0xD); + tWindowId = AddWindow(&sWindowTemplate_BerryCrushRankings); + PutWindowTilemap(tWindowId); + FillWindowPixelBuffer(tWindowId, PIXEL_FILL(0)); + TextWindow_SetStdFrame0_WithPal(tWindowId, 0x21D, 0xD0); + DrawStdFrameWithCustomTileAndPalette(tWindowId, 0, 0x21D, 0xD); break; case 1: xPos = 96 - GetStringWidth(2, gText_BerryCrush2, -1) / 2u; AddTextPrinterParameterized3( - data[1], + tWindowId, 2, xPos, 2, @@ -2853,7 +3115,7 @@ static void Task_ShowBerryCrushRankings(u8 taskId) ); xPos = 96 - GetStringWidth(2, gText_PressingSpeedRankings, -1) / 2u; AddTextPrinterParameterized3( - data[1], + tWindowId, 2, xPos, 18, @@ -2867,7 +3129,7 @@ static void Task_ShowBerryCrushRankings(u8 taskId) ConvertIntToDecimalStringN(gStringVar1, i + 2, STR_CONV_MODE_LEFT_ALIGN, 1); StringExpandPlaceholders(gStringVar4, gText_Var1Players); AddTextPrinterParameterized3( - data[1], + tWindowId, 2, 4, yPos, @@ -2877,17 +3139,17 @@ static void Task_ShowBerryCrushRankings(u8 taskId) ); for (j = 0; j < 8; ++j) { - if (((data[i + 2] & 0xFF) >> (7 - j)) & 1) + if (((tPressingSpeeds(i) & 0xFF) >> (7 - j)) & 1) score += sPressingSpeedConversionTable[j]; } - ConvertIntToDecimalStringN(gStringVar1, (u16)data[i + 2] >> 8, STR_CONV_MODE_RIGHT_ALIGN, 3); + ConvertIntToDecimalStringN(gStringVar1, (u16)tPressingSpeeds(i) >> 8, STR_CONV_MODE_RIGHT_ALIGN, 3); ConvertIntToDecimalStringN(gStringVar2, score / 1000000, STR_CONV_MODE_LEADING_ZEROS, 2); str = StringExpandPlaceholders(gStringVar4, gText_XDotY3); *str++ = CHAR_SPACE; StringCopy(str, gText_TimesPerSec); xPos = 192 - (u8)GetStringWidth(3, gStringVar4, 0); AddTextPrinterParameterized3( - data[1], + tWindowId, 3, xPos, yPos, @@ -2898,24 +3160,24 @@ static void Task_ShowBerryCrushRankings(u8 taskId) yPos += 14; score = 0; } - CopyWindowToVram(data[1], COPYWIN_BOTH); + CopyWindowToVram(tWindowId, COPYWIN_BOTH); break; case 2: - if (gMain.newKeys & (A_BUTTON | B_BUTTON)) + if (JOY_NEW(A_BUTTON | B_BUTTON)) break; else return; case 3: - ClearStdWindowAndFrameToTransparent(data[1], 1); - ClearWindowTilemap(data[1]); - RemoveWindow(data[1]); + ClearStdWindowAndFrameToTransparent(tWindowId, TRUE); + ClearWindowTilemap(tWindowId); + RemoveWindow(tWindowId); DestroyTask(taskId); EnableBothScriptContexts(); ScriptContext2_Disable(); - data[0] = 0; + tState = 0; return; } - ++data[0]; + ++tState; } void ShowBerryCrushRankings(void) @@ -2924,95 +3186,96 @@ void ShowBerryCrushRankings(void) ScriptContext2_Enable(); taskId = CreateTask(Task_ShowBerryCrushRankings, 0); - gTasks[taskId].data[2] = gSaveBlock2Ptr->berryCrush.berryCrushResults[0]; - gTasks[taskId].data[3] = gSaveBlock2Ptr->berryCrush.berryCrushResults[1]; - gTasks[taskId].data[4] = gSaveBlock2Ptr->berryCrush.berryCrushResults[2]; - gTasks[taskId].data[5] = gSaveBlock2Ptr->berryCrush.berryCrushResults[3]; + gTasks[taskId].tPressingSpeeds(0) = gSaveBlock2Ptr->berryCrush.berryCrushResults[0]; + gTasks[taskId].tPressingSpeeds(1) = gSaveBlock2Ptr->berryCrush.berryCrushResults[1]; + gTasks[taskId].tPressingSpeeds(2) = gSaveBlock2Ptr->berryCrush.berryCrushResults[2]; + gTasks[taskId].tPressingSpeeds(3) = gSaveBlock2Ptr->berryCrush.berryCrushResults[3]; } -static void BerryCrush_PrintTimeOnSprites(struct BerryCrushGame_138 * manager, u16 frames) +static void PrintTimer(struct BerryCrushGame_Gfx * gfx, u16 frames) { - FramesToMinSec(manager, frames); - DigitObjUtil_PrintNumOn(0, manager->minutes); - DigitObjUtil_PrintNumOn(1, manager->secondsInt); - DigitObjUtil_PrintNumOn(2, manager->secondsFrac); + FramesToMinSec(gfx, frames); + DigitObjUtil_PrintNumOn(0, gfx->minutes); + DigitObjUtil_PrintNumOn(1, gfx->secondsInt); + DigitObjUtil_PrintNumOn(2, gfx->secondsFrac); } -void BerryCrush_HideTimerSprites(struct BerryCrushGame_138 * manager) +static void HideTimer(struct BerryCrushGame_Gfx * gfx) { - manager->timerSprites[0]->invisible = TRUE; - manager->timerSprites[1]->invisible = TRUE; + gfx->timerSprites[0]->invisible = TRUE; + gfx->timerSprites[1]->invisible = TRUE; DigitObjUtil_HideOrShow(2, 1); DigitObjUtil_HideOrShow(1, 1); DigitObjUtil_HideOrShow(0, 1); } -static void sub_814EB38(struct BerryCrushGame * game) +static void CreatePlayerNameWindows(struct BerryCrushGame * game) { u8 i; for (i = 0; i < game->playerCount; ++i) { - game->spritesManager.seatCoords[i] = &gUnknown_846F294[gUnknown_846F280[game->playerCount - 2][i]]; - game->spritesManager.unk83[i] = AddWindow(&gUnknown_846E3F8[game->spritesManager.seatCoords[i]->unk0]); - PutWindowTilemap(game->spritesManager.unk83[i]); - FillWindowPixelBuffer(game->spritesManager.unk83[i], PIXEL_FILL(0)); + game->gfx.playerCoords[i] = &sPlayerCoords[gUnknown_846F280[game->playerCount - 2][i]]; + game->gfx.nameWindowIds[i] = AddWindow(&sWindowTemplates_PlayerNames[game->gfx.playerCoords[i]->playerId]); + PutWindowTilemap(game->gfx.nameWindowIds[i]); + FillWindowPixelBuffer(game->gfx.nameWindowIds[i], PIXEL_FILL(0)); } } -static void sub_814EBB0(struct BerryCrushGame * game) +static void DrawPlayerNameWindows(struct BerryCrushGame * game) { u8 i; for (i = 0; i < game->playerCount; ++i) { - PutWindowTilemap(game->spritesManager.unk83[i]); + PutWindowTilemap(game->gfx.nameWindowIds[i]); if (i == game->localId) { AddTextPrinterParameterized4( - game->spritesManager.unk83[i], + game->gfx.nameWindowIds[i], 2, - 36 - GetStringWidth(2, game->unk98[i].unk0, 0) / 2u, + 36 - GetStringWidth(2, game->players[i].name, 0) / 2u, 1, 0, 0, sBerryCrushTextColorTable[1], 0, - game->unk98[i].unk0 + game->players[i].name ); } else { AddTextPrinterParameterized4( - game->spritesManager.unk83[i], + game->gfx.nameWindowIds[i], 2, - 36 - GetStringWidth(2, game->unk98[i].unk0, 0) / 2u, + 36 - GetStringWidth(2, game->players[i].name, 0) / 2u, 1, 0, 0, sBerryCrushTextColorTable[2], 0, - game->unk98[i].unk0 + game->players[i].name ); } - CopyWindowToVram(game->spritesManager.unk83[i], COPYWIN_BOTH); + CopyWindowToVram(game->gfx.nameWindowIds[i], COPYWIN_BOTH); } CopyBgTilemapBufferToVram(0); } -static void sub_814EC80(struct BerryCrushGame * game) +// Each player name window border uses a color that corresponds to a slot of the crusher lid +static void CopyPlayerNameWindowGfxToBg(struct BerryCrushGame * game) { u8 i = 0; - u8 *r4; + u8 *crusherGfx; - LZ77UnCompWram(gUnknown_8EB0ADC, gDecompressionBuffer); - for (r4 = gDecompressionBuffer; i < game->playerCount; ++i) + LZ77UnCompWram(gBerryCrush_Crusher_Tilemap, gDecompressionBuffer); + for (crusherGfx = gDecompressionBuffer; i < game->playerCount; ++i) { CopyToBgTilemapBufferRect( 3, - &r4[game->spritesManager.seatCoords[i]->unk0 * 40], - game->spritesManager.seatCoords[i]->unk1, - game->spritesManager.seatCoords[i]->unk2, + &crusherGfx[game->gfx.playerCoords[i]->playerId * 40], + game->gfx.playerCoords[i]->windowGfxX, + game->gfx.playerCoords[i]->windowGfxY, 10, 2 ); @@ -3020,52 +3283,60 @@ static void sub_814EC80(struct BerryCrushGame * game) CopyBgTilemapBufferToVram(3); } -static void sub_814ECE0(struct BerryCrushGame * game) +static void CreateGameSprites(struct BerryCrushGame * game) { u8 i = 0; u8 spriteId; - game->depth = -104; + game->depth = CRUSHER_START_Y; game->vibration = 0; gSpriteCoordOffsetX = 0; - gSpriteCoordOffsetY = -104; - for (; i < 4; ++i) + gSpriteCoordOffsetY = CRUSHER_START_Y; + for (i = 0; i < NELEMS(sSpriteSheets) - 1; ++i) LoadCompressedSpriteSheet(&sSpriteSheets[i]); LoadSpritePalettes(sSpritePals); + + // Create sprite for crusher base spriteId = CreateSprite(&sSpriteTemplate_BerryCrushCore, 120, 88, 5); - game->spritesManager.coreSprite = &gSprites[spriteId]; - game->spritesManager.coreSprite->oam.priority = 3; - game->spritesManager.coreSprite->coordOffsetEnabled = TRUE; - game->spritesManager.coreSprite->animPaused = TRUE; + game->gfx.coreSprite = &gSprites[spriteId]; + game->gfx.coreSprite->oam.priority = 3; + game->gfx.coreSprite->coordOffsetEnabled = TRUE; + game->gfx.coreSprite->animPaused = TRUE; + + // Create sprites for the impact effect for (i = 0; i < game->playerCount; ++i) { spriteId = CreateSprite( &sSpriteTemplate_BerryCrushImpact, - game->spritesManager.seatCoords[i]->unk4 + 120, - game->spritesManager.seatCoords[i]->unk6 + 32, + game->gfx.playerCoords[i]->impactXOffset + 120, + game->gfx.playerCoords[i]->impactYOffset + 32, 0 ); - game->spritesManager.impactSprites[i] = &gSprites[spriteId]; - game->spritesManager.impactSprites[i]->oam.priority = 1; - game->spritesManager.impactSprites[i]->invisible = TRUE; - game->spritesManager.impactSprites[i]->coordOffsetEnabled = TRUE; - game->spritesManager.impactSprites[i]->animPaused = TRUE; + game->gfx.impactSprites[i] = &gSprites[spriteId]; + game->gfx.impactSprites[i]->oam.priority = 1; + game->gfx.impactSprites[i]->invisible = TRUE; + game->gfx.impactSprites[i]->coordOffsetEnabled = TRUE; + game->gfx.impactSprites[i]->animPaused = TRUE; } - for (i = 0; i < NELEMS(game->spritesManager.sparkleSprites); ++i) + + // Create sprites for sparkle effect + for (i = 0; i < NELEMS(game->gfx.sparkleSprites); ++i) { spriteId = CreateSprite( &sSpriteTemplate_BerryCrushPowderSparkles, - gUnknown_846F2D6[i][0] + 120, - gUnknown_846F2D6[i][1] + 136, + sSparkleCoords[i][0] + 120, + sSparkleCoords[i][1] + 136, 6 ); - game->spritesManager.sparkleSprites[i] = &gSprites[spriteId]; - game->spritesManager.sparkleSprites[i]->oam.priority = 3; - game->spritesManager.sparkleSprites[i]->invisible = TRUE; - game->spritesManager.sparkleSprites[i]->animPaused = TRUE; - game->spritesManager.sparkleSprites[i]->data[0] = i; + game->gfx.sparkleSprites[i] = &gSprites[spriteId]; + game->gfx.sparkleSprites[i]->oam.priority = 3; + game->gfx.sparkleSprites[i]->invisible = TRUE; + game->gfx.sparkleSprites[i]->animPaused = TRUE; + game->gfx.sparkleSprites[i]->data[0] = i; } - for (i = 0; i < NELEMS(game->spritesManager.timerSprites); ++i) + + // Create sprites for timer + for (i = 0; i < NELEMS(game->gfx.timerSprites); ++i) { spriteId = CreateSprite( &sSpriteTemplate_BerryCrushTimer, @@ -3073,43 +3344,44 @@ static void sub_814ECE0(struct BerryCrushGame * game) 8, 0 ); - game->spritesManager.timerSprites[i] = &gSprites[spriteId]; - game->spritesManager.timerSprites[i]->oam.priority = 0; - game->spritesManager.timerSprites[i]->invisible = FALSE; - game->spritesManager.timerSprites[i]->animPaused = FALSE; + game->gfx.timerSprites[i] = &gSprites[spriteId]; + game->gfx.timerSprites[i]->oam.priority = 0; + game->gfx.timerSprites[i]->invisible = FALSE; + game->gfx.timerSprites[i]->animPaused = FALSE; } DigitObjUtil_CreatePrinter(0, 0, &sDigitObjTemplates[0]); DigitObjUtil_CreatePrinter(1, 0, &sDigitObjTemplates[1]); DigitObjUtil_CreatePrinter(2, 0, &sDigitObjTemplates[2]); - if (game->gameState == 1) - BerryCrush_HideTimerSprites(&game->spritesManager); + + if (game->gameState == STATE_INIT) + HideTimer(&game->gfx); } -static void sub_814EF10(struct BerryCrushGame * r5) +static void DestroyGameSprites(struct BerryCrushGame * game) { - u8 r4 = 0; + u8 i = 0; - FreeSpriteTilesByTag(4); - FreeSpriteTilesByTag(3); - FreeSpriteTilesByTag(2); - FreeSpriteTilesByTag(1); - FreeSpritePaletteByTag(4); - FreeSpritePaletteByTag(2); - FreeSpritePaletteByTag(1); - for (; r4 < NELEMS(r5->spritesManager.timerSprites); ++r4) - DestroySprite(r5->spritesManager.timerSprites[r4]); + FreeSpriteTilesByTag(TAG_TIMER_DIGITS); + FreeSpriteTilesByTag(GFXTAG_SPARKLE); + FreeSpriteTilesByTag(GFXTAG_IMPACT); + FreeSpriteTilesByTag(TAG_CRUSHER_BASE); + FreeSpritePaletteByTag(TAG_TIMER_DIGITS); + FreeSpritePaletteByTag(PALTAG_EFFECT); + FreeSpritePaletteByTag(TAG_CRUSHER_BASE); + for (; i < NELEMS(game->gfx.timerSprites); ++i) + DestroySprite(game->gfx.timerSprites[i]); DigitObjUtil_DeletePrinter(2); DigitObjUtil_DeletePrinter(1); DigitObjUtil_DeletePrinter(0); - for (r4 = 0; r4 < NELEMS(r5->spritesManager.sparkleSprites); ++r4) - DestroySprite(r5->spritesManager.sparkleSprites[r4]); - for (r4 = 0; r4 < r5->playerCount; ++r4) - DestroySprite(r5->spritesManager.impactSprites[r4]); - if (r5->spritesManager.coreSprite->inUse) - DestroySprite(r5->spritesManager.coreSprite); + for (i = 0; i < NELEMS(game->gfx.sparkleSprites); ++i) + DestroySprite(game->gfx.sparkleSprites[i]); + for (i = 0; i < game->playerCount; ++i) + DestroySprite(game->gfx.impactSprites[i]); + if (game->gfx.coreSprite->inUse) + DestroySprite(game->gfx.coreSprite); } -static void SpriteCB_BerryCrushImpact(struct Sprite * sprite) +static void SpriteCB_Impact(struct Sprite * sprite) { if (sprite->animEnded) { @@ -3118,7 +3390,7 @@ static void SpriteCB_BerryCrushImpact(struct Sprite * sprite) } } -static void sub_814EFFC(struct Sprite * sprite) +static void SpriteCB_Sparkle_End(struct Sprite * sprite) { u8 r1 = 0; SpriteCallback r5 = SpriteCallbackDummy; @@ -3132,51 +3404,79 @@ static void sub_814EFFC(struct Sprite * sprite) sprite->callback = r5; } -static void sub_814F044(struct Sprite * sprite) -{ - s16 *r4 = sprite->data; +// Redefining from above +#define sX data[0] +#define sYSpeed data[1] +#define sYAccel data[2] +#define sXSpeed data[3] +#define sSinIdx data[4] +#define sSinSpeed data[5] +#define sAmplitude data[6] +// The last element (data[7]) is a bitfield. +// The first 15 bits are the y coord to stop at. +// The last bit is a flag for whether or not to move on the x too +#define sBitfield data[7] +#define MASK_TARGET_Y 0x7FFF +#define F_MOVE_HORIZ 0x8000 - r4[1] += r4[2]; - sprite->pos2.y += r4[1] >> 8; - if (r4[7] & 0x8000) +static void SpriteCB_Sparkle(struct Sprite * sprite) +{ + s16 *data = sprite->data; + + sYSpeed += sYAccel; + sprite->pos2.y += Q_8_8_TO_INT(sYSpeed); + if (sBitfield & F_MOVE_HORIZ) { - sprite->data[0] += r4[3]; - r4[4] += r4[5]; - sprite->pos2.x = Sin(r4[4] >> 7, r4[6]); - if (r4[7] & 0x8000 && r4[4] >> 7 > 126) + sprite->sX += sXSpeed; + sSinIdx += sSinSpeed; + sprite->pos2.x = Sin(Q_N_S_TO_INT(7, sSinIdx), sAmplitude); + if ((sBitfield & F_MOVE_HORIZ) && Q_N_S_TO_INT(7, sSinIdx) > 126) { sprite->pos2.x = 0; - r4[7] &= 0x7FFF; + sBitfield &= MASK_TARGET_Y; } } - sprite->pos1.x = r4[0] >> 7; - if (sprite->pos1.y + sprite->pos2.y > (r4[7] & 0x7FFF)) - sprite->callback = sub_814EFFC; + sprite->pos1.x = Q_N_S_TO_INT(7, sX); + if (sprite->pos1.y + sprite->pos2.y > (sBitfield & MASK_TARGET_Y)) + sprite->callback = SpriteCB_Sparkle_End; } -static void sub_814F0D8(struct Sprite * sprite) +static void SpriteCB_Sparkle_Init(struct Sprite * sprite) { - s16 *r7 = sprite->data; - s16 r4, r5; - s32 r2; - u32 r8 = 0; + s16 *data = sprite->data; + s16 xMult, var; + s16 targetY; + s32 speed; + u32 zero = 0; - r2 = 640; - r7[1] = r2; - r7[2] = 32; - r7[7] = 168; - r4 = sprite->pos2.x * 128; - r5 = MathUtil_Div16Shift(7, (168 - sprite->pos1.y) << 7, (r2 + 32) >> 1); - sprite->data[0] = sprite->pos1.x << 7; - r7[3] = MathUtil_Div16Shift(7, r4, r5); - r2 = MathUtil_Mul16Shift(7, r5, 85); - r7[4] = r8; - r7[5] = MathUtil_Div16Shift(7, 0x3F80, r2); - r7[6] = sprite->pos2.x / 4; - r7[7] |= 0x8000; - sprite->pos2.y = r8; - sprite->pos2.x = r8; - sprite->callback = sub_814F044; + speed = Q_8_8(2.5); + sYSpeed = speed; + sYAccel = Q_8_8(0.125); + targetY = 168; + sBitfield = targetY; + xMult = Q_N_S(7, sprite->pos2.x); + var = divfxn16(7, Q_N_S(7, targetY - (u16)sprite->pos1.y), (speed + Q_8_8(0.125)) >> 1); + sprite->sX = Q_N_S(7, (u16)sprite->pos1.x); + sXSpeed = divfxn16(7, xMult, var); + speed = mulfxn16(7, var, Q_N_S(7, 0.666666667)); + sSinIdx = zero; + sSinSpeed = divfxn16(7, Q_N_S(7, 127), speed); + sAmplitude = sprite->pos2.x / 4; + sBitfield |= F_MOVE_HORIZ; + sprite->pos2.y = zero; + sprite->pos2.x = zero; + sprite->callback = SpriteCB_Sparkle; sprite->animPaused = FALSE; sprite->invisible = FALSE; } + +#undef sX +#undef sYSpeed +#undef sYAccel +#undef sXSpeed +#undef sSinIdx +#undef sSinSpeed +#undef sAmplitude +#undef sBitfield +#undef MASK_TARGET_Y +#undef F_MOVE_HORIZ diff --git a/src/digit_obj_util.c b/src/digit_obj_util.c index 852c386ac..3f7128513 100644 --- a/src/digit_obj_util.c +++ b/src/digit_obj_util.c @@ -74,7 +74,7 @@ bool32 DigitObjUtil_Init(u32 count) u32 i; if (sOamWork != NULL) - DigitObjUtil_Teardown(); + DigitObjUtil_Free(); sOamWork = Alloc(sizeof(*sOamWork)); if (sOamWork == NULL) @@ -97,7 +97,7 @@ bool32 DigitObjUtil_Init(u32 count) return TRUE; } -void DigitObjUtil_Teardown(void) +void DigitObjUtil_Free(void) { if (sOamWork != NULL) { diff --git a/src/dodrio_berry_picking.c b/src/dodrio_berry_picking.c index 35562bde7..53af1f48c 100644 --- a/src/dodrio_berry_picking.c +++ b/src/dodrio_berry_picking.c @@ -299,7 +299,7 @@ static void sub_8150A84(u8 taskId) case 2: if (!sub_8155E68()) { - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); gUnknown_203F3E0->unk0C++; } break; @@ -412,7 +412,7 @@ static void sub_8150CF4(void) gUnknown_203F3E0->unk10++; break; case 1: - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); gUnknown_203F3E0->unk10++; break; case 2: @@ -424,7 +424,7 @@ static void sub_8150CF4(void) case 3: if (!IsMinigameCountdownRunning()) { - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); gUnknown_203F3E0->unk10++; } break; @@ -1023,12 +1023,12 @@ static void sub_815184C(void) { if (gUnknown_203F3E0->unk128 != 0) { - sub_80FBA44(); + ClearRecvCommands(); gUnknown_203F3E0->unk124 = 0; } else if (gUnknown_203F3E0->unk124 > 70) { - sub_80FBA44(); + ClearRecvCommands(); gUnknown_203F3E0->unk124 = 0; } } @@ -1089,12 +1089,12 @@ static void sub_8151A5C(void) { if (gUnknown_203F3E0->unk128 != 0) { - sub_80FBA44(); + ClearRecvCommands(); gUnknown_203F3E0->unk124 = 0; } else if (gUnknown_203F3E0->unk124 > 70) { - sub_80FBA44(); + ClearRecvCommands(); gUnknown_203F3E0->unk124 = 0; } } diff --git a/src/dodrio_berry_picking_2.c b/src/dodrio_berry_picking_2.c index aa9f65042..e5e263647 100644 --- a/src/dodrio_berry_picking_2.c +++ b/src/dodrio_berry_picking_2.c @@ -1431,12 +1431,12 @@ static void sub_8155A78(void) case 2: if (!IsDma3ManagerBusyWithBgCopy()) { - CreateTask(Task_SaveGame_UpdatedLinkRecords, 0); + CreateTask(Task_LinkSave, 0); gUnknown_203F440->state++; } break; case 3: - if (!FuncIsActiveTask(Task_SaveGame_UpdatedLinkRecords)) + if (!FuncIsActiveTask(Task_LinkSave)) gUnknown_203F440->state++; break; default: @@ -1577,7 +1577,7 @@ static void sub_8155EA0(void) ChangeBgX(3, 0, 0); ChangeBgY(3, 0, 0); InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_ON | DISPCNT_OBJ_1D_MAP); SetBgTilemapBuffer(3, gUnknown_203F440->tilemapBuffers[0]); SetBgTilemapBuffer(1, gUnknown_203F440->tilemapBuffers[1]); diff --git a/src/dodrio_berry_picking_3.c b/src/dodrio_berry_picking_3.c index fec1d62f7..3bd538f94 100644 --- a/src/dodrio_berry_picking_3.c +++ b/src/dodrio_berry_picking_3.c @@ -8,7 +8,7 @@ void sub_815A5BC(s32 a0) struct Padded_U8 data[2]; data[0].value = 1; data[1].value = a0; - RfuPrepareSend0x2f00(data); + Rfu_SendPacket(data); } u8 sub_815A5E8(s32 a0) @@ -114,7 +114,7 @@ void sub_815A61C(struct DodrioSubstruct_31A0 * arg0, struct DodrioSubstruct_31A0 packet.unkA_3 = arg6; packet.unkB_1 = arg7; packet.unkB_0 = arg8; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } u32 sub_815A950(u32 unused, struct DodrioSubstruct_31A0 * arg0, struct DodrioSubstruct_31A0_2C * arg1, struct DodrioSubstruct_31A0_2C * arg2, struct DodrioSubstruct_31A0_2C * arg3, struct DodrioSubstruct_31A0_2C * arg4, struct DodrioSubstruct_31A0_2C * arg5, u8 *arg6, u32 *arg7, u32 *arg8) @@ -192,7 +192,7 @@ void sub_815AAD8(u8 arg0) struct UnkPacket3 packet; packet.id = 3; packet.unk4 = arg0; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } u32 sub_815AB04(u32 arg0, u8 *arg1) @@ -223,7 +223,7 @@ void sub_815AB3C(u32 arg0) struct UnkPacket4 packet; packet.id = 4; packet.unk4 = arg0; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } u32 sub_815AB60(u32 arg0) diff --git a/src/graphics.c b/src/graphics.c index 04a6f6206..03986a03f 100644 --- a/src/graphics.c +++ b/src/graphics.c @@ -1414,7 +1414,7 @@ const u32 gTradeGba_Gfx[] = INCBIN_U32("graphics/link/gba.4bpp"); const u16 gUnknown_8EAFE80[] = INCBIN_U16("graphics/interface/blank2.gbapal"); -const u16 gUnknown_8EAFEA0[] = INCBIN_U16("graphics/berry_crush/berry_crush.gbapal"); +const u16 gBerryCrush_Crusher_Pal[] = INCBIN_U16("graphics/berry_crush/berry_crush.gbapal"); const u16 gUnknown_8EAFF60[] = INCBIN_U16("graphics/unknown/unknown_EAFF60.gbapal"); -const u32 gUnknown_8EAFFC0[] = INCBIN_U32("graphics/berry_crush/berry_crush.4bpp.lz"); -const u32 gUnknown_8EB0ADC[] = INCBIN_U32("graphics/berry_crush/data_EB0ADC.bin.lz"); +const u32 gBerryCrush_Crusher_Gfx[] = INCBIN_U32("graphics/berry_crush/berry_crush.4bpp.lz"); +const u32 gBerryCrush_Crusher_Tilemap[] = INCBIN_U32("graphics/berry_crush/data_EB0ADC.bin.lz"); diff --git a/src/hall_of_fame.c b/src/hall_of_fame.c index e6f8b72ec..d2c7555e2 100644 --- a/src/hall_of_fame.c +++ b/src/hall_of_fame.c @@ -1198,7 +1198,7 @@ static bool8 DrawHofBackground(void) break; case 3: InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); break; case 4: SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_1D_MAP | DISPCNT_OBJ_ON); diff --git a/src/item.c b/src/item.c index 801c7d689..0df45cbd3 100644 --- a/src/item.c +++ b/src/item.c @@ -139,7 +139,7 @@ bool8 CheckBagHasItem(u16 itemId, u16 count) return FALSE; } -bool8 CheckHasAtLeastOneBerry(void) +bool8 HasAtLeastOneBerry(void) { u8 itemId; bool8 exists; diff --git a/src/link.c b/src/link.c index 2a242dde9..d3c0cccec 100644 --- a/src/link.c +++ b/src/link.c @@ -1381,7 +1381,7 @@ void SetLinkStandbyCallback(void) { if (gWirelessCommType == 1) { - LinkRfu_SetRfuFuncToSend6600(); + Rfu_SetLinkStandbyCallback(); } else { diff --git a/src/link_rfu_2.c b/src/link_rfu_2.c index cf23098d7..46715488e 100644 --- a/src/link_rfu_2.c +++ b/src/link_rfu_2.c @@ -894,7 +894,7 @@ static void HandleSendFailure(u8 unused, u32 flags) { if (!(flags & 1)) { - sResendBlock16[0] = RFU_COMMAND_0x8900 | i; + sResendBlock16[0] = RFUCMD_0x8900 | i; for (j = 0; j < 7; j++) { sResendBlock16[j + 1] = (r10[12 * i + (j << 1) + 1] << 8) | r10[12 * i + (j << 1) + 0]; @@ -949,7 +949,7 @@ static void RfuFunc_SendKeysToRfu(void) { gUnknown_3001188++; gHeldKeyCodeToSend |= (gUnknown_3001188 << 8); - RfuPrepareSendBuffer(RFU_COMMAND_0xbe00); + RfuPrepareSendBuffer(RFUCMD_SEND_HELD_KEYS); } } @@ -983,18 +983,18 @@ static void RfuHandleReceiveCommand(u8 unused) { switch (gRecvCmds[i][0] & 0xff00) { - case RFU_COMMAND_0x7800: + case RFUCMD_0x7800: if (Rfu.parent_child == MODE_CHILD && gReceivedRemoteLinkPlayers) return; // fallthrough - case RFU_COMMAND_0x7700: + case RFUCMD_0x7700: if (gRfuLinkStatus->parentChild == MODE_CHILD) { Rfu.playerCount = gRecvCmds[i][1]; Rfu.unk_cce = sub_80F9770((u8 *)(gRecvCmds[i] + 2)); } break; - case RFU_COMMAND_0x8800: + case RFUCMD_0x8800: if (Rfu.cmd_8800_recvbuf[i].receiving == 0) { Rfu.cmd_8800_recvbuf[i].next = 0; @@ -1005,7 +1005,7 @@ static void RfuHandleReceiveCommand(u8 unused) Rfu.unk_5c[i] = 0; } break; - case RFU_COMMAND_0x8900: + case RFUCMD_0x8900: if (Rfu.cmd_8800_recvbuf[i].receiving == 1) { Rfu.cmd_8800_recvbuf[i].next = gRecvCmds[i][0] & 0xff; @@ -1021,17 +1021,17 @@ static void RfuHandleReceiveCommand(u8 unused) } } break; - case RFU_COMMAND_0xa100: + case RFUCMD_SEND_BLOCK_REQ: Rfu_InitBlockSend(gUnknown_843EC64[gRecvCmds[i][1]].buffer, (u16)gUnknown_843EC64[gRecvCmds[i][1]].size); break; - case RFU_COMMAND_0x5f00: + case RFUCMD_READY_CLOSE_LINK: Rfu.cmd5f00Ack[i] = 1; break; - case RFU_COMMAND_0x6600: + case RFUCMD_READY_EXIT_STANDBY: if (Rfu.cmd_6600_count == gRecvCmds[i][1]) Rfu.cmd_6600_recvd[i] = 1; break; - case RFU_COMMAND_0xed00: + case RFUCMD_0xEE00: if (Rfu.parent_child == MODE_CHILD) { if (gReceivedRemoteLinkPlayers) @@ -1048,13 +1048,13 @@ static void RfuHandleReceiveCommand(u8 unused) } else { - RfuPrepareSendBuffer(RFU_COMMAND_0xee00); + RfuPrepareSendBuffer(RFUCMD_0xED00); gSendCmd[1] = gRecvCmds[i][1]; gSendCmd[2] = gRecvCmds[i][2]; gSendCmd[3] = gRecvCmds[i][3]; } break; - case RFU_COMMAND_0xee00: + case RFUCMD_0xED00: if (Rfu.parent_child == MODE_PARENT) { Rfu.bm_DisconnectSlot |= gRecvCmds[i][1]; @@ -1062,7 +1062,7 @@ static void RfuHandleReceiveCommand(u8 unused) sub_80FA9D0(gRecvCmds[i][1]); } break; - case RFU_COMMAND_0xbe00: + case RFUCMD_SEND_HELD_KEYS: gLinkPartnersHeldKeys[i] = gRecvCmds[i][1]; break; } @@ -1138,16 +1138,16 @@ static void RfuPrepareSendBuffer(u16 command) gSendCmd[0] = command; switch (command) { - case RFU_COMMAND_0x8800: + case RFUCMD_0x8800: gSendCmd[1] = Rfu.cmd_8800_sendbuf.count; gSendCmd[2] = Rfu.cmd_8800_sendbuf.owner + 0x80; break; - case RFU_COMMAND_0xa100: + case RFUCMD_SEND_BLOCK_REQ: if (Cmd8000recvIsFinished()) gSendCmd[1] = Rfu.cmdA100_blockRequestType; break; - case RFU_COMMAND_0x7700: - case RFU_COMMAND_0x7800: + case RFUCMD_0x7700: + case RFUCMD_0x7800: tmp = Rfu.bm_PartnerFlags ^ Rfu.bm_DisconnectSlot; Rfu.playerCount = gUnknown_843EC41[tmp] + 1; gSendCmd[1] = Rfu.playerCount; @@ -1155,30 +1155,30 @@ static void RfuPrepareSendBuffer(u16 command) for (i = 0; i < RFU_CHILD_MAX; i++) buff[i] = Rfu.linkPlayerIdx[i]; break; - case RFU_COMMAND_0x6600: - case RFU_COMMAND_0x5f00: + case RFUCMD_READY_EXIT_STANDBY: + case RFUCMD_READY_CLOSE_LINK: gSendCmd[1] = Rfu.cmd_6600_count; break; - case RFU_COMMAND_0x2f00: + case RFUCMD_SEND_PACKET: for (i = 0; i < 6; i++) gSendCmd[1 + i] = Rfu.unk_f2[i]; break; - case RFU_COMMAND_0xbe00: + case RFUCMD_SEND_HELD_KEYS: gSendCmd[1] = gHeldKeyCodeToSend; break; - case RFU_COMMAND_0xee00: + case RFUCMD_0xED00: break; - case RFU_COMMAND_0xed00: + case RFUCMD_0xEE00: break; } } -void RfuPrepareSend0x2f00(void * data) +void Rfu_SendPacket(void * data) { if (gSendCmd[0] == 0 && !RfuIsErrorStatus1or2()) { memcpy(Rfu.unk_f2, data, sizeof(Rfu.unk_f2)); - RfuPrepareSendBuffer(RFU_COMMAND_0x2f00); + RfuPrepareSendBuffer(RFUCMD_SEND_PACKET); } } @@ -1208,7 +1208,7 @@ bool32 Rfu_InitBlockSend(const u8 *src, size_t size) memcpy(gBlockSendBuffer, src, size); Rfu.cmd_8800_sendbuf.payload = gBlockSendBuffer; } - RfuPrepareSendBuffer(RFU_COMMAND_0x8800); + RfuPrepareSendBuffer(RFUCMD_0x8800); Rfu.RfuFunc = RfuFunc_HandleBlockSend; Rfu.unk_5b = 0; return TRUE; @@ -1218,7 +1218,7 @@ static void RfuFunc_HandleBlockSend(void) { if (gSendCmd[0] == 0) { - RfuPrepareSendBuffer(RFU_COMMAND_0x8800); + RfuPrepareSendBuffer(RFUCMD_0x8800); if (Rfu.parent_child == MODE_PARENT) { if (++Rfu.unk_5b > 2) @@ -1226,7 +1226,7 @@ static void RfuFunc_HandleBlockSend(void) } else { - if ((gRecvCmds[GetMultiplayerId()][0] & 0xff00) == RFU_COMMAND_0x8800) + if ((gRecvCmds[GetMultiplayerId()][0] & 0xff00) == RFUCMD_0x8800) Rfu.RfuFunc = RfuFunc_SendNextBlock; } } @@ -1235,7 +1235,7 @@ static void RfuFunc_SendNextBlock(void) { s32 i; const u8 *src = Rfu.cmd_8800_sendbuf.payload; - gSendCmd[0] = RFU_COMMAND_0x8900 | Rfu.cmd_8800_sendbuf.next; + gSendCmd[0] = RFUCMD_0x8900 | Rfu.cmd_8800_sendbuf.next; for (i = 0; i < 7; i++) gSendCmd[i + 1] = (src[(i << 1) + Rfu.cmd_8800_sendbuf.next * 12 + 1] << 8) | src[(i << 1) + Rfu.cmd_8800_sendbuf.next * 12 + 0]; Rfu.cmd_8800_sendbuf.next++; @@ -1253,7 +1253,7 @@ static void RfuFunc_SendLastBlock(void) s32 i; if (Rfu.parent_child == MODE_CHILD) { - gSendCmd[0] = RFU_COMMAND_0x8900 | (Rfu.cmd_8800_sendbuf.count - 1); + gSendCmd[0] = RFUCMD_0x8900 | (Rfu.cmd_8800_sendbuf.count - 1); for (i = 0; i < 7; i++) gSendCmd[i + 1] = (src[(i << 1) + (Rfu.cmd_8800_sendbuf.count - 1) * 12 + 1] << 8) | src[(i << 1) + (Rfu.cmd_8800_sendbuf.count - 1) * 12 + 0]; if ((u8)gRecvCmds[mpId][0] == Rfu.cmd_8800_sendbuf.count - 1) @@ -1274,7 +1274,7 @@ static void RfuFunc_SendLastBlock(void) bool8 LinkRfu_PrepareCmd0xA100(u8 blockRequestType) { Rfu.cmdA100_blockRequestType = blockRequestType; - RfuPrepareSendBuffer(RFU_COMMAND_0xa100); + RfuPrepareSendBuffer(RFUCMD_SEND_BLOCK_REQ); return TRUE; } @@ -1340,7 +1340,7 @@ static void RfuFunc_BuildCommand5F00(void) { if (gSendCmd[0] == 0 && !Rfu.unk_ce8) { - RfuPrepareSendBuffer(RFU_COMMAND_0x5f00); + RfuPrepareSendBuffer(RFUCMD_READY_CLOSE_LINK); Rfu.RfuFunc = RfuFunc_WaitAck5F00; } } @@ -1370,7 +1370,7 @@ static void RfuFunc_Send6600_3(void) { if (Rfu.unk_124.count == 0 && Rfu.cmd_6600_timer > 60) { - RfuPrepareSendBuffer(RFU_COMMAND_0x6600); + RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); Rfu.cmd_6600_timer = 0; } } @@ -1394,7 +1394,7 @@ static void RfuFunc_Send6600_2(void) { if (Rfu.unk_124.count == 0 && gSendCmd[0] == 0) { - RfuPrepareSendBuffer(RFU_COMMAND_0x6600); + RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); Rfu.RfuFunc = RfuFunc_Send6600_3; } } @@ -1408,7 +1408,7 @@ static void RfuFunc_Send6600_1(void) { if (Rfu.unk_124.count == 0 && gSendCmd[0] == 0) { - RfuPrepareSendBuffer(RFU_COMMAND_0x6600); + RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); Rfu.RfuFunc = RfuFunc_Send6600_3; } } @@ -1424,14 +1424,14 @@ static void RfuFunc_Send6600_1(void) { if (Rfu.unk_124.count == 0 && gSendCmd[0] == 0) { - RfuPrepareSendBuffer(RFU_COMMAND_0x6600); + RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); Rfu.RfuFunc = RfuFunc_Send6600_2; } } } } -void LinkRfu_SetRfuFuncToSend6600(void) +void Rfu_SetLinkStandbyCallback(void) { if (Rfu.RfuFunc == NULL) { @@ -1638,9 +1638,9 @@ static void sub_80FA834(u8 taskId) if (Rfu.parent_child == MODE_PARENT) { if (gReceivedRemoteLinkPlayers) - RfuPrepareSendBuffer(RFU_COMMAND_0x7800); + RfuPrepareSendBuffer(RFUCMD_0x7800); else - RfuPrepareSendBuffer(RFU_COMMAND_0x7700); + RfuPrepareSendBuffer(RFUCMD_0x7700); gTasks[taskId].data[0] = 101; } else @@ -1660,7 +1660,7 @@ static void sub_80FA834(u8 taskId) if (Cmd8000recvIsFinished()) { Rfu.cmdA100_blockRequestType = 0; - RfuPrepareSendBuffer(RFU_COMMAND_0xa100); + RfuPrepareSendBuffer(RFUCMD_SEND_BLOCK_REQ); gTasks[taskId].data[0]++; } } @@ -1750,7 +1750,7 @@ static void Task_ExchangeLinkPlayers(u8 taskId) if (gSendCmd[0] == 0) { ResetBlockReceivedFlag(r4); - RfuPrepareSendBuffer(RFU_COMMAND_0x7800); + RfuPrepareSendBuffer(RFUCMD_0x7800); gTasks[taskId].data[0]++; } break; @@ -2393,7 +2393,7 @@ void RFUVSync(void) rfu_LMAN_syncVBlank(); } -void sub_80FBA44(void) +void ClearRecvCommands(void) { CpuFill32(0, gRecvCmds, sizeof(gRecvCmds)); } @@ -2561,7 +2561,7 @@ static void sub_80FBDB8(u8 taskId) { if (gSendCmd[0] == 0 && !Rfu.unk_ce8) { - RfuPrepareSendBuffer(RFU_COMMAND_0xed00); + RfuPrepareSendBuffer(RFUCMD_0xEE00); gSendCmd[1] = gTasks[taskId].data[0]; gSendCmd[2] = gTasks[taskId].data[1]; Rfu.playerCount -= gUnknown_843EC41[gTasks[taskId].data[0]]; diff --git a/src/math_util.c b/src/math_util.c index f77c82608..d4e2f3f56 100644 --- a/src/math_util.c +++ b/src/math_util.c @@ -1,6 +1,6 @@ #include "global.h" -s16 MathUtil_Mul16(s16 x, s16 y) +s16 mulfx16(s16 x, s16 y) { s32 result; @@ -10,7 +10,7 @@ s16 MathUtil_Mul16(s16 x, s16 y) return result; } -s16 MathUtil_Mul16Shift(u8 s, s16 x, s16 y) +s16 mulfxn16(u8 s, s16 x, s16 y) { s32 result; @@ -20,7 +20,7 @@ s16 MathUtil_Mul16Shift(u8 s, s16 x, s16 y) return result; } -s32 MathUtil_Mul32(s32 x, s32 y) +s32 mulfx32(s32 x, s32 y) { s64 result; @@ -30,7 +30,7 @@ s32 MathUtil_Mul32(s32 x, s32 y) return result; } -s16 MathUtil_Div16(s16 x, s16 y) +s16 divfx16(s16 x, s16 y) { if (y == 0) { @@ -39,7 +39,7 @@ s16 MathUtil_Div16(s16 x, s16 y) return (x << 8) / y; } -s16 MathUtil_Div16Shift(u8 s, s16 x, s16 y) +s16 divfxn16(u8 s, s16 x, s16 y) { if (y == 0) { @@ -48,7 +48,7 @@ s16 MathUtil_Div16Shift(u8 s, s16 x, s16 y) return (x << s) / y; } -s32 MathUtil_Div32(s32 x, s32 y) +s32 divfx32(s32 x, s32 y) { s64 _x; @@ -61,7 +61,7 @@ s32 MathUtil_Div32(s32 x, s32 y) return _x / y; } -s16 MathUtil_Inv16(s16 y) +s16 invfx16(s16 y) { s32 x; @@ -69,7 +69,7 @@ s16 MathUtil_Inv16(s16 y) return x / y; } -s16 MathUtil_Inv16Shift(u8 s, s16 y) +s16 invfxn16(u8 s, s16 y) { s32 x; @@ -77,7 +77,7 @@ s16 MathUtil_Inv16Shift(u8 s, s16 y) return x / y; } -s32 MathUtil_Inv32(s32 y) +s32 invfx32(s32 y) { s64 x; diff --git a/src/naming_screen.c b/src/naming_screen.c index 2f40cf2aa..f239620cf 100644 --- a/src/naming_screen.c +++ b/src/naming_screen.c @@ -496,7 +496,7 @@ static void NamingScreen_InitBGs(void) ChangeBgY(3, 0, 0); InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); for (i = 0; i < NELEMS(gUnknown_83E22A0) - 1; i++) sNamingScreenData->windows[i] = AddWindow(&gUnknown_83E22A0[i]); diff --git a/src/new_menu_helpers.c b/src/new_menu_helpers.c index 556d83a69..2d7e8c4b4 100644 --- a/src/new_menu_helpers.c +++ b/src/new_menu_helpers.c @@ -388,7 +388,7 @@ void FreeAllOverworldWindowBuffers(void) FreeAllWindowBuffers(); } -void ResetBg0(void) +void InitTextBoxGfxAndPrinters(void) { ChangeBgX(0, 0, 0); ChangeBgY(0, 0, 0); diff --git a/src/oak_speech.c b/src/oak_speech.c index 96ba0adee..63cb35806 100644 --- a/src/oak_speech.c +++ b/src/oak_speech.c @@ -534,7 +534,7 @@ static void Task_OaksSpeech1(u8 taskId) case 4: gPaletteFade.bufferTransferDisabled = TRUE; InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); Menu_LoadStdPalAt(0xD0); LoadPalette(sHelpDocsPalette, 0x000, 0x080); LoadPalette(stdpal_get(2) + 15, 0x000, 0x002); @@ -1418,8 +1418,8 @@ static void Task_OakSpeech39(u8 taskId) PlaySE(SE_WARP_IN); r0 = data[2]; data[2] -= 32; - x = MathUtil_Inv16(r0 - 8); - y = MathUtil_Inv16(data[2] - 16); + x = invfx16(r0 - 8); + y = invfx16(data[2] - 16); SetBgAffine(2, 0x7800, 0x5400, 0x78, 0x54, x, y, 0); if (data[2] <= 96) { @@ -1566,7 +1566,7 @@ static void CB2_ReturnFromNamingScreen(void) case 3: FreeAllWindowBuffers(); InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); LoadPalette(sHelpDocsPalette, 0, 0xe0); break; case 4: diff --git a/src/overworld.c b/src/overworld.c index 2083b7578..47b629817 100644 --- a/src/overworld.c +++ b/src/overworld.c @@ -1345,7 +1345,7 @@ static void InitOverworldBgs(void) SetBgTilemapBuffer(2, gBGTilemapBuffers1); SetBgTilemapBuffer(3, gBGTilemapBuffers3); InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); sub_8069348(); } @@ -1363,7 +1363,7 @@ static void InitOverworldBgs_NoResetHeap(void) SetBgTilemapBuffer(2, gBGTilemapBuffers1); SetBgTilemapBuffer(3, gBGTilemapBuffers3); InitStandardTextBoxWindows(); - ResetBg0(); + InitTextBoxGfxAndPrinters(); sub_8069348(); } diff --git a/src/pokemon_jump.c b/src/pokemon_jump.c index 853ec4f26..45634ad9c 100644 --- a/src/pokemon_jump.c +++ b/src/pokemon_jump.c @@ -244,7 +244,7 @@ static void sub_8147A34(u8 taskId) memset(packet, 0, sizeof(packet)); packet[0] = 0x7FFF; packet[1] = data[12]; - RfuPrepareSend0x2f00(packet); + Rfu_SendPacket(packet); } } else diff --git a/src/pokemon_jump_2.c b/src/pokemon_jump_2.c index a219459c1..2fe066da1 100644 --- a/src/pokemon_jump_2.c +++ b/src/pokemon_jump_2.c @@ -1002,12 +1002,12 @@ static bool32 sub_814881C(void) case 2: if (sub_8149804()) { - CreateTask(Task_SaveGame_UpdatedLinkRecords, 6); + CreateTask(Task_LinkSave, 6); gUnknown_203F3D4->unk8++; } break; case 3: - if (!FuncIsActiveTask(Task_SaveGame_UpdatedLinkRecords)) + if (!FuncIsActiveTask(Task_LinkSave)) { sub_814A6CC(); gUnknown_203F3D4->unk8++; diff --git a/src/pokemon_jump_3.c b/src/pokemon_jump_3.c index 04d9ad439..978c4ab71 100644 --- a/src/pokemon_jump_3.c +++ b/src/pokemon_jump_3.c @@ -17,7 +17,7 @@ void sub_8149A6C(struct PokemonJump1_MonInfo *arg0) packet.species = arg0->species; packet.otId = arg0->otId; packet.personality = arg0->personality; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } bool32 sub_8149A90(int multiplayerId, struct PokemonJump1_MonInfo *arg0) @@ -51,7 +51,7 @@ void sub_8149AE0(u32 arg0) struct UnkPacket2 packet; packet.id = 2; packet.unk4 = arg0; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } struct UnkPacket3 @@ -79,7 +79,7 @@ void sub_8149AF8(struct PokemonJump1_82E4 *arg0, struct PokemonJump1Sub *arg1) packet.unk2 = arg0->unk10; packet.unk3_1 = arg0->unk14; packet.unk4 = arg0->unkE; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } bool32 sub_8149B7C(struct PokemonJump1_82E4 *arg0, struct PokemonJump1Sub *arg1) @@ -125,7 +125,7 @@ void sub_8149BF4(struct PokemonJump1_82E4 *arg0, u8 arg1, u16 arg2) packet.unk4 = arg0->unkE; packet.unk6 = arg1; packet.unk8 = arg2; - RfuPrepareSend0x2f00(&packet); + Rfu_SendPacket(&packet); } bool32 sub_8149C24(struct PokemonJump1_82E4 *arg0, int multiplayerId, u8 *arg2, u16 *arg3) diff --git a/src/pokemon_jump_4.c b/src/pokemon_jump_4.c index b197ebeef..4725e3fc2 100644 --- a/src/pokemon_jump_4.c +++ b/src/pokemon_jump_4.c @@ -55,7 +55,7 @@ void sub_8149CEC(struct PokemonJump2 *arg0) void sub_8149D24(void) { FreeAllWindowBuffers(); - DigitObjUtil_Teardown(); + DigitObjUtil_Free(); } static void sub_8149D34(struct PokemonJump2 *arg0) diff --git a/src/save.c b/src/save.c index 353ad5cb2..3ce4025bf 100644 --- a/src/save.c +++ b/src/save.c @@ -844,7 +844,7 @@ u32 TryWriteSpecialSaveSection(u8 sector, u8* src) return 1; } -void Task_SaveGame_UpdatedLinkRecords(u8 taskId) +void Task_LinkSave(u8 taskId) { switch (gTasks[taskId].data[0]) { diff --git a/src/start_menu.c b/src/start_menu.c index 6280ba7b4..4f901c25d 100644 --- a/src/start_menu.c +++ b/src/start_menu.c @@ -941,11 +941,11 @@ static void task50_after_link_battle_save(u8 taskId) DestroyTask(taskId); break; case 5: - CreateTask(Task_SaveGame_UpdatedLinkRecords, 5); + CreateTask(Task_LinkSave, 5); data[0] = 6; break; case 6: - if (!FuncIsActiveTask(Task_SaveGame_UpdatedLinkRecords)) + if (!FuncIsActiveTask(Task_LinkSave)) data[0] = 3; break; } diff --git a/src/union_room.c b/src/union_room.c index f19eba38d..876e11e19 100644 --- a/src/union_room.c +++ b/src/union_room.c @@ -2898,7 +2898,7 @@ static void Task_RunUnionRoom(u8 taskId) if (var5 == -2 || var5 == IN_UNION_ROOM) { data->playerSendBuffer[0] = IN_UNION_ROOM; - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); StringCopy(gStringVar4, gUnknown_845842C[gLinkPlayers[0].gender]); data->state = 32; } @@ -2913,7 +2913,7 @@ static void Task_RunUnionRoom(u8 taskId) else { data->playerSendBuffer[0] = sPlayerCurrActivity | IN_UNION_ROOM; - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); data->state = 27; } } @@ -2942,7 +2942,7 @@ static void Task_RunUnionRoom(u8 taskId) data->playerSendBuffer[0] = ACTIVITY_TRADE | IN_UNION_ROOM; data->playerSendBuffer[1] = sUnionRoomTrade.species; data->playerSendBuffer[2] = sUnionRoomTrade.level; - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); data->state = 29; break; case 29: @@ -3130,32 +3130,32 @@ static void Task_RunUnionRoom(u8 taskId) if (!HasAtLeastTwoMonsOfLevel30OrLower()) { data->playerSendBuffer[0] = ACTIVITY_DECLINE | IN_UNION_ROOM; - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); data->state = 10; StringCopy(gStringVar4, gUnknown_84584C0); } else { - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); data->state = 13; } } else if (sPlayerCurrActivity == (ACTIVITY_CARD | IN_UNION_ROOM)) { - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); ViewURoomPartnerTrainerCard(gStringVar4, data, MODE_PARENT); data->state = 40; } else { - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); data->state = 13; } break; case 1: case -1: data->playerSendBuffer[0] = ACTIVITY_DECLINE | IN_UNION_ROOM; - RfuPrepareSend0x2f00(data->playerSendBuffer); + Rfu_SendPacket(data->playerSendBuffer); data->state = 10; GetYouDeclinedTheOfferMessage(gStringVar4, sPlayerCurrActivity); break; @@ -3418,7 +3418,7 @@ void var_800D_set_xB(void) static void ReceiveUnionRoomActivityPacket(struct UnkStruct_URoom * uroom) { - if (gRecvCmds[1][1] != 0 && (gRecvCmds[1][0] & 0xFF00) == RFU_COMMAND_0x2f00) + if (gRecvCmds[1][1] != 0 && (gRecvCmds[1][0] & 0xFF00) == RFUCMD_SEND_PACKET) { uroom->recvActivityRequest[0] = gRecvCmds[1][1]; if (gRecvCmds[1][1] == (ACTIVITY_TRADE | IN_UNION_ROOM)) From 27d4411de0511a7dd342cebf7b05d01bfdec66b0 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Wed, 5 May 2021 13:07:22 -0400 Subject: [PATCH 02/21] Fix accidental label swap in link_rfu.h --- include/link_rfu.h | 4 ++-- src/link_rfu_2.c | 12 ++++++------ 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/include/link_rfu.h b/include/link_rfu.h index 80bad0a21..7d40776f3 100644 --- a/include/link_rfu.h +++ b/include/link_rfu.h @@ -14,8 +14,8 @@ #define RFUCMD_0x8900 0x8900 #define RFUCMD_SEND_BLOCK_REQ 0xa100 #define RFUCMD_SEND_HELD_KEYS 0xbe00 -#define RFUCMD_0xED00 0xee00 -#define RFUCMD_0xEE00 0xed00 +#define RFUCMD_0xED00 0xed00 +#define RFUCMD_0xEE00 0xee00 // RfuTgtData.gname is read as these structs. struct GFtgtGnameSub diff --git a/src/link_rfu_2.c b/src/link_rfu_2.c index 46715488e..8c7447264 100644 --- a/src/link_rfu_2.c +++ b/src/link_rfu_2.c @@ -1031,7 +1031,7 @@ static void RfuHandleReceiveCommand(u8 unused) if (Rfu.cmd_6600_count == gRecvCmds[i][1]) Rfu.cmd_6600_recvd[i] = 1; break; - case RFUCMD_0xEE00: + case RFUCMD_0xED00: if (Rfu.parent_child == MODE_CHILD) { if (gReceivedRemoteLinkPlayers) @@ -1048,13 +1048,13 @@ static void RfuHandleReceiveCommand(u8 unused) } else { - RfuPrepareSendBuffer(RFUCMD_0xED00); + RfuPrepareSendBuffer(RFUCMD_0xEE00); gSendCmd[1] = gRecvCmds[i][1]; gSendCmd[2] = gRecvCmds[i][2]; gSendCmd[3] = gRecvCmds[i][3]; } break; - case RFUCMD_0xED00: + case RFUCMD_0xEE00: if (Rfu.parent_child == MODE_PARENT) { Rfu.bm_DisconnectSlot |= gRecvCmds[i][1]; @@ -1166,10 +1166,10 @@ static void RfuPrepareSendBuffer(u16 command) case RFUCMD_SEND_HELD_KEYS: gSendCmd[1] = gHeldKeyCodeToSend; break; - case RFUCMD_0xED00: - break; case RFUCMD_0xEE00: break; + case RFUCMD_0xED00: + break; } } @@ -2561,7 +2561,7 @@ static void sub_80FBDB8(u8 taskId) { if (gSendCmd[0] == 0 && !Rfu.unk_ce8) { - RfuPrepareSendBuffer(RFUCMD_0xEE00); + RfuPrepareSendBuffer(RFUCMD_0xED00); gSendCmd[1] = gTasks[taskId].data[0]; gSendCmd[2] = gTasks[taskId].data[1]; Rfu.playerCount -= gUnknown_843EC41[gTasks[taskId].data[0]]; From c8e0d60897a8e9ecb0e6997e5d61e331860c525f Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Wed, 5 May 2021 13:37:37 -0400 Subject: [PATCH 03/21] Name args for berry crush commands --- src/berry_crush.c | 80 +++++++++++++++++++++++++++++------------------ 1 file changed, 49 insertions(+), 31 deletions(-) diff --git a/src/berry_crush.c b/src/berry_crush.c index 4b34b054d..9f1dc208f 100644 --- a/src/berry_crush.c +++ b/src/berry_crush.c @@ -93,6 +93,24 @@ enum { CMD_CLOSE_LINK, CMD_QUIT, }; + +// Args for Cmd_BeginNormalPaletteFade +#define bSelectedPals(i) args[0 + i] +#define bDelay args[4] +#define bStartY args[5] +#define bTargetY args[6] +#define bPalette(i) args[7 + i] +#define bCommunicateAfter args[9] + +// Args for Cmd_WaitPaletteFade +#define bWaitFadeCommAfter args[0] + +// Args for Cmd_PrintMessage +#define bMsgId args[0] +#define bFlags args[1] +#define bKeys(i) args[2 + i] +#define bNextCmdState args[4] + #define F_MSG_CLEAR (1 << 0) #define F_MSG_EXPAND (1 << 1) @@ -1181,28 +1199,28 @@ static u32 Cmd_BeginNormalPaletteFade(struct BerryCrushGame * game, u8 *args) u16 color; u32 selectedPals[2]; - selectedPals[0] = (u32)args[0]; + selectedPals[0] = (u32)bSelectedPals(0); - selectedPals[1] = (u32)args[1]; + selectedPals[1] = (u32)bSelectedPals(1); selectedPals[1] <<= 8; selectedPals[0] |= selectedPals[1]; - selectedPals[1] = (u32)args[2]; + selectedPals[1] = (u32)bSelectedPals(2); selectedPals[1] <<= 16; selectedPals[0] |= selectedPals[1]; - selectedPals[1] = (u32)args[3]; + selectedPals[1] = (u32)bSelectedPals(3); selectedPals[1] <<= 24; selectedPals[0] |= selectedPals[1]; - args[0] = args[9]; + bWaitFadeCommAfter = bCommunicateAfter; - color = args[8]; + color = bPalette(1); color <<= 8; - color |= args[7]; + color |= bPalette(0); gPaletteFade.bufferTransferDisabled = FALSE; - BeginNormalPaletteFade(selectedPals[0], args[4], args[5], args[6], color); + BeginNormalPaletteFade(selectedPals[0], bDelay, bStartY, bTargetY, color); UpdatePaletteFade(); game->nextCmd = CMD_WAIT_FADE; return 0; @@ -1215,7 +1233,7 @@ static u32 Cmd_WaitPaletteFade(struct BerryCrushGame * game, u8 *args) case 0: if (UpdatePaletteFade()) return 0; - if(args[0] != 0) + if (bWaitFadeCommAfter) ++game->cmdState; else game->cmdState = 3; @@ -1251,22 +1269,22 @@ static u32 Cmd_PrintMessage(struct BerryCrushGame * game, u8 *args) u16 keys; - keys = args[3]; + keys = bKeys(1); keys <<= 8; - keys |= args[2] << 0; + keys |= bKeys(0) << 0; switch (game->cmdState) { case 0: DrawDialogueFrame(0, FALSE); - if (args[1] & F_MSG_EXPAND) + if (bFlags & F_MSG_EXPAND) { - StringExpandPlaceholders(gStringVar4, sMessages[args[0]]); + StringExpandPlaceholders(gStringVar4, sMessages[bMsgId]); AddTextPrinterParameterized2(0, 2, gStringVar4, game->textSpeed, 0, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); } else { - AddTextPrinterParameterized2(0, 2, sMessages[args[0]], game->textSpeed, NULL, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); + AddTextPrinterParameterized2(0, 2, sMessages[bMsgId], game->textSpeed, NULL, TEXT_COLOR_DARK_GRAY, TEXT_COLOR_WHITE, TEXT_COLOR_LIGHT_GRAY); } CopyWindowToVram(0, COPYWIN_BOTH); break; @@ -1283,10 +1301,10 @@ static u32 Cmd_PrintMessage(struct BerryCrushGame * game, u8 *args) return 0; break; case 3: - if (args[1] & F_MSG_CLEAR) + if (bFlags & F_MSG_CLEAR) ClearDialogWindowAndFrame(0, TRUE); RunOrScheduleCommand(game->nextCmd, SCHEDULE_CMD, NULL); - game->cmdState = args[4]; + game->cmdState = bNextCmdState; return 0; } ++game->cmdState; @@ -2458,25 +2476,25 @@ static void ResetGame(struct BerryCrushGame * game) static void SetPaletteFadeArgs(u8 *args, bool8 communicateAfter, u32 selectedPals, s8 delay, u8 startY, u8 targetY, u16 palette) { - args[0] = ((u8 *)&selectedPals)[0]; - args[1] = ((u8 *)&selectedPals)[1]; - args[2] = ((u8 *)&selectedPals)[2]; - args[3] = ((u8 *)&selectedPals)[3]; - args[4] = delay; - args[5] = startY; - args[6] = targetY; - args[7] = ((u8 *)&palette)[0]; - args[8] = ((u8 *)&palette)[1]; - args[9] = communicateAfter; + bSelectedPals(0) = ((u8 *)&selectedPals)[0]; + bSelectedPals(1) = ((u8 *)&selectedPals)[1]; + bSelectedPals(2) = ((u8 *)&selectedPals)[2]; + bSelectedPals(3) = ((u8 *)&selectedPals)[3]; + bDelay = delay; + bStartY = startY; + bTargetY = targetY; + bPalette(0) = ((u8 *)&palette)[0]; + bPalette(1) = ((u8 *)&palette)[1]; + bCommunicateAfter = communicateAfter; } static void SetPrintMessageArgs(u8 *args, u8 stringId, u8 flags, u16 waitKeys, u8 followupCmd) { - args[0] = stringId; - args[1] = flags; - args[2] = ((u8 *)&waitKeys)[0]; - args[3] = ((u8 *)&waitKeys)[1]; - args[4] = followupCmd; + bMsgId = stringId; + bFlags = flags; + bKeys(0) = ((u8 *)&waitKeys)[0]; + bKeys(1) = ((u8 *)&waitKeys)[1]; + bNextCmdState = followupCmd; } // GF file break From da67ad94b6918e110aa737e0dd80ac2f76a40746 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 6 May 2021 09:20:03 -0400 Subject: [PATCH 04/21] Fix typo and sync bool-typed fields --- src/berry_crush.c | 44 ++++++++++++++++---------------------------- 1 file changed, 16 insertions(+), 28 deletions(-) diff --git a/src/berry_crush.c b/src/berry_crush.c index 9f1dc208f..320e9c131 100644 --- a/src/berry_crush.c +++ b/src/berry_crush.c @@ -209,9 +209,9 @@ struct BerryCrushGame_Player struct BerryCrushGame_LocalState { u16 sendFlag; - u8 endGame:1; - u8 bigSparkle:1; - u8 pushedAButton:1; + bool8 endGame:1; + bool8 bigSparkle:1; + bool8 pushedAButton:1; u8 playerPressedAFlags:5; s8 vibration; u16 depth; @@ -224,9 +224,9 @@ struct BerryCrushGame_LinkState { u16 rfuCmd; u16 sendFlag; - u8 endGame:1; - u8 bigSparkle:1; - u8 pushedAButton:1; + bool8 endGame:1; + bool8 bigSparkle:1; + bool8 pushedAButton:1; u8 playerPressedAFlags:5; s8 vibration; u16 depth; @@ -235,18 +235,6 @@ struct BerryCrushGame_LinkState u16 sparkleAmount; }; -struct BerryCrushGame_40 -{ - s16 unk0; - s16 unk2; - s16 unk4; - s16 unk6; - s16 unk8; - s16 unkA; - s16 unkC; - s16 unkE; -}; - // Flags for the inputFlags field // Field is 16 bits; 3 bits for each player, last bit is unused // The first two bits are interchangeable @@ -331,11 +319,11 @@ struct BerryCrushGame s32 powder; s32 targetDepth; u8 newDepth; - u8 noRoomForPowder:1; // Never read - u8 newRecord:1; - u8 playedSound:1; - u8 endGame:1; - u8 bigSparkle:1; + bool8 noRoomForPowder:1; // Never read + bool8 newRecord:1; + bool8 playedSound:1; + bool8 endGame:1; + bool8 bigSparkle:1; u8 sparkleAmount:3; u16 leaderTimer; u16 timer; @@ -640,7 +628,7 @@ static const struct WindowTemplate sWindowTemplates_Results[] = { }; static const u8 sResultsWindowHeights[][MAX_RFU_PLAYERS - 1] = { - { 6, 8, 9, 11 }, // "Preses" and "Neatness/Cooperative/Power" pages + { 6, 8, 9, 11 }, // "Presses" and "Neatness/Cooperative/Power" pages { 12, 14, 15, 16 }, // "Crushing" page }; @@ -1075,28 +1063,28 @@ static void SaveResults(void) case 2: if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[0]) { - sGame->newRecord = 1; + sGame->newRecord = TRUE; gSaveBlock2Ptr->berryCrush.berryCrushResults[0] = sGame->pressingSpeed; } break; case 3: if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[1]) { - sGame->newRecord = 1; + sGame->newRecord = TRUE; gSaveBlock2Ptr->berryCrush.berryCrushResults[1] = sGame->pressingSpeed; } break; case 4: if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[2]) { - sGame->newRecord = 1; + sGame->newRecord = TRUE; gSaveBlock2Ptr->berryCrush.berryCrushResults[2] = sGame->pressingSpeed; } break; case 5: if (sGame->pressingSpeed > gSaveBlock2Ptr->berryCrush.berryCrushResults[3]) { - sGame->newRecord = 1; + sGame->newRecord = TRUE; gSaveBlock2Ptr->berryCrush.berryCrushResults[3] = sGame->pressingSpeed; } break; From f2847354f42e7bc62279a713f9331a900f9c7c75 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 6 May 2021 09:27:56 -0400 Subject: [PATCH 05/21] Improve documentation of math_util --- include/math_util.h | 27 +++++++++++++++++++++------ src/math_util.c | 19 ++++++++++--------- 2 files changed, 31 insertions(+), 15 deletions(-) diff --git a/include/math_util.h b/include/math_util.h index 1ccde1ef5..b1243df56 100644 --- a/include/math_util.h +++ b/include/math_util.h @@ -1,11 +1,26 @@ #ifndef GUARD_MATH_UTIL_H #define GUARD_MATH_UTIL_H -s16 invfx16(s16 y); -s16 mulfx16(s16 x, s16 y); -s32 divfx32(s32 x, s32 y); -s32 mulfx32(s32 x, s32 y); -s16 divfxn16(u8 s, s16 x, s16 y); -s16 mulfxn16(u8 s, s16 x, s16 y); +// Fixed-point arithmetic library. + +// Proposed TODO: Move the macros here from global.h +typedef s16 fx16; // Fixed-point Q8.8 +typedef s16 fxn16; // Fixed-point with arbitrary precision (QN.S) +typedef s32 fx32; // Fixed-point Q24.8 + +// x * y +fx16 mulfx16(fx16 x, fx16 y); +fxn16 mulfxn16(u8 s, fxn16 x, fxn16 y); +fx32 mulfx32(fx32 x, fx32 y); + +// x / y +fx16 divfx16(fx16 x, fx16 y); +fxn16 divfxn16(u8 s, fxn16 x, fxn16 y); +fx32 divfx32(fx32 x, fx32 y); + +// 1.0 / y +fx16 invfx16(fx16 y); +fxn16 invfxn16(u8 s, fxn16 y); +fx32 invfx32(fx32 y); #endif //GUARD_MATH_UTIL_H diff --git a/src/math_util.c b/src/math_util.c index d4e2f3f56..e13c36ea6 100644 --- a/src/math_util.c +++ b/src/math_util.c @@ -1,6 +1,7 @@ #include "global.h" +#include "math_util.h" -s16 mulfx16(s16 x, s16 y) +fx16 mulfx16(fx16 x, fx16 y) { s32 result; @@ -10,7 +11,7 @@ s16 mulfx16(s16 x, s16 y) return result; } -s16 mulfxn16(u8 s, s16 x, s16 y) +fxn16 mulfxn16(u8 s, fxn16 x, fxn16 y) { s32 result; @@ -20,7 +21,7 @@ s16 mulfxn16(u8 s, s16 x, s16 y) return result; } -s32 mulfx32(s32 x, s32 y) +fx32 mulfx32(fx32 x, fx32 y) { s64 result; @@ -30,7 +31,7 @@ s32 mulfx32(s32 x, s32 y) return result; } -s16 divfx16(s16 x, s16 y) +fx16 divfx16(fx16 x, fx16 y) { if (y == 0) { @@ -39,7 +40,7 @@ s16 divfx16(s16 x, s16 y) return (x << 8) / y; } -s16 divfxn16(u8 s, s16 x, s16 y) +fxn16 divfxn16(u8 s, fxn16 x, fxn16 y) { if (y == 0) { @@ -48,7 +49,7 @@ s16 divfxn16(u8 s, s16 x, s16 y) return (x << s) / y; } -s32 divfx32(s32 x, s32 y) +fx32 divfx32(fx32 x, fx32 y) { s64 _x; @@ -61,7 +62,7 @@ s32 divfx32(s32 x, s32 y) return _x / y; } -s16 invfx16(s16 y) +fx16 invfx16(fx16 y) { s32 x; @@ -69,7 +70,7 @@ s16 invfx16(s16 y) return x / y; } -s16 invfxn16(u8 s, s16 y) +fxn16 invfxn16(u8 s, fxn16 y) { s32 x; @@ -77,7 +78,7 @@ s16 invfxn16(u8 s, s16 y) return x / y; } -s32 invfx32(s32 y) +fx32 invfx32(fx32 y) { s64 x; From 2f58a0c5f7f916e7242e3694efb51e769c0bc620 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 6 May 2021 12:22:28 -0400 Subject: [PATCH 06/21] Fill in some missing macro/enum uses --- src/berry_crush.c | 60 +++++++++++++++++++++++------------------------ 1 file changed, 30 insertions(+), 30 deletions(-) diff --git a/src/berry_crush.c b/src/berry_crush.c index 320e9c131..5969d2516 100644 --- a/src/berry_crush.c +++ b/src/berry_crush.c @@ -1164,7 +1164,7 @@ static void RunOrScheduleCommand(u16 command, u8 runMode, u8 *args) if (command != CMD_NONE) sBerryCrushCommands[command](game, args); if (game->nextCmd >= NELEMS(sBerryCrushCommands)) - game->nextCmd = 0; + game->nextCmd = CMD_NONE; game->cmdCallback = sBerryCrushCommands[game->nextCmd]; break; case SCHEDULE_CMD: @@ -2408,7 +2408,7 @@ static u32 Cmd_CloseLink(struct BerryCrushGame * game, UNUSED u8 *args) return 0; game->nextCmd = CMD_QUIT; RunOrScheduleCommand(CMD_HIDE_GAME, SCHEDULE_CMD, NULL); - game->cmdState = 2; // ??? + game->cmdState = 2; // State is not progressed return 0; } ++game->cmdState; @@ -2429,7 +2429,7 @@ static void ResetGame(struct BerryCrushGame * game) game->unused = 0; game->cmdTimer = 0; game->gameState = STATE_RESET; - game->playAgainState = 0; + game->playAgainState = PLAY_AGAIN_YES; game->powder = 0; game->targetAPresses = 0; game->totalAPresses = 0; @@ -2447,7 +2447,7 @@ static void ResetGame(struct BerryCrushGame * game) game->numBigSparkleChecks = -1; game->numBigSparkles = 0; game->sparkleCounter = 0; - for (i = 0; i < 5; ++i) + for (i = 0; i < MAX_RFU_PLAYERS; ++i) { game->players[i].berryId = -1; game->players[i].inputTime = 0; @@ -2821,7 +2821,7 @@ static void UpdateInputEffects(struct BerryCrushGame * game, struct BerryCrushGa { gfx->sparkleSprites[i]->callback = SpriteCB_Sparkle_Init; gfx->sparkleSprites[i]->pos1.x = sSparkleCoords[i][0] + 120; - gfx->sparkleSprites[i]->pos1.y = sSparkleCoords[i][1] + 136 - (temp1 * 4); + gfx->sparkleSprites[i]->pos1.y = sSparkleCoords[i][1] + 136 - (yModifier * 4); gfx->sparkleSprites[i]->pos2.x = sSparkleCoords[i][0] + (sSparkleCoords[i][0] / (xModifier * 4)); gfx->sparkleSprites[i]->pos2.y = sSparkleCoords[i][1]; if (linkState->bigSparkle) @@ -2923,8 +2923,8 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 linkIdToPrint = i; ConvertIntToDecimalStringN(gStringVar1, bcPlayers->stats[command][i], STR_CONV_MODE_RIGHT_ALIGN, 4); realX = x - GetStringWidth(2, sBCRankingHeaders[command], -1) - 4; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX, y + 14 * i, sBerryCrushTextColorTable[0], 0, sBCRankingHeaders[command]); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX - 24, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar1); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, sBCRankingHeaders[command]); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX - 24, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar1); break; case RESULTS_PAGE_RANDOM: // Neatness @@ -2943,7 +2943,7 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 ConvertIntToDecimalStringN(gStringVar2, realX, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, sBCRankingHeaders[command]); realX2 = x - 4; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX2 - GetStringWidth(2, gStringVar4, 0), y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX2 - GetStringWidth(2, gStringVar4, 0), y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); break; case RESULTS_PAGE_CRUSHING: // Berry names @@ -2954,7 +2954,7 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 j = 0; StringCopy(gStringVar1, gBerries[j].name); StringExpandPlaceholders(gStringVar4, sBCRankingHeaders[command]); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x - GetStringWidth(2, gStringVar4, -1) - 4, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x - GetStringWidth(2, gStringVar4, -1) - 4, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); break; } if (linkPlayerId == game->localId) @@ -2964,7 +2964,7 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 gStringVar3[0] = linkIdToPrint + CHAR_1; DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, game->players[linkPlayerId].name); DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gStringVar3); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 4, y + 14 * i, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 4, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); } } @@ -2977,30 +2977,30 @@ static void printCrushingResults(struct BerryCrushGame * game) u8 y = GetWindowAttribute(game->gfx.resultsIndowId, WINDOW_HEIGHT) * 8 - 42; FramesToMinSec(&game->gfx, players->time); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_TimeColon); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_TimeColon); x = 190 - (u8)GetStringWidth(2, gText_SpaceSec, 0); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gText_SpaceSec); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_SpaceSec); x -= 32; ConvertIntToDecimalStringN(gStringVar1, game->gfx.secondsInt, STR_CONV_MODE_LEADING_ZEROS, 2); ConvertIntToDecimalStringN(gStringVar2, game->gfx.secondsFrac, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, gText_XDotY2); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); x -= (u8)GetStringWidth(2, gText_SpaceMin, 0) + 3; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gText_SpaceMin); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_SpaceMin); x -= 9; ConvertIntToDecimalStringN(gStringVar1, game->gfx.minutes, STR_CONV_MODE_LEADING_ZEROS, 1); StringExpandPlaceholders(gStringVar4, gText_StrVar1); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); y += 14; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_PressingSpeed); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_PressingSpeed); x = 190 - (u8)GetStringWidth(2, gText_TimesPerSec, 0); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 3, x, y, sBerryCrushTextColorTable[0], 0, gText_TimesPerSec); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 3, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_TimesPerSec); for (i = 0; i < 8; ++i) if (((u8)game->pressingSpeed >> (7 - i)) & 1) @@ -3010,17 +3010,17 @@ static void printCrushingResults(struct BerryCrushGame * game) StringExpandPlaceholders(gStringVar4, gText_XDotY3); x -= 38; if (game->newRecord) - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[5], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_RED], 0, gStringVar4); else - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); y += 14; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[0], 0, gText_Silkiness); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_Silkiness); ConvertIntToDecimalStringN(gStringVar1, players->silkiness, STR_CONV_MODE_RIGHT_ALIGN, 3); StringExpandPlaceholders(gStringVar4, gText_Var1Percent); x = 190 - (u8)GetStringWidth(2, gStringVar4, 0); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[0], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); } static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushGame_Gfx * spriteManager) @@ -3054,17 +3054,17 @@ static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushG switch (game->gameState) { case STATE_RESULTS_PRESSES: - PrintTextCentered(spriteManager->resultsIndowId, 22, 3, gText_PressesRankings); + PrintTextCentered(spriteManager->resultsIndowId, 22, COLORID_BLUE, gText_PressesRankings); PrintResultsText(game, RESULTS_PAGE_PRESSES, 0xB0, 8 * sResultsWindowHeights[0][playerCountMinus2] - game->playerCount * 14); spriteManager->resultsState = 5; return FALSE; case STATE_RESULTS_RANDOM: - PrintTextCentered(spriteManager->resultsIndowId, 22, 4, sBCRankingHeaders[game->results.playerIdsRanked[0][7] + 3]); + PrintTextCentered(spriteManager->resultsIndowId, 22, COLORID_GREEN, sBCRankingHeaders[game->results.randomPageId + 3]); PrintResultsText(game, RESULTS_PAGE_RANDOM, 0xB0, 8 * sResultsWindowHeights[0][playerCountMinus2] - game->playerCount * 14); spriteManager->resultsState = 5; return FALSE; case STATE_RESULTS_CRUSHING: - PrintTextCentered(spriteManager->resultsIndowId, 24, 3, gText_CrushingResults); + PrintTextCentered(spriteManager->resultsIndowId, 24, COLORID_BLUE, gText_CrushingResults); PrintResultsText(game, RESULTS_PAGE_CRUSHING, 0xC0, 0x10); break; } @@ -3115,7 +3115,7 @@ static void Task_ShowBerryCrushRankings(u8 taskId) 2, xPos, 2, - sBerryCrushTextColorTable[3], + sBerryCrushTextColorTable[COLORID_BLUE], 0, gText_BerryCrush2 ); @@ -3125,7 +3125,7 @@ static void Task_ShowBerryCrushRankings(u8 taskId) 2, xPos, 18, - sBerryCrushTextColorTable[3], + sBerryCrushTextColorTable[COLORID_BLUE], 0, gText_PressingSpeedRankings ); @@ -3139,7 +3139,7 @@ static void Task_ShowBerryCrushRankings(u8 taskId) 2, 4, yPos, - sBerryCrushTextColorTable[0], + sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4 ); @@ -3159,7 +3159,7 @@ static void Task_ShowBerryCrushRankings(u8 taskId) 3, xPos, yPos, - sBerryCrushTextColorTable[0], + sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4 ); @@ -3244,7 +3244,7 @@ static void DrawPlayerNameWindows(struct BerryCrushGame * game) 1, 0, 0, - sBerryCrushTextColorTable[1], + sBerryCrushTextColorTable[COLORID_BLACK], 0, game->players[i].name ); @@ -3258,7 +3258,7 @@ static void DrawPlayerNameWindows(struct BerryCrushGame * game) 1, 0, 0, - sBerryCrushTextColorTable[2], + sBerryCrushTextColorTable[COLORID_LIGHT_GRAY], 0, game->players[i].name ); From 7b1ae6e629980c6bc1ed1a70f6b74c679f96f38e Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 6 May 2021 12:35:49 -0400 Subject: [PATCH 07/21] Fix another typo --- src/berry_crush.c | 58 +++++++++++++++++++++++------------------------ 1 file changed, 29 insertions(+), 29 deletions(-) diff --git a/src/berry_crush.c b/src/berry_crush.c index 5969d2516..f291892fe 100644 --- a/src/berry_crush.c +++ b/src/berry_crush.c @@ -289,7 +289,7 @@ struct BerryCrushGame_Gfx struct Sprite *timerSprites[2]; u8 resultsState; u8 unused; - u8 resultsIndowId; + u8 resultsWindowId; u8 nameWindowIds[MAX_RFU_PLAYERS]; u16 bgBuffers[4][BG_SCREEN_SIZE]; }; @@ -2923,8 +2923,8 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 linkIdToPrint = i; ConvertIntToDecimalStringN(gStringVar1, bcPlayers->stats[command][i], STR_CONV_MODE_RIGHT_ALIGN, 4); realX = x - GetStringWidth(2, sBCRankingHeaders[command], -1) - 4; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, sBCRankingHeaders[command]); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX - 24, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar1); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, realX, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, sBCRankingHeaders[command]); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, realX - 24, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar1); break; case RESULTS_PAGE_RANDOM: // Neatness @@ -2943,7 +2943,7 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 ConvertIntToDecimalStringN(gStringVar2, realX, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, sBCRankingHeaders[command]); realX2 = x - 4; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, realX2 - GetStringWidth(2, gStringVar4, 0), y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, realX2 - GetStringWidth(2, gStringVar4, 0), y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); break; case RESULTS_PAGE_CRUSHING: // Berry names @@ -2954,7 +2954,7 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 j = 0; StringCopy(gStringVar1, gBerries[j].name); StringExpandPlaceholders(gStringVar4, sBCRankingHeaders[command]); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x - GetStringWidth(2, gStringVar4, -1) - 4, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x - GetStringWidth(2, gStringVar4, -1) - 4, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); break; } if (linkPlayerId == game->localId) @@ -2964,7 +2964,7 @@ static void PrintResultsText(struct BerryCrushGame * game, u8 command, u8 x, u8 gStringVar3[0] = linkIdToPrint + CHAR_1; DynamicPlaceholderTextUtil_SetPlaceholderPtr(0, game->players[linkPlayerId].name); DynamicPlaceholderTextUtil_ExpandPlaceholders(gStringVar4, gStringVar3); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 4, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, 4, y + 14 * i, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); } } @@ -2974,33 +2974,33 @@ static void printCrushingResults(struct BerryCrushGame * game) u8 x = 0; u32 score = 0; struct BerryCrushGame_Results *players = &game->results; - u8 y = GetWindowAttribute(game->gfx.resultsIndowId, WINDOW_HEIGHT) * 8 - 42; + u8 y = GetWindowAttribute(game->gfx.resultsWindowId, WINDOW_HEIGHT) * 8 - 42; FramesToMinSec(&game->gfx, players->time); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_TimeColon); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_TimeColon); x = 190 - (u8)GetStringWidth(2, gText_SpaceSec, 0); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_SpaceSec); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_SpaceSec); x -= 32; ConvertIntToDecimalStringN(gStringVar1, game->gfx.secondsInt, STR_CONV_MODE_LEADING_ZEROS, 2); ConvertIntToDecimalStringN(gStringVar2, game->gfx.secondsFrac, STR_CONV_MODE_LEADING_ZEROS, 2); StringExpandPlaceholders(gStringVar4, gText_XDotY2); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); x -= (u8)GetStringWidth(2, gText_SpaceMin, 0) + 3; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_SpaceMin); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_SpaceMin); x -= 9; ConvertIntToDecimalStringN(gStringVar1, game->gfx.minutes, STR_CONV_MODE_LEADING_ZEROS, 1); StringExpandPlaceholders(gStringVar4, gText_StrVar1); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); y += 14; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_PressingSpeed); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_PressingSpeed); x = 190 - (u8)GetStringWidth(2, gText_TimesPerSec, 0); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 3, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_TimesPerSec); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 3, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_TimesPerSec); for (i = 0; i < 8; ++i) if (((u8)game->pressingSpeed >> (7 - i)) & 1) @@ -3010,17 +3010,17 @@ static void printCrushingResults(struct BerryCrushGame * game) StringExpandPlaceholders(gStringVar4, gText_XDotY3); x -= 38; if (game->newRecord) - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_RED], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_RED], 0, gStringVar4); else - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); y += 14; - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_Silkiness); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, 2, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gText_Silkiness); ConvertIntToDecimalStringN(gStringVar1, players->silkiness, STR_CONV_MODE_RIGHT_ALIGN, 3); StringExpandPlaceholders(gStringVar4, gText_Var1Percent); x = 190 - (u8)GetStringWidth(2, gStringVar4, 0); - AddTextPrinterParameterized3(game->gfx.resultsIndowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); + AddTextPrinterParameterized3(game->gfx.resultsWindowId, 2, x, y, sBerryCrushTextColorTable[COLORID_GRAY], 0, gStringVar4); } static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushGame_Gfx * spriteManager) @@ -3039,32 +3039,32 @@ static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushG template.height = sResultsWindowHeights[1][playerCountMinus2]; else template.height = sResultsWindowHeights[0][playerCountMinus2]; - spriteManager->resultsIndowId = AddWindow(&template); + spriteManager->resultsWindowId = AddWindow(&template); break; case 1: - PutWindowTilemap(spriteManager->resultsIndowId); - FillWindowPixelBuffer(spriteManager->resultsIndowId, PIXEL_FILL(0)); + PutWindowTilemap(spriteManager->resultsWindowId); + FillWindowPixelBuffer(spriteManager->resultsWindowId, PIXEL_FILL(0)); break; case 2: - TextWindow_SetStdFrame0_WithPal(spriteManager->resultsIndowId, 0x21D, 0xD0); - DrawStdFrameWithCustomTileAndPalette(spriteManager->resultsIndowId, FALSE, 541, 13); + TextWindow_SetStdFrame0_WithPal(spriteManager->resultsWindowId, 0x21D, 0xD0); + DrawStdFrameWithCustomTileAndPalette(spriteManager->resultsWindowId, FALSE, 541, 13); break; case 3: playerCountMinus2 = game->playerCount - 2; switch (game->gameState) { case STATE_RESULTS_PRESSES: - PrintTextCentered(spriteManager->resultsIndowId, 22, COLORID_BLUE, gText_PressesRankings); + PrintTextCentered(spriteManager->resultsWindowId, 22, COLORID_BLUE, gText_PressesRankings); PrintResultsText(game, RESULTS_PAGE_PRESSES, 0xB0, 8 * sResultsWindowHeights[0][playerCountMinus2] - game->playerCount * 14); spriteManager->resultsState = 5; return FALSE; case STATE_RESULTS_RANDOM: - PrintTextCentered(spriteManager->resultsIndowId, 22, COLORID_GREEN, sBCRankingHeaders[game->results.randomPageId + 3]); + PrintTextCentered(spriteManager->resultsWindowId, 22, COLORID_GREEN, sBCRankingHeaders[game->results.randomPageId + 3]); PrintResultsText(game, RESULTS_PAGE_RANDOM, 0xB0, 8 * sResultsWindowHeights[0][playerCountMinus2] - game->playerCount * 14); spriteManager->resultsState = 5; return FALSE; case STATE_RESULTS_CRUSHING: - PrintTextCentered(spriteManager->resultsIndowId, 24, COLORID_BLUE, gText_CrushingResults); + PrintTextCentered(spriteManager->resultsWindowId, 24, COLORID_BLUE, gText_CrushingResults); PrintResultsText(game, RESULTS_PAGE_CRUSHING, 0xC0, 0x10); break; } @@ -3073,7 +3073,7 @@ static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushG printCrushingResults(game); break; case 5: - CopyWindowToVram(spriteManager->resultsIndowId, COPYWIN_BOTH); + CopyWindowToVram(spriteManager->resultsWindowId, COPYWIN_BOTH); spriteManager->resultsState = 0; return TRUE; } @@ -3083,8 +3083,8 @@ static bool32 OpenResultsWindow(struct BerryCrushGame * game, struct BerryCrushG static void CloseResultsWindow(struct BerryCrushGame * game) { - ClearStdWindowAndFrameToTransparent(game->gfx.resultsIndowId, 1); - RemoveWindow(game->gfx.resultsIndowId); + ClearStdWindowAndFrameToTransparent(game->gfx.resultsWindowId, TRUE); + RemoveWindow(game->gfx.resultsWindowId); DrawPlayerNameWindows(game); } From 5c965f5357c09a9eaaad029441401498e0877966 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Mon, 24 May 2021 14:59:35 -0400 Subject: [PATCH 08/21] Rename fixed point math routines again --- include/math_util.h | 18 +++++++-------- src/battle_anim_effects_2.c | 14 +++++------ src/berry_crush.c | 46 ++++++++++++++++++------------------- src/math_util.c | 18 +++++++-------- src/oak_speech.c | 4 ++-- 5 files changed, 50 insertions(+), 50 deletions(-) diff --git a/include/math_util.h b/include/math_util.h index b1243df56..29fa8f59d 100644 --- a/include/math_util.h +++ b/include/math_util.h @@ -9,18 +9,18 @@ typedef s16 fxn16; // Fixed-point with arbitrary precision (QN.S) typedef s32 fx32; // Fixed-point Q24.8 // x * y -fx16 mulfx16(fx16 x, fx16 y); -fxn16 mulfxn16(u8 s, fxn16 x, fxn16 y); -fx32 mulfx32(fx32 x, fx32 y); +fx16 Q_8_8_mul(fx16 x, fx16 y); +fxn16 Q_N_S_mul(u8 s, fxn16 x, fxn16 y); +fx32 Q_24_8_mul(fx32 x, fx32 y); // x / y -fx16 divfx16(fx16 x, fx16 y); -fxn16 divfxn16(u8 s, fxn16 x, fxn16 y); -fx32 divfx32(fx32 x, fx32 y); +fx16 Q_8_8_div(fx16 x, fx16 y); +fxn16 Q_N_S_div(u8 s, fxn16 x, fxn16 y); +fx32 Q_24_8_div(fx32 x, fx32 y); // 1.0 / y -fx16 invfx16(fx16 y); -fxn16 invfxn16(u8 s, fxn16 y); -fx32 invfx32(fx32 y); +fx16 Q_8_8_inv(fx16 y); +fxn16 Q_N_S_inv(u8 s, fxn16 y); +fx32 Q_24_8_inv(fx32 y); #endif //GUARD_MATH_UTIL_H diff --git a/src/battle_anim_effects_2.c b/src/battle_anim_effects_2.c index b2342a0c9..e24434a0e 100644 --- a/src/battle_anim_effects_2.c +++ b/src/battle_anim_effects_2.c @@ -1532,7 +1532,7 @@ void AnimAirWaveProjectile(struct Sprite *sprite) { sprite->data[0] = 8; task->data[5] = 4; - a = invfx16(0x1000); + a = Q_8_8_inv(0x1000); sprite->pos1.x += sprite->pos2.x; sprite->pos1.y += sprite->pos2.y; sprite->pos2.y = 0; @@ -1551,8 +1551,8 @@ void AnimAirWaveProjectile(struct Sprite *sprite) sprite->data[1] = 0; sprite->data[6] = 0; sprite->data[5] = 0; - sprite->data[3] = mulfx16(mulfx16(b, a), invfx16(0x1C0)); - sprite->data[4] = mulfx16(mulfx16(c, a), invfx16(0x1C0)); + sprite->data[3] = Q_8_8_mul(Q_8_8_mul(b, a), Q_8_8_inv(0x1C0)); + sprite->data[4] = Q_8_8_mul(Q_8_8_mul(c, a), Q_8_8_inv(0x1C0)); sprite->callback = AnimAirWaveProjectile_Step1; } } @@ -1643,18 +1643,18 @@ void AnimTask_AirCutterProjectile(u8 taskId) else xDiff = attackerX - targetX; - gTasks[taskId].data[5] = mulfx16(xDiff, invfx16(gBattleAnimArgs[2] & ~1)); - gTasks[taskId].data[6] = mulfx16(gTasks[taskId].data[5], 0x80); + gTasks[taskId].data[5] = Q_8_8_mul(xDiff, Q_8_8_inv(gBattleAnimArgs[2] & ~1)); + gTasks[taskId].data[6] = Q_8_8_mul(gTasks[taskId].data[5], 0x80); gTasks[taskId].data[7] = gBattleAnimArgs[2]; if (targetY >= attackerY) { yDiff = targetY - attackerY; - gTasks[taskId].data[8] = mulfx16(yDiff, invfx16(gTasks[taskId].data[5])) & ~1; + gTasks[taskId].data[8] = Q_8_8_mul(yDiff, Q_8_8_inv(gTasks[taskId].data[5])) & ~1; } else { yDiff = attackerY - targetY; - gTasks[taskId].data[8] = mulfx16(yDiff, invfx16(gTasks[taskId].data[5])) | 1; + gTasks[taskId].data[8] = Q_8_8_mul(yDiff, Q_8_8_inv(gTasks[taskId].data[5])) | 1; } gTasks[taskId].data[3] = gBattleAnimArgs[3]; diff --git a/src/berry_crush.c b/src/berry_crush.c index f291892fe..f2c54297b 100644 --- a/src/berry_crush.c +++ b/src/berry_crush.c @@ -1052,10 +1052,10 @@ static void SaveResults(void) time = sGame->results.time; time = Q_24_8(time); - time = divfx32(time, Q_24_8(60)); + time = Q_24_8_div(time, Q_24_8(60)); presses = sGame->results.totalAPresses; presses = Q_24_8(presses); - presses = divfx32(presses, time) & 0xFFFF; + presses = Q_24_8_div(presses, time) & 0xFFFF; sGame->pressingSpeed = presses; switch (sGame->playerCount) @@ -1402,7 +1402,7 @@ static u32 Cmd_WaitForOthersToPickBerries(struct BerryCrushGame * game, u8 *args } game->cmdTimer = 0; ResetBlockReceivedFlags(); - game->targetDepth = divfx32(Q_24_8(game->targetAPresses), Q_24_8(32)); + game->targetDepth = Q_24_8_div(Q_24_8(game->targetAPresses), Q_24_8(32)); break; case 5: ClearDialogWindowAndFrame(0, TRUE); @@ -1630,7 +1630,7 @@ static void HandlePartnerInput(struct BerryCrushGame * game) { temp = game->totalAPresses; temp = Q_24_8(temp); - temp = divfx32(temp, game->targetDepth); + temp = Q_24_8_div(temp, game->targetDepth); temp = Q_24_8_TO_INT(temp); game->newDepth = (u8)temp; return; @@ -2030,16 +2030,16 @@ static u32 Cmd_TabulateResults(struct BerryCrushGame * game, UNUSED u8 *args) // Silkiness is the percentage of times big sparkles were produced when possible, // which itself depends on the number of A presses every 30 frames // (numBigSparkles * 50 / numBigSparkleChecks) + 50 - temp1 = mulfx32(Q_24_8(game->numBigSparkles), Q_24_8(50)); - temp1 = divfx32(temp1, Q_24_8(game->numBigSparkleChecks)) + Q_24_8(50); + temp1 = Q_24_8_mul(Q_24_8(game->numBigSparkles), Q_24_8(50)); + temp1 = Q_24_8_div(temp1, Q_24_8(game->numBigSparkleChecks)) + Q_24_8(50); temp1 = Q_24_8_TO_INT(temp1); game->results.silkiness = temp1 & 0x7F; // Calculate amount of powder temp1 = Q_24_8(temp1); - temp1 = divfx32(temp1, Q_24_8(100)); + temp1 = Q_24_8_div(temp1, Q_24_8(100)); temp2 = Q_24_8(game->powder * game->playerCount); - temp2 = mulfx32(temp2, temp1); + temp2 = Q_24_8_mul(temp2, temp1); game->results.powder = Q_24_8_TO_INT(temp2); // Choose random second results page @@ -2061,10 +2061,10 @@ static u32 Cmd_TabulateResults(struct BerryCrushGame * game, UNUSED u8 *args) // "Neat" inputs are those done at a regular interval temp1 = game->players[i].maxNeatInputStreak; temp1 = Q_24_8(temp1); - temp1 = mulfx32(temp1, Q_24_8(100)); + temp1 = Q_24_8_mul(temp1, Q_24_8(100)); temp2 = game->players[i].numAPresses; temp2 = Q_24_8(temp2); - temp2 = divfx32(temp1, temp2); + temp2 = Q_24_8_div(temp1, temp2); } else { @@ -2078,10 +2078,10 @@ static u32 Cmd_TabulateResults(struct BerryCrushGame * game, UNUSED u8 *args) // done at the same time as another player temp1 = game->players[i].numSyncedAPresses; temp1 = Q_24_8(temp1); - temp1 = mulfx32(temp1, Q_24_8(100)); + temp1 = Q_24_8_mul(temp1, Q_24_8(100)); temp2 = game->players[i].numAPresses; temp2 = Q_24_8(temp2); - temp2 = divfx32(temp1, temp2); + temp2 = Q_24_8_div(temp1, temp2); } else { @@ -2104,10 +2104,10 @@ static u32 Cmd_TabulateResults(struct BerryCrushGame * game, UNUSED u8 *args) // player spent pressing A temp1 = game->players[i].timePressingA; temp1 = Q_24_8(temp1); - temp1 = mulfx32(temp1, Q_24_8(100)); + temp1 = Q_24_8_mul(temp1, Q_24_8(100)); temp2 = game->timer; temp2 = Q_24_8(temp2); - temp2 = divfx32(temp1, temp2); + temp2 = Q_24_8_div(temp1, temp2); } break; } @@ -2716,12 +2716,12 @@ static void CreateBerrySprites(struct BerryCrushGame * game, struct BerryCrushGa distance = Q_N_S(7, distance); var2 = speed + Q_8_8(0.125); var2 = var2 / 2; // go from Q8.8 to Q9.7 - var1 = divfxn16(7, Q_N_S(7, 127), var2); + var1 = Q_N_S_div(7, Q_N_S(7, 127), var2); sX = Q_N_S(7, (u16)spritesManager->berrySprites[i]->pos1.x); - sXSpeed = divfxn16(7, distance, var1); - var1 = mulfxn16(7, var1, Q_N_S(7, 0.666666667)); + sXSpeed = Q_N_S_div(7, distance, var1); + var1 = Q_N_S_mul(7, var1, Q_N_S(7, 0.666666667)); sSinIdx = 0; - sSinSpeed = divfxn16(7, Q_N_S(7, 127), var1); + sSinSpeed = Q_N_S_div(7, Q_N_S(7, 127), var1); sBitfield |= F_MOVE_HORIZ; if (spritesManager->playerCoords[i]->berryXOffset < 0) StartSpriteAffineAnim(spritesManager->berrySprites[i], 1); @@ -2883,7 +2883,7 @@ static void FramesToMinSec(struct BerryCrushGame_Gfx * gfx, u16 frames) gfx->minutes = frames / 3600; gfx->secondsInt = (frames % 3600) / 60; - frac_secs = mulfx16(Q_8_8(frames % 60), Q_8_8(0.016666667)); + frac_secs = Q_8_8_mul(Q_8_8(frames % 60), Q_8_8(0.016666667)); for (i = 0; i < 8; i++) { @@ -3461,12 +3461,12 @@ static void SpriteCB_Sparkle_Init(struct Sprite * sprite) targetY = 168; sBitfield = targetY; xMult = Q_N_S(7, sprite->pos2.x); - var = divfxn16(7, Q_N_S(7, targetY - (u16)sprite->pos1.y), (speed + Q_8_8(0.125)) >> 1); + var = Q_N_S_div(7, Q_N_S(7, targetY - (u16) sprite->pos1.y), (speed + Q_8_8(0.125)) >> 1); sprite->sX = Q_N_S(7, (u16)sprite->pos1.x); - sXSpeed = divfxn16(7, xMult, var); - speed = mulfxn16(7, var, Q_N_S(7, 0.666666667)); + sXSpeed = Q_N_S_div(7, xMult, var); + speed = Q_N_S_mul(7, var, Q_N_S(7, 0.666666667)); sSinIdx = zero; - sSinSpeed = divfxn16(7, Q_N_S(7, 127), speed); + sSinSpeed = Q_N_S_div(7, Q_N_S(7, 127), speed); sAmplitude = sprite->pos2.x / 4; sBitfield |= F_MOVE_HORIZ; sprite->pos2.y = zero; diff --git a/src/math_util.c b/src/math_util.c index e13c36ea6..eff2fd7c0 100644 --- a/src/math_util.c +++ b/src/math_util.c @@ -1,7 +1,7 @@ #include "global.h" #include "math_util.h" -fx16 mulfx16(fx16 x, fx16 y) +fx16 Q_8_8_mul(fx16 x, fx16 y) { s32 result; @@ -11,7 +11,7 @@ fx16 mulfx16(fx16 x, fx16 y) return result; } -fxn16 mulfxn16(u8 s, fxn16 x, fxn16 y) +fxn16 Q_N_S_mul(u8 s, fxn16 x, fxn16 y) { s32 result; @@ -21,7 +21,7 @@ fxn16 mulfxn16(u8 s, fxn16 x, fxn16 y) return result; } -fx32 mulfx32(fx32 x, fx32 y) +fx32 Q_24_8_mul(fx32 x, fx32 y) { s64 result; @@ -31,7 +31,7 @@ fx32 mulfx32(fx32 x, fx32 y) return result; } -fx16 divfx16(fx16 x, fx16 y) +fx16 Q_8_8_div(fx16 x, fx16 y) { if (y == 0) { @@ -40,7 +40,7 @@ fx16 divfx16(fx16 x, fx16 y) return (x << 8) / y; } -fxn16 divfxn16(u8 s, fxn16 x, fxn16 y) +fxn16 Q_N_S_div(u8 s, fxn16 x, fxn16 y) { if (y == 0) { @@ -49,7 +49,7 @@ fxn16 divfxn16(u8 s, fxn16 x, fxn16 y) return (x << s) / y; } -fx32 divfx32(fx32 x, fx32 y) +fx32 Q_24_8_div(fx32 x, fx32 y) { s64 _x; @@ -62,7 +62,7 @@ fx32 divfx32(fx32 x, fx32 y) return _x / y; } -fx16 invfx16(fx16 y) +fx16 Q_8_8_inv(fx16 y) { s32 x; @@ -70,7 +70,7 @@ fx16 invfx16(fx16 y) return x / y; } -fxn16 invfxn16(u8 s, fxn16 y) +fxn16 Q_N_S_inv(u8 s, fxn16 y) { s32 x; @@ -78,7 +78,7 @@ fxn16 invfxn16(u8 s, fxn16 y) return x / y; } -fx32 invfx32(fx32 y) +fx32 Q_24_8_inv(fx32 y) { s64 x; diff --git a/src/oak_speech.c b/src/oak_speech.c index 63cb35806..3779090a3 100644 --- a/src/oak_speech.c +++ b/src/oak_speech.c @@ -1418,8 +1418,8 @@ static void Task_OakSpeech39(u8 taskId) PlaySE(SE_WARP_IN); r0 = data[2]; data[2] -= 32; - x = invfx16(r0 - 8); - y = invfx16(data[2] - 16); + x = Q_8_8_inv(r0 - 8); + y = Q_8_8_inv(data[2] - 16); SetBgAffine(2, 0x7800, 0x5400, 0x78, 0x54, x, y, 0); if (data[2] <= 96) { From 1a9ba7bb0aeb27a7d0bca43190edd054e517f27b Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Wed, 26 May 2021 09:59:32 -0400 Subject: [PATCH 09/21] Revert typedefs in math_util --- include/math_util.h | 23 +++++++++-------------- src/math_util.c | 18 +++++++++--------- 2 files changed, 18 insertions(+), 23 deletions(-) diff --git a/include/math_util.h b/include/math_util.h index 29fa8f59d..1f8edc5d9 100644 --- a/include/math_util.h +++ b/include/math_util.h @@ -3,24 +3,19 @@ // Fixed-point arithmetic library. -// Proposed TODO: Move the macros here from global.h -typedef s16 fx16; // Fixed-point Q8.8 -typedef s16 fxn16; // Fixed-point with arbitrary precision (QN.S) -typedef s32 fx32; // Fixed-point Q24.8 - // x * y -fx16 Q_8_8_mul(fx16 x, fx16 y); -fxn16 Q_N_S_mul(u8 s, fxn16 x, fxn16 y); -fx32 Q_24_8_mul(fx32 x, fx32 y); +s16 Q_8_8_mul(s16 x, s16 y); +s16 Q_N_S_mul(u8 s, s16 x, s16 y); +s32 Q_24_8_mul(s32 x, s32 y); // x / y -fx16 Q_8_8_div(fx16 x, fx16 y); -fxn16 Q_N_S_div(u8 s, fxn16 x, fxn16 y); -fx32 Q_24_8_div(fx32 x, fx32 y); +s16 Q_8_8_div(s16 x, s16 y); +s16 Q_N_S_div(u8 s, s16 x, s16 y); +s32 Q_24_8_div(s32 x, s32 y); // 1.0 / y -fx16 Q_8_8_inv(fx16 y); -fxn16 Q_N_S_inv(u8 s, fxn16 y); -fx32 Q_24_8_inv(fx32 y); +s16 Q_8_8_inv(s16 y); +s16 Q_N_S_inv(u8 s, s16 y); +s32 Q_24_8_inv(s32 y); #endif //GUARD_MATH_UTIL_H diff --git a/src/math_util.c b/src/math_util.c index eff2fd7c0..767e4d93d 100644 --- a/src/math_util.c +++ b/src/math_util.c @@ -1,7 +1,7 @@ #include "global.h" #include "math_util.h" -fx16 Q_8_8_mul(fx16 x, fx16 y) +s16 Q_8_8_mul(s16 x, s16 y) { s32 result; @@ -11,7 +11,7 @@ fx16 Q_8_8_mul(fx16 x, fx16 y) return result; } -fxn16 Q_N_S_mul(u8 s, fxn16 x, fxn16 y) +s16 Q_N_S_mul(u8 s, s16 x, s16 y) { s32 result; @@ -21,7 +21,7 @@ fxn16 Q_N_S_mul(u8 s, fxn16 x, fxn16 y) return result; } -fx32 Q_24_8_mul(fx32 x, fx32 y) +s32 Q_24_8_mul(s32 x, s32 y) { s64 result; @@ -31,7 +31,7 @@ fx32 Q_24_8_mul(fx32 x, fx32 y) return result; } -fx16 Q_8_8_div(fx16 x, fx16 y) +s16 Q_8_8_div(s16 x, s16 y) { if (y == 0) { @@ -40,7 +40,7 @@ fx16 Q_8_8_div(fx16 x, fx16 y) return (x << 8) / y; } -fxn16 Q_N_S_div(u8 s, fxn16 x, fxn16 y) +s16 Q_N_S_div(u8 s, s16 x, s16 y) { if (y == 0) { @@ -49,7 +49,7 @@ fxn16 Q_N_S_div(u8 s, fxn16 x, fxn16 y) return (x << s) / y; } -fx32 Q_24_8_div(fx32 x, fx32 y) +s32 Q_24_8_div(s32 x, s32 y) { s64 _x; @@ -62,7 +62,7 @@ fx32 Q_24_8_div(fx32 x, fx32 y) return _x / y; } -fx16 Q_8_8_inv(fx16 y) +s16 Q_8_8_inv(s16 y) { s32 x; @@ -70,7 +70,7 @@ fx16 Q_8_8_inv(fx16 y) return x / y; } -fxn16 Q_N_S_inv(u8 s, fxn16 y) +s16 Q_N_S_inv(u8 s, s16 y) { s32 x; @@ -78,7 +78,7 @@ fxn16 Q_N_S_inv(u8 s, fxn16 y) return x / y; } -fx32 Q_24_8_inv(fx32 y) +s32 Q_24_8_inv(s32 y) { s64 x; From 5d9e161ae1ac63425b2ab3d2e7f5b072f182a081 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Fri, 28 May 2021 16:04:10 -0400 Subject: [PATCH 10/21] Port link_rfu_2 fakematch fix from Emerald --- src/link_rfu_2.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/link_rfu_2.c b/src/link_rfu_2.c index 8c7447264..c6c568551 100644 --- a/src/link_rfu_2.c +++ b/src/link_rfu_2.c @@ -887,7 +887,7 @@ static bool32 RfuProcessEnqueuedRecvBlock(void) static void HandleSendFailure(u8 unused, u32 flags) { - s32 i, j; + s32 i, j, temp; const u8 *r10 = Rfu.cmd_8800_sendbuf.payload; for (i = 0; i < Rfu.cmd_8800_sendbuf.count; i++) @@ -897,12 +897,14 @@ static void HandleSendFailure(u8 unused, u32 flags) sResendBlock16[0] = RFUCMD_0x8900 | i; for (j = 0; j < 7; j++) { - sResendBlock16[j + 1] = (r10[12 * i + (j << 1) + 1] << 8) | r10[12 * i + (j << 1) + 0]; + temp = j << 1; + sResendBlock16[j + 1] = (r10[12 * i + temp + 1] << 8) | r10[12 * i + temp + 0]; } for (j = 0; j < 7; j++) { - sResendBlock8[2 * j + 1] = sResendBlock16[j] >> 8; - sResendBlock8[2 * j + 0] = sResendBlock16[j]; + temp = j << 1; + sResendBlock8[temp + 1] = sResendBlock16[j] >> 8; + sResendBlock8[temp + 0] = sResendBlock16[j]; j++;j--; // Needed to match; } From e80a68327bcfd99995ce6016acb84e61afc293f4 Mon Sep 17 00:00:00 2001 From: Kurausukun Date: Mon, 31 May 2021 01:20:36 -0400 Subject: [PATCH 11/21] [LEAK-INFORMED] fix CreateShedinja fakematch --- include/pokemon.h | 1 - src/daycare.c | 2 ++ src/evolution_scene.c | 12 ++++-------- 3 files changed, 6 insertions(+), 9 deletions(-) diff --git a/include/pokemon.h b/include/pokemon.h index 075a50792..8348b1178 100644 --- a/include/pokemon.h +++ b/include/pokemon.h @@ -319,7 +319,6 @@ extern u8 gEnemyPartyCount; extern struct Pokemon gEnemyParty[PARTY_SIZE]; extern const struct BaseStats gBaseStats[]; extern const u8 *const gItemEffectTable[]; -extern const struct Evolution gEvolutionTable[][EVOS_PER_MON]; extern const u8 gStatStageRatios[][2]; extern struct SpriteTemplate gMultiuseSpriteTemplate; extern struct PokemonStorage* gPokemonStoragePtr; diff --git a/src/daycare.c b/src/daycare.c index 97190c1d6..e29c0fc70 100644 --- a/src/daycare.c +++ b/src/daycare.c @@ -32,6 +32,8 @@ // Combination of RSE's Day-Care (re-used on Four Island), FRLG's Day-Care, and egg_hatch.c +extern struct Evolution gEvolutionTable[][EVOS_PER_MON]; + struct EggHatchData { u8 eggSpriteID; diff --git a/src/evolution_scene.c b/src/evolution_scene.c index 0eb36b523..ffbec26ba 100644 --- a/src/evolution_scene.c +++ b/src/evolution_scene.c @@ -26,6 +26,8 @@ #include "constants/songs.h" #include "constants/pokemon.h" +extern struct Evolution gEvolutionTable[][EVOS_PER_MON]; + struct EvoInfo { u8 preEvoSpriteId; @@ -545,8 +547,6 @@ static void CreateShedinja(u16 preEvoSpecies, struct Pokemon* mon) { s32 i; struct Pokemon* shedinja = &gPlayerParty[gPlayerPartyCount]; - const struct Evolution *evos; - const struct Evolution *evos2; CopyMon(&gPlayerParty[gPlayerPartyCount], mon, sizeof(struct Pokemon)); SetMonData(&gPlayerParty[gPlayerPartyCount], MON_DATA_SPECIES, (&gEvolutionTable[preEvoSpecies][1].targetSpecies)); @@ -567,12 +567,8 @@ static void CreateShedinja(u16 preEvoSpecies, struct Pokemon* mon) CalculateMonStats(&gPlayerParty[gPlayerPartyCount]); CalculatePlayerPartyCount(); - // can't match it otherwise, ehh - evos2 = gEvolutionTable[0]; - evos = evos2 + EVOS_PER_MON * preEvoSpecies; - - GetSetPokedexFlag(SpeciesToNationalPokedexNum(evos[1].targetSpecies), FLAG_SET_SEEN); - GetSetPokedexFlag(SpeciesToNationalPokedexNum(evos[1].targetSpecies), FLAG_SET_CAUGHT); + GetSetPokedexFlag(SpeciesToNationalPokedexNum(gEvolutionTable[preEvoSpecies][1].targetSpecies), FLAG_SET_SEEN); + GetSetPokedexFlag(SpeciesToNationalPokedexNum(gEvolutionTable[preEvoSpecies][1].targetSpecies), FLAG_SET_CAUGHT); if (GetMonData(shedinja, MON_DATA_SPECIES) == SPECIES_SHEDINJA && GetMonData(shedinja, MON_DATA_LANGUAGE) == LANGUAGE_JAPANESE From 6580ac8739b799ba96827fb63a268d5d63d055eb Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Tue, 1 Jun 2021 15:55:14 -0400 Subject: [PATCH 12/21] Sync link_rfu_2 symbols from Emerald --- include/link.h | 8 +- include/link_rfu.h | 180 ++++---- src/cable_club.c | 4 +- src/link.c | 18 +- src/link_rfu_2.c | 947 +++++++++++++++++++++------------------- src/link_rfu_3.c | 116 ++--- src/mystery_gift_menu.c | 4 +- src/pokemon_jump_2.c | 2 +- src/union_room.c | 52 +-- src/union_room_chat.c | 24 +- 10 files changed, 717 insertions(+), 638 deletions(-) diff --git a/include/link.h b/include/link.h index 766bba919..564180b2b 100644 --- a/include/link.h +++ b/include/link.h @@ -65,7 +65,7 @@ #define LINKCMD_SEND_HELD_KEYS_2 0xCAFE #define LINKCMD_0xCCCC 0xCCCC -#define LINKTYPE_0x1111 0x1111 // trade +#define LINKTYPE_TRADE 0x1111 // trade #define LINKTYPE_0x1122 0x1122 // trade #define LINKTYPE_0x1133 0x1133 // trade #define LINKTYPE_0x1144 0x1144 // trade @@ -85,6 +85,8 @@ #define MASTER_HANDSHAKE 0x8FFF #define SLAVE_HANDSHAKE 0xB9A0 +#define IsSendCmdComplete() (gSendCmd[0] == 0) + enum { LINK_STATE_START0, @@ -280,9 +282,9 @@ bool8 IsWirelessAdapterConnected(void); bool8 Link_PrepareCmd0xCCCC_Rfu0xA100(u8 blockRequestType); void LinkVSync(void); bool8 HandleLinkConnection(void); -void PrepareLocalLinkPlayerBlock(void); +void LocalLinkPlayerToBlock(void); void LinkPlayerFromBlock(u32 who); -void SetLinkErrorFromRfu(u32 status, u8 lastSendQueueCount, u8 lastRecvQueueCount, u8 unk_06); +void SetLinkErrorFromRfu(u32 status, u8 lastSendQueueCount, u8 lastRecvQueueCount, u8 isConnectionError); u8 sub_800A8D4(void); void sub_800AA24(void); void sub_800A900(u8 a0); diff --git a/include/link_rfu.h b/include/link_rfu.h index 7d40776f3..03f9a1f06 100644 --- a/include/link_rfu.h +++ b/include/link_rfu.h @@ -3,19 +3,53 @@ #include "global.h" #include "librfu.h" +#include "link.h" #include "AgbRfu_LinkManager.h" #define RFUCMD_SEND_PACKET 0x2F00 #define RFUCMD_READY_CLOSE_LINK 0x5f00 #define RFUCMD_READY_EXIT_STANDBY 0x6600 -#define RFUCMD_0x7700 0x7700 -#define RFUCMD_0x7800 0x7800 -#define RFUCMD_0x8800 0x8800 -#define RFUCMD_0x8900 0x8900 +#define RFUCMD_PLAYERS_LIST 0x7700 +#define RFUCMD_PLAYERS_LIST_2 0x7800 +#define RFUCMD_SEND_BLOCK_INIT 0x8800 +#define RFUCMD_SEND_BLOCK_STEP 0x8900 #define RFUCMD_SEND_BLOCK_REQ 0xa100 #define RFUCMD_SEND_HELD_KEYS 0xbe00 -#define RFUCMD_0xED00 0xed00 -#define RFUCMD_0xEE00 0xee00 +#define RFUCMD_PARENT_DISCONNECT 0xed00 +#define RFUCMD_CHILD_DISCONNECT 0xee00 + +#define RFU_PACKET_SIZE 6 + +#define RFU_SERIAL_7F7D 0x7F7D + +#define RECV_QUEUE_NUM_SLOTS 20 +#define RECV_QUEUE_SLOT_LENGTH (14 * MAX_RFU_PLAYERS) + +#define SEND_QUEUE_NUM_SLOTS 40 +#define SEND_QUEUE_SLOT_LENGTH 14 + +#define BACKUP_QUEUE_NUM_SLOTS 2 +#define BACKUP_QUEUE_SLOT_LENGTH 14 + +#define RFU_PACKET_SIZE 6 + +#define RFU_STATUS_OK 0 +#define RFU_STATUS_FATAL_ERROR 1 +#define RFU_STATUS_CONNECTION_ERROR 2 +#define RFU_STATUS_CHILD_SEND_COMPLETE 3 +#define RFU_STATUS_NEW_CHILD_DETECTED 4 +#define RFU_STATUS_JOIN_GROUP_OK 5 +#define RFU_STATUS_JOIN_GROUP_NO 6 +#define RFU_STATUS_WAIT_ACK_JOIN_GROUP 7 +#define RFU_STATUS_LEAVE_GROUP_NOTICE 8 +#define RFU_STATUS_LEAVE_GROUP 9 +#define RFU_STATUS_10 10 +#define RFU_STATUS_11 11 +#define RFU_STATUS_ACK_JOIN_GROUP 12 + +#define RFU_RECV_IDLE 0 +#define RFU_RECV_RECEIVING 1 +#define RFU_RECV_FINISHED 2 // RfuTgtData.gname is read as these structs. struct GFtgtGnameSub @@ -53,20 +87,6 @@ struct Padded_U8 u8 value; }; -struct UnkLinkRfuStruct_02022B44 -{ - u8 fill_00[6]; - u16 unk_06; - u8 fill_08[6]; - vu8 unk_0e; - u8 unk_0f; - u8 fill_10[0x54]; - u16 unk_64; - u8 fill_66[0x1d]; - u8 unk_83; - u8 fill_84[0x58]; -}; - struct RfuBlockSend { /* 0x00 */ u16 next; @@ -79,9 +99,9 @@ struct RfuBlockSend /* 0x12 */ u8 receiving; }; -struct UnkRfuStruct_2_Sub_124 +struct RfuRecvQueue { - /* 0x000 */ u8 slots[20][70]; + /* 0x000 */ u8 slots[RECV_QUEUE_NUM_SLOTS][RECV_QUEUE_SLOT_LENGTH]; /* 0x578 */ vu8 recv_slot; /* 0x579 */ vu8 send_slot; /* 0x57a */ vu8 count; @@ -90,16 +110,16 @@ struct UnkRfuStruct_2_Sub_124 struct RfuSendQueue { - /* 0x000 */ u8 slots[40][14]; + /* 0x000 */ u8 slots[SEND_QUEUE_NUM_SLOTS][SEND_QUEUE_SLOT_LENGTH]; /* 0x230 */ vu8 recv_slot; /* 0x231 */ vu8 send_slot; /* 0x232 */ vu8 count; /* 0x233 */ vu8 full; }; -struct UnkRfuStruct_2_Sub_c1c +struct RfuBackupQueue { - /* 0x00 */ u8 slots[2][14]; + /* 0x00 */ u8 slots[BACKUP_QUEUE_NUM_SLOTS][BACKUP_QUEUE_SLOT_LENGTH]; /* 0x1c */ vu8 recv_slot; /* 0x1d */ vu8 send_slot; /* 0x1e */ vu8 count; @@ -125,57 +145,57 @@ typedef struct UnkRfuStruct_2 /* 0x00e */ u8 unk_0e; /* 0x00f */ u8 unk_0f; /* 0x010 */ u16 linkman_param[2]; - /* 0x014 */ u8 unk_14[RFU_CHILD_MAX][14]; - /* 0x04c */ u8 unk_4c[14]; + /* 0x014 */ u8 main_UNI_recvBuffer[RFU_CHILD_MAX][14]; + /* 0x04c */ u8 lastCmdBeforeCommInterrupt[14]; /* 0x05a */ u8 cmdA100_blockRequestType; - /* 0x05b */ u8 unk_5b; - /* 0x05c */ u8 unk_5c[5]; - /* 0x061 */ u8 unk_61[5]; - /* 0x066 */ u8 unk_66; - /* 0x067 */ u8 unk_67; + /* 0x05b */ u8 sendBlockInitDelay; + /* 0x05c */ bool8 blockReceived[MAX_RFU_PLAYERS]; + /* 0x061 */ u8 numBlocksReceived[MAX_RFU_PLAYERS]; + /* 0x066 */ u8 idleTaskId; + /* 0x067 */ u8 searchTaskId; /* 0x068 */ u8 filler_68[4]; - /* 0x06c */ struct RfuBlockSend cmd_8800_sendbuf; - /* 0x080 */ struct RfuBlockSend cmd_8800_recvbuf[5]; - /* 0x0e4 */ u8 cmd5f00Ack[5]; - /* 0x0e9 */ u8 cmd_6600_recvd[5]; + /* 0x06c */ struct RfuBlockSend sendBlock; + /* 0x080 */ struct RfuBlockSend recvBlock[MAX_RFU_PLAYERS]; + /* 0x0e4 */ bool8 readyCloseLink[MAX_RFU_PLAYERS]; + /* 0x0e9 */ bool8 readyExitStandby[MAX_RFU_PLAYERS]; /* 0x0ee */ vu8 errorState; /* 0x0ef */ bool8 isShuttingDown; /* 0x0f0 */ u8 linkLossRecoveryState; - /* 0x0f1 */ u8 unk_f1; - /* 0x0f2 */ u16 unk_f2[6]; - /* 0x0fe */ u16 cmd_6600_timer; - /* 0x100 */ u16 cmd_6600_count; + /* 0x0f1 */ u8 status; + /* 0x0f2 */ u16 packet[RFU_PACKET_SIZE]; + /* 0x0fe */ u16 resendExitStandbyTimer; + /* 0x100 */ u16 resendExitStandbyCount; /* 0x102 */ u8 unk_102; - /* 0x104 */ struct RfuTgtData unk_104; - /* 0x124 */ struct UnkRfuStruct_2_Sub_124 unk_124; + /* 0x104 */ struct RfuTgtData tgtData; + /* 0x124 */ struct RfuRecvQueue recvQueue; /* 0x6a0 */ struct RfuSendQueue sendQueue; - /* 0x8d4 */ struct UnkRfuStruct_2_Sub_c1c unk_c1c; - /* 0x8f4 */ vu8 unk_c3c; + /* 0x8d4 */ struct RfuBackupQueue backupQueue; + /* 0x8f4 */ vu8 linkRecovered; /* 0x8f5 */ u8 reconnectedParentIdx; /* 0x8f6 */ vu8 child_slot; /* 0x8f7 */ u8 unk_c3f[70]; - /* 0x93d */ u8 unk_c85; - /* 0x93e */ u8 unk_c86; - /* 0x93f */ u8 recvCmds[5][7][2]; + /* 0x93d */ u8 sendStatus; + /* 0x93e */ u8 recvStatus; + /* 0x93f */ u8 recvCmds[MAX_RFU_PLAYERS][7][2]; /* 0x985 */ u8 parentId; - /* 0x986 */ u8 unk_cce; // childId + /* 0x986 */ u8 multiplayerId; // childId /* 0x987 */ u8 unk_ccf; - /* 0x988 */ vu8 unk_cd0; - /* 0x989 */ u8 unk_cd1[RFU_CHILD_MAX]; - /* 0x98d */ u8 unk_cd5[RFU_CHILD_MAX]; - /* 0x991 */ u8 unk_cd9; + /* 0x988 */ vu8 sem_UNI_SendRecv; + /* 0x989 */ u8 partnerSendStatuses[RFU_CHILD_MAX]; + /* 0x98d */ u8 partnerRecvStatuses[RFU_CHILD_MAX]; + /* 0x991 */ u8 linkClosing; /* 0x992 */ u8 unk_cda; - /* 0x993 */ vu8 unk_cdb; - /* 0x994 */ vu8 unk_cdc; + /* 0x993 */ volatile bool8 unk_cdb; + /* 0x994 */ volatile bool8 unk_cdc; /* 0x995 */ u8 unk_cdd; /* 0x996 */ u8 linkPlayerIdx[RFU_CHILD_MAX]; /* 0x99a */ u8 bm_PartnerFlags; /* 0x99b */ u8 bm_DisconnectSlot; /* 0x99c */ u8 unk_ce4; - /* 0x99d */ u8 unk_ce5; + /* 0x99d */ u8 bmChatLeaderMaybe; /* 0x99e */ u8 unionRoomChatters; /* 0x99f */ u8 acceptSlot_flag; - /* 0x9a0 */ bool8 unk_ce8; + /* 0x9a0 */ bool8 foundNewLeaderMaybe; /* 0x9a1 */ u8 unk_ce9; /* 0x9a2 */ u8 unk_cea[RFU_CHILD_MAX]; /* 0x9a6 */ u8 unk_cee[RFU_CHILD_MAX]; @@ -190,7 +210,7 @@ void AddTextPrinterToWindow1(const u8 *str); bool32 MG_PrintTextOnWindow1AndWaitButton(u8 * cmdPtr, const u8 * src); void LinkRfu_FatalError(void); void MG_DrawCheckerboardPattern(void); -void Rfu_BeginBuildAndSendCommand5F(void); +void Rfu_SetCloseLinkCallback(void); bool8 IsLinkRfuTaskFinished(void); void DestroyWirelessStatusIndicatorSprite(void); void MEvent_CreateTask_CardOrNewsWithFriend(u32 arg0); @@ -199,18 +219,18 @@ void MEvent_CreateTask_Leader(u32 arg0); void Rfu_SendPacket(void * data); u8 CreateTask_ListenToWireless(void); void LinkRfu_DestroyIdleTask(void); -void sub_80F86F4(void); +void InitRFUAPI(void); void sub_80FB128(bool32 a0); bool32 IsSendingKeysToRfu(void); -void Rfu_set_zero(void); +void ClearLinkRfuCallback(void); u8 GetRfuPlayerCount(void); void StartSendingKeysToRfu(void); u8 LinkRfu_GetMultiplayerId(void); bool32 Rfu_InitBlockSend(const u8 * src, size_t size); -bool8 LinkRfu_PrepareCmd0xA100(u8 blockRequestType); +bool8 Rfu_SendBlockRequest(u8 blockRequestType); u8 Rfu_GetBlockReceivedStatus(void); -void Rfu_SetBlockReceivedFlag(u8 who); -void Rfu_ResetBlockReceivedFlag(u8 who); +void Rfu_SetBlockReceivedFlag(u8 linkPlayerId); +void Rfu_ResetBlockReceivedFlag(u8 linkPlayerId); bool8 Rfu_IsMaster(void); void ResetLinkRfuGFLayer(void); bool32 LinkRfuMain1(void); @@ -219,34 +239,34 @@ bool32 IsRfuRecvQueueEmpty(void); u32 GetRfuRecvQueueLength(void); void LinkRfu_Shutdown(void); void LinkRfu_CreateIdleTask(void); -bool8 ToggleLMANlinkRecovery(bool32 a0); +bool8 ToggleLMANlinkRecovery(bool32 enable); void var_800D_set_xB(void); struct GFtgtGname *GetHostRFUtgtGname(void); void UpdateWirelessStatusIndicatorSprite(void); void InitRFU(void); -bool32 RfuIsErrorStatus1or2(void); +bool32 RfuHasErrored(void); -void RFU_queue_20_70_reset(struct UnkRfuStruct_2_Sub_124 *ptr); -void RFU_queue_40_14_reset(struct RfuSendQueue *ptr); +void RfuRecvQueue_Reset(struct RfuRecvQueue *ptr); +void RfuSendQueue_Reset(struct RfuSendQueue *ptr); -void RfuSetErrorStatus(u8 a0, u16 msg); -u8 RfuGetErrorStatus(void); -void RFU_queue_20_70_recv(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2); -bool8 RFU_queue_40_14_send(struct RfuSendQueue *q1, u8 *q2); -bool8 RFU_queue_2_14_send(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2); -void RFU_queue_2_14_recv(struct UnkRfuStruct_2_Sub_c1c *q1, const u8 *q2); -bool8 RFU_queue_20_70_send(struct UnkRfuStruct_2_Sub_124 * a0, u8 *a1); -void RFU_queue_40_14_recv(struct RfuSendQueue * a0, u8 *a1); +void RfuSetStatus(u8 status, u16 msg); +u8 RfuGetStatus(void); +void RfuRecvQueue_Enqueue(struct RfuRecvQueue *q1, u8 *q2); +bool8 RfuSendQueue_Dequeue(struct RfuSendQueue *q1, u8 *q2); +bool8 RfuBackupQueue_Dequeue(struct RfuBackupQueue *q1, u8 *q2); +void RfuBackupQueue_Enqueue(struct RfuBackupQueue *q1, const u8 *q2); +bool8 RfuRecvQueue_Dequeue(struct RfuRecvQueue * a0, u8 *a1); +void RfuSendQueue_Enqueue(struct RfuSendQueue * a0, u8 *a1); void InitHostRFUtgtGname(struct GFtgtGname *data, u8 activity, bool32 started, s32 child_sprite_genders); void UpdateGameData_GroupLockedIn(bool8 started); -bool32 RfuSerialNumberIsValid(u32 a0); -bool8 sub_80FC1B0(void); +bool32 IsRfuSerialNumberValid(u32 serialNo); +bool8 IsRfuRecoveringFromLinkLoss(void); bool8 LmanAcceptSlotFlagIsNotZero(void); void LinkRfu_StopManagerAndFinalizeSlots(void); bool32 sub_80FA5D4(void); bool32 sub_80FC1CC(void); bool32 WaitRfuState(bool32 a0); -bool32 TrainerIdAndNameStillInPartnersList(u16 trainerId, const u8 *trainerName); +bool32 CheckTrainerHasLeftByIdAndName(u16 trainerId, const u8 *trainerName); void SendByteToPartnerByIdAndName(u8 a0, u16 a1, const u8 *a2); u32 WaitSendByteToPartnerByIdAndName(u16 a0, const u8 *a1); void SetHostRFUtgtGname(u8 activity, u32 child_sprite_genders, u32 a2); @@ -254,7 +274,7 @@ void InitializeRfuLinkManager_LinkLeader(u32 availSlots); void RequestDisconnectSlotByTrainerNameAndId(const u8 *trainerName, u16 trainerId); void LinkRfu3_SetGnameUnameFromStaticBuffers(struct GFtgtGname *gname, u8 *uname); void InitializeRfuLinkManager_JoinGroup(void); -void LinkRfuNIsend8(void); +void SendLeaveGroupNotice(void); void CreateTask_RfuReconnectWithParent(const u8 *src, u16 trainerId); void UpdateGameDataWithActivitySpriteGendersFlag(u8 activity, u32 child_sprite_genders, u32 started); void RecordMixTrainerNames(void); @@ -271,8 +291,8 @@ void sub_80FC114(const u8 *name, struct GFtgtGname *structPtr, u8 a2); bool32 PlayerHasMetTrainerBefore(u16 id, u8 *name); bool8 LinkRfu_GetNameIfCompatible(struct GFtgtGname *gname, u8 *uname, u8 idx); bool8 LinkRfu_GetNameIfSerial7F7D(struct GFtgtGname *gname, u8 *uname, u8 idx); -bool32 GetRfuUnkCE8(void); -void sub_80FA4A8(void); +bool32 RfuHasFoundNewLeader(void); +void Rfu_UnionRoomChat_StopLinkManager(void); void sub_80FB9D0(void); void sub_80FB030(u32 a0); void ClearRecvCommands(void); diff --git a/src/cable_club.c b/src/cable_club.c index 34b023281..c3de9dd26 100644 --- a/src/cable_club.c +++ b/src/cable_club.c @@ -516,7 +516,7 @@ u8 CreateTask_ReestablishLinkInCableClubRoom(void) gLinkType = LINKTYPE_MULTI_BATTLE; break; case USING_TRADE_CENTER: - gLinkType = LINKTYPE_0x1111; + gLinkType = LINKTYPE_TRADE; break; case USING_RECORD_CORNER: gLinkType = LINKTYPE_0x3322; @@ -859,7 +859,7 @@ static void Task_StartWirelessCableClubTrade(u8 taskId) case 0: ScriptContext2_Enable(); FadeScreen(FADE_TO_BLACK, 0); - Rfu_set_zero(); + ClearLinkRfuCallback(); data[0]++; break; case 1: diff --git a/src/link.c b/src/link.c index d3c0cccec..8122aafc0 100644 --- a/src/link.c +++ b/src/link.c @@ -226,7 +226,7 @@ bool8 IsWirelessAdapterConnected(void) return FALSE; SetWirelessCommType1(); - sub_80F86F4(); + InitRFUAPI(); sub_80FB128(TRUE); if (rfu_LMAN_REQBN_softReset_and_checkID() == RFU_ID) { @@ -378,7 +378,7 @@ void OpenLink(void) } else { - sub_80F86F4(); + InitRFUAPI(); } gReceivedRemoteLinkPlayers = FALSE; for (i = 0; i < MAX_LINK_PLAYERS; i++) @@ -749,7 +749,7 @@ void ClearLinkCallback_2(void) { if (gWirelessCommType) { - Rfu_set_zero(); + ClearLinkRfuCallback(); } else { @@ -1003,7 +1003,7 @@ bool8 Link_PrepareCmd0xCCCC_Rfu0xA100(u8 blockRequestType) { if (gWirelessCommType == 1) { - return LinkRfu_PrepareCmd0xA100(blockRequestType); + return Rfu_SendBlockRequest(blockRequestType); } if (gLinkCallback == NULL) { @@ -1309,7 +1309,7 @@ void Link_StartSend5FFFwithParam(u16 a0) { if (gWirelessCommType == 1) { - Rfu_BeginBuildAndSendCommand5F(); + Rfu_SetCloseLinkCallback(); } else { @@ -1326,7 +1326,7 @@ void SetCloseLinkCallback(void) { if (gWirelessCommType == 1) { - Rfu_BeginBuildAndSendCommand5F(); + Rfu_SetCloseLinkCallback(); } else { @@ -1441,12 +1441,12 @@ static void CheckErrorStatus(void) } } -void SetLinkErrorFromRfu(u32 status, u8 lastSendQueueCount, u8 lastRecvQueueCount, u8 unk_06) +void SetLinkErrorFromRfu(u32 status, u8 lastSendQueueCount, u8 lastRecvQueueCount, u8 isConnectionError) { sLinkErrorBuffer.status = status; sLinkErrorBuffer.lastSendQueueCount = lastSendQueueCount; sLinkErrorBuffer.lastRecvQueueCount = lastRecvQueueCount; - sLinkErrorBuffer.unk_06 = unk_06; + sLinkErrorBuffer.unk_06 = isConnectionError; } void CB2_LinkError(void) @@ -1619,7 +1619,7 @@ bool8 HasLinkErrorOccurred(void) return gLinkErrorOccurred; } -void PrepareLocalLinkPlayerBlock(void) +void LocalLinkPlayerToBlock(void) { struct LinkPlayerBlock * block; diff --git a/src/link_rfu_2.c b/src/link_rfu_2.c index c6c568551..8b37c5214 100644 --- a/src/link_rfu_2.c +++ b/src/link_rfu_2.c @@ -20,8 +20,22 @@ struct SioInfo u8 fill_a0[0x5c]; }; -static EWRAM_DATA struct InitializeParametersTag sRfuReqConfig = {}; -static EWRAM_DATA struct UnkLinkRfuStruct_02022B44 gUnknown_203AC08 = {}; +struct RfuDebug +{ + u8 fill_00[6]; + u16 unk_06; + u8 fill_08[6]; + vu8 unk_0e; + u8 unk_0f; + u8 fill_10[0x54]; + u16 unk_64; + u8 fill_66[0x1d]; + u8 unk_83; + u8 fill_84[0x58]; +}; + +static EWRAM_DATA INIT_PARAM sRfuReqConfig = {}; +static EWRAM_DATA struct RfuDebug sRfuDebug = {}; static u32 gf_rfu_REQ_api[RFU_API_BUFF_SIZE_RAM / 4]; static u8 sResendBlock8[14]; @@ -35,18 +49,18 @@ static void sub_80F8AA4(void); static void sub_80F8AEC(void); static void MscCallback_Child(u16 a0); static void MSCCallback_SetUnkCDB(u16 a0); -static void sub_80F906C(void); +static void UpdateBackupQueue(void); static void RfuHandleReceiveCommand(u8 unused); static void ResetSendDataManager(struct RfuBlockSend *data); static void RfuPrepareSendBuffer(u16 command); -static void RfuFunc_HandleBlockSend(void); -static void RfuFunc_SendNextBlock(void); -static void RfuFunc_SendLastBlock(void); +static void HandleBlockSend(void); +static void SendNextBlock(void); +static void SendLastBlock(void); static void CallRfuFunc(void); -static void sub_80FA738(void); -static s32 sub_80FA788(void); +static void UpdateChildStatuses(void); +static s32 GetRfuRecvStatus(void); static void sub_80FA834(u8 taskId); -static void sub_80FA9D0(u16 a0); +static void ClearSelectedLinkPlayerIds(u16 disconnectMask); static void ValidateAndReceivePokemonSioInfo(void * a0); static void Task_ExchangeLinkPlayers(u8 taskId); static void sub_80FACF0(u8 taskId); @@ -57,10 +71,10 @@ static u8 GetPartnerIndexByNameAndTrainerID(const u8 *trainerName, u16 trainerId static void RfuReqDisconnectSlot(u32 bmDisconnectSlot); static void sub_80FBE20(u32 a0, u32 a1); static void sub_80FC028(u8 taskId); -static void rfu_dbg_clear(void); +static void Debug_PrintEmpty(void); static void Task_idle(u8 taskId); -static const struct InitializeParametersTag sRfuReqConfigTemplate = { +static const INIT_PARAM sRfuReqConfigTemplate = { .maxMFrame = 4, .MC_TimerCount = 32, .availSlot_flag = 0, @@ -115,21 +129,45 @@ static const u8 gUnknown_843EC38[] = { 2, 2, 3 }; -static const u8 gUnknown_843EC41[] = { - 0, 1, 1, 2, - 1, 2, 2, 3, - 1, 2, 2, 3, - 2, 3, 3, 4 +static const u8 sNumSetBits[] = { + [0x0] = 0, + [0x1] = 1, + [0x2] = 1, + [0x3] = 2, + [0x4] = 1, + [0x5] = 2, + [0x6] = 2, + [0x7] = 3, + [0x8] = 1, + [0x9] = 2, + [0xA] = 2, + [0xB] = 3, + [0xC] = 2, + [0xD] = 3, + [0xE] = 3, + [0xF] = 4 }; -static const u8 gUnknown_843EC51[] = { - 0, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0 +static const u8 sNumTrailingZeroes[] = { + [0x0] = 0, + [0x1] = 0, + [0x2] = 1, + [0x3] = 0, + [0x4] = 2, + [0x5] = 0, + [0x6] = 1, + [0x7] = 0, + [0x8] = 3, + [0x9] = 0, + [0xA] = 1, + [0xB] = 0, + [0xC] = 2, + [0xD] = 0, + [0xE] = 1, + [0xF] = 0 }; -static const struct { - u8 *buffer; - u32 size; -} gUnknown_843EC64[] = { +static const struct BlockRequest sBlockRequests[] = { { gBlockSendBuffer, 200 }, { gBlockSendBuffer, 200 }, { gBlockSendBuffer, 100 }, @@ -139,7 +177,7 @@ static const struct { static const u16 sAcceptedSerialNos[] = { 0x0002, // Pokemon FR/LG/EM - 0x7f7d, + RFU_SERIAL_7F7D, 0xFFFF }; @@ -171,12 +209,12 @@ static const TaskFunc gUnknown_843ED88[] = { sub_80FACF0 }; -static void rfu_dbg_print_str(const void *string, u8 x, u8 y) +static void Debug_PrintString(const void *string, u8 x, u8 y) { // debug? } -static void rfu_dbg_print_num(u16 num, u8 x, u8 y, u8 ndigits) +static void Debug_PrintNum(u16 num, u8 x, u8 y, u8 ndigits) { } @@ -192,13 +230,13 @@ void ResetLinkRfuGFLayer(void) { Rfu.errorState = 0; } - for (i = 0; i < 5; i++) + for (i = 0; i < MAX_RFU_PLAYERS; i++) { - ResetSendDataManager(Rfu.cmd_8800_recvbuf + i); + ResetSendDataManager(&Rfu.recvBlock[i]); } - ResetSendDataManager(&Rfu.cmd_8800_sendbuf); - RFU_queue_20_70_reset(&Rfu.unk_124); - RFU_queue_40_14_reset(&Rfu.sendQueue); + ResetSendDataManager(&Rfu.sendBlock); + RfuRecvQueue_Reset(&Rfu.recvQueue); + RfuSendQueue_Reset(&Rfu.sendQueue); CpuFill16(0, gSendCmd, sizeof gSendCmd); CpuFill16(0, gRecvCmds, sizeof gRecvCmds); CpuFill16(0, gLinkPlayers, sizeof gLinkPlayers); @@ -208,7 +246,7 @@ void InitRFU(void) { IntrFunc serialIntr = gIntrTable[1]; IntrFunc timerIntr = gIntrTable[2]; - sub_80F86F4(); + InitRFUAPI(); rfu_REQ_stopMode(); rfu_waitREQComplete(); REG_IME = 0; @@ -217,11 +255,12 @@ void InitRFU(void) REG_IME = INTR_FLAG_VBLANK; } -void sub_80F86F4(void) +void InitRFUAPI(void) { if (!rfu_initializeAPI(gf_rfu_REQ_api, RFU_API_BUFF_SIZE_RAM, gIntrTable + 1, TRUE)) { gLinkType = 0; + // ClearSavedLinkPlayers(); // Em fix sub_80FB128(FALSE); ResetLinkRfuGFLayer(); rfu_setTimerInterrupt(3, gIntrTable + 2); @@ -230,7 +269,7 @@ void sub_80F86F4(void) static void Task_LinkLeaderSearchForChildren(u8 taskId) { - sub_80FA738(); + UpdateChildStatuses(); switch (Rfu.state) { case 0: @@ -248,13 +287,13 @@ static void Task_LinkLeaderSearchForChildren(u8 taskId) case 3: break; case 4: - rfu_LMAN_stopManager(0); + rfu_LMAN_stopManager(FALSE); Rfu.state = 5; break; case 5: break; case 18: - Rfu.unk_cdb = 0; + Rfu.unk_cdb = FALSE; rfu_LMAN_setMSCCallback(MSCCallback_SetUnkCDB); sub_80F8AA4(); sub_80F8AEC(); @@ -266,22 +305,24 @@ static void Task_LinkLeaderSearchForChildren(u8 taskId) } } -static u8 sub_80F886C(u8 idx) +static u8 CountTrailingZeroes(u8 acceptSlot) { - return gUnknown_843EC51[idx]; + return sNumTrailingZeroes[acceptSlot]; } -static void sub_80F887C(s32 r2, s32 r5) +static void ReassignPartnerIds(s32 before, s32 after) { u8 i; u8 r4 = 1; - s32 r1 = r2; + s32 beforeBak = before; s32 r6 = 0; - if (r5 == -1) + if (after == -1) { - for (i = 0; i < RFU_CHILD_MAX; r2 >>= 1, i++) + // First Time Init + // UB: linkPlayerIdx may be uninitialized + for (i = 0; i < RFU_CHILD_MAX; before >>= 1, i++) { - if (r2 & 1) + if (before & 1) { Rfu.linkPlayerIdx[i] = r4; r4++; @@ -290,13 +331,15 @@ static void sub_80F887C(s32 r2, s32 r5) } else { - for (i = 0; i < RFU_CHILD_MAX; r1 >>= 1, i++) + // Delete before flags + for (i = 0; i < RFU_CHILD_MAX; beforeBak >>= 1, i++) { - if (!(r1 & 1)) + if (!(beforeBak & 1)) { Rfu.linkPlayerIdx[i] = 0; } } + // Get highest retained index for (r4 = 4; r4 != 0; r4--) { for (i = 0; i < RFU_CHILD_MAX && Rfu.linkPlayerIdx[i] != r4; i++); @@ -305,9 +348,10 @@ static void sub_80F887C(s32 r2, s32 r5) r6 = r4; } } - for (r5 &= ~r2, i = 0; i < RFU_CHILD_MAX; r5 >>= 1, i++) + // Replace with new flags + for (after &= ~before, i = 0; i < RFU_CHILD_MAX; after >>= 1, i++) { - if (r5 & 1) + if (after & 1) { Rfu.linkPlayerIdx[i] = r6++; } @@ -337,13 +381,13 @@ static void Task_JoinGroupSearchForParent(u8 taskId) gTasks[taskId].data[1] = 10; break; case 11: - switch (sub_80FA788()) + switch (GetRfuRecvStatus()) { - case 5: + case RFU_STATUS_JOIN_GROUP_OK: Rfu.state = 12; break; - case 6: - case 9: + case RFU_STATUS_JOIN_GROUP_NO: + case RFU_STATUS_LEAVE_GROUP: rfu_LMAN_requestChangeAgbClockMaster(); Rfu.unk_ce4 = 2; DestroyTask(taskId); @@ -355,13 +399,13 @@ static void Task_JoinGroupSearchForParent(u8 taskId) u8 bmChildSlot = 1 << Rfu.child_slot; rfu_clearSlot(TYPE_NI_SEND | TYPE_NI_RECV, Rfu.child_slot); rfu_setRecvBuffer(TYPE_UNI, Rfu.child_slot, Rfu.unk_c3f, sizeof(Rfu.unk_c3f)); - rfu_UNI_setSendData(bmChildSlot, Rfu.unk_4c, sizeof(Rfu.unk_4c)); + rfu_UNI_setSendData(bmChildSlot, Rfu.lastCmdBeforeCommInterrupt, sizeof(Rfu.lastCmdBeforeCommInterrupt)); gTasks[taskId].data[1] = 8; DestroyTask(taskId); - if (gUnknown_203AC08.unk_0f == 0) + if (sRfuDebug.unk_0f == 0) { - rfu_dbg_clear(); - gUnknown_203AC08.unk_0f++; + Debug_PrintEmpty(); + sRfuDebug.unk_0f++; } CreateTask(sub_80FA834, 5); break; @@ -377,7 +421,7 @@ static void sub_80F8AA4(void) { if (acceptSlot & 1) { - rfu_setRecvBuffer(TYPE_UNI, i, Rfu.unk_14[i], sizeof(Rfu.unk_14[i])); + rfu_setRecvBuffer(TYPE_UNI, i, Rfu.main_UNI_recvBuffer[i], sizeof(Rfu.main_UNI_recvBuffer[i])); rfu_clearSlot(TYPE_UNI_SEND | TYPE_UNI_RECV, i); } acceptSlot >>= 1; @@ -388,19 +432,19 @@ static void sub_80F8AEC(void) { u8 acceptSlot = lman.acceptSlot_flag; rfu_UNI_setSendData(acceptSlot, Rfu.recvCmds, sizeof(Rfu.recvCmds)); - Rfu.unk_cda = sub_80F886C(acceptSlot); + Rfu.unk_cda = CountTrailingZeroes(acceptSlot); Rfu.bm_PartnerFlags = acceptSlot; - sub_80F887C(acceptSlot, -1); + ReassignPartnerIds(acceptSlot, -1); Rfu.parent_child = MODE_PARENT; } static void Task_LinkRfu_UnionRoomListen(u8 taskId) { - if (GetHostRFUtgtGname()->activity == (ACTIVITY_PLYRTALK | IN_UNION_ROOM) && RfuGetErrorStatus() == 4) + if (GetHostRFUtgtGname()->activity == (ACTIVITY_PLYRTALK | IN_UNION_ROOM) && RfuGetStatus() == 4) { rfu_REQ_disconnect(lman.acceptSlot_flag); rfu_waitREQComplete(); - RfuSetErrorStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); } switch (Rfu.state) { @@ -412,14 +456,14 @@ static void Task_LinkRfu_UnionRoomListen(u8 taskId) case 1: break; case 17: - rfu_LMAN_establishConnection(2, 0, 240, (u16*)sAcceptedSerialNos); + rfu_LMAN_establishConnection(MODE_P_C_SWITCH, 0, 240, (u16*)sAcceptedSerialNos); rfu_LMAN_setMSCCallback(MscCallback_Child); Rfu.state = 18; break; case 18: break; case 13: - if (rfu_UNI_setSendData(1 << Rfu.child_slot, Rfu.unk_4c, sizeof(Rfu.unk_4c)) == 0) + if (rfu_UNI_setSendData(1 << Rfu.child_slot, Rfu.lastCmdBeforeCommInterrupt, sizeof(Rfu.lastCmdBeforeCommInterrupt)) == 0) { Rfu.parent_child = MODE_CHILD; DestroyTask(taskId); @@ -440,7 +484,7 @@ static void Task_LinkRfu_UnionRoomListen(u8 taskId) case 15: break; case 16: - Rfu.unk_cdb = 0; + Rfu.unk_cdb = FALSE; rfu_LMAN_setMSCCallback(MSCCallback_SetUnkCDB); UpdateGameData_GroupLockedIn(1); sub_80F8AA4(); @@ -449,7 +493,7 @@ static void Task_LinkRfu_UnionRoomListen(u8 taskId) gTasks[taskId].data[1] = 8; Rfu.parent_child = MODE_PARENT; CreateTask(sub_80FA834, 5); - Rfu.unk_ce8 = TRUE; + Rfu.foundNewLeaderMaybe = TRUE; DestroyTask(taskId); break; } @@ -462,25 +506,25 @@ void LinkRfu_CreateConnectionAsParent(void) void LinkRfu_StopManagerBeforeEnteringChat(void) { - rfu_LMAN_stopManager(0); + rfu_LMAN_stopManager(FALSE); } static void MscCallback_Child(u16 unused) { s32 i; - for (i = 0; i < 14; i++) + for (i = 0; i < BACKUP_QUEUE_SLOT_LENGTH; i++) { - Rfu.unk_4c[i] = 0; + Rfu.lastCmdBeforeCommInterrupt[i] = 0; } rfu_REQ_recvData(); rfu_waitREQComplete(); if (gRfuSlotStatusUNI[Rfu.child_slot]->recv.newDataFlag) { - Rfu.unk_cd0++; - RFU_queue_20_70_recv(&Rfu.unk_124, Rfu.unk_c3f); - gUnknown_203AC08.unk_06++; - sub_80F906C(); + Rfu.sem_UNI_SendRecv++; + RfuRecvQueue_Enqueue(&Rfu.recvQueue, Rfu.unk_c3f); + sRfuDebug.unk_06++; + UpdateBackupQueue(); rfu_UNI_readySendData(Rfu.child_slot); rfu_UNI_clearRecvNewDataFlag(Rfu.child_slot); } @@ -489,7 +533,7 @@ static void MscCallback_Child(u16 unused) static void MSCCallback_SetUnkCDB(u16 unused) { - Rfu.unk_cdb = 1; + Rfu.unk_cdb = TRUE; } void LinkRfu_Shutdown(void) @@ -504,7 +548,7 @@ void LinkRfu_Shutdown(void) { if (FuncIsActiveTask(Task_LinkLeaderSearchForChildren) == TRUE) { - DestroyTask(Rfu.unk_67); + DestroyTask(Rfu.searchTaskId); ResetLinkRfuGFLayer(); } } @@ -512,7 +556,7 @@ void LinkRfu_Shutdown(void) { if (FuncIsActiveTask(Task_JoinGroupSearchForParent) == TRUE) { - DestroyTask(Rfu.unk_67); + DestroyTask(Rfu.searchTaskId); ResetLinkRfuGFLayer(); } } @@ -520,7 +564,7 @@ void LinkRfu_Shutdown(void) { if (FuncIsActiveTask(Task_LinkRfu_UnionRoomListen) == TRUE) { - DestroyTask(Rfu.unk_67); + DestroyTask(Rfu.searchTaskId); ResetLinkRfuGFLayer(); } } @@ -537,10 +581,10 @@ static void CreateTask_LinkLeaderSearchForChildren(void) { if (QL_IS_PLAYBACK_STATE) return; - Rfu.unk_67 = CreateTask(Task_LinkLeaderSearchForChildren, 1); + Rfu.searchTaskId = CreateTask(Task_LinkLeaderSearchForChildren, 1); } -static bool8 RfuStateIs7AndPlayerIsChild(void) +static bool8 ContactedByParentAttemptingToReconnect(void) { if (Rfu.state == 7 && Rfu.parentId) { @@ -563,7 +607,7 @@ static void CreateTask_JoinGroupSearchForParent(void) { if (QL_IS_PLAYBACK_STATE) return; - Rfu.unk_67 = CreateTask(Task_JoinGroupSearchForParent, 1); + Rfu.searchTaskId = CreateTask(Task_JoinGroupSearchForParent, 1); } bool8 LmanAcceptSlotFlagIsNotZero(void) @@ -596,6 +640,7 @@ void sub_80F8FA0(void) Rfu.state = 14; } +UNUSED static void sub_80F8FAC(u8 a0) { u8 i; @@ -611,14 +656,14 @@ static void sub_80F8FAC(u8 a0) } } -static void sub_80F8FD4(void) +static void MoveRecvCmdsToRfuBuffer(void) { s32 i, j; - for (i = 0; i < 5; i++) + for (i = 0; i < MAX_RFU_PLAYERS; i++) { GF_RFU_MANAGER *ptr = &Rfu; - for (j = 0; j < 7; j++) + for (j = 0; j < CMD_LENGTH - 1; j++) { ptr->recvCmds[i][j][1] = gRecvCmds[i][j] >> 8; ptr->recvCmds[i][j][0] = gRecvCmds[i][j]; @@ -627,37 +672,37 @@ static void sub_80F8FD4(void) CpuFill16(0, gRecvCmds, sizeof gRecvCmds); } -static void sub_80F9038(void) +static void MoveSendCmdToFirstRecvCmd(void) { s32 i; - for (i = 0; i < 7; i++) + for (i = 0; i < CMD_LENGTH - 1; i++) { gRecvCmds[0][i] = gSendCmd[i]; } - for (i = 0; i < 7; i++) + for (i = 0; i < CMD_LENGTH - 1; i++) { gSendCmd[i] = 0; } } -static void sub_80F906C(void) +static void UpdateBackupQueue(void) { - if (Rfu.unk_c3c) + if (Rfu.linkRecovered) { - u8 r2 = RFU_queue_2_14_send(&Rfu.unk_c1c, Rfu.unk_4c); - if (Rfu.unk_c1c.count == 0) + bool8 backupEmpty = RfuBackupQueue_Dequeue(&Rfu.backupQueue, Rfu.lastCmdBeforeCommInterrupt); + if (Rfu.backupQueue.count == 0) { - Rfu.unk_c3c = 0; + Rfu.linkRecovered = FALSE; } - if (r2) + if (backupEmpty) { return; } } - if (Rfu.unk_c3c == 0) + if (!Rfu.linkRecovered) { - RFU_queue_40_14_send(&Rfu.sendQueue, Rfu.unk_4c); - RFU_queue_2_14_recv(&Rfu.unk_c1c, Rfu.unk_4c); + RfuSendQueue_Dequeue(&Rfu.sendQueue, Rfu.lastCmdBeforeCommInterrupt); + RfuBackupQueue_Enqueue(&Rfu.backupQueue, Rfu.lastCmdBeforeCommInterrupt); } } @@ -670,9 +715,9 @@ bool32 IsRfuRecvQueueEmpty(void) { return FALSE; } - for (i = 0; i < 5; i++) + for (i = 0; i < MAX_RFU_PLAYERS; i++) { - for (j = 0; j < 7; j++) + for (j = 0; j < CMD_LENGTH - 1; j++) { if (gRecvCmds[i][j] != 0) { @@ -693,7 +738,7 @@ static bool32 sub_80F911C(void) } else { - Rfu.unk_cdb = 0; + Rfu.unk_cdb = FALSE; if ((Rfu.bm_PartnerFlags & gRfuLinkStatus->connSlotFlag) == Rfu.bm_PartnerFlags && (Rfu.bm_PartnerFlags & gRfuLinkStatus->connSlotFlag)) { if (!Rfu.unk_cdc) @@ -704,7 +749,7 @@ static bool32 sub_80F911C(void) Rfu.bm_DisconnectSlot = 0; if (Rfu.unk_ce4 == 1) { - RfuSetErrorStatus(2, 0x8000); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x8000); GetLinkmanErrorParams(0x8000); return FALSE; } @@ -715,7 +760,7 @@ static bool32 sub_80F911C(void) return FALSE; } } - sub_80F8FD4(); + MoveRecvCmdsToRfuBuffer(); rfu_UNI_readySendData(Rfu.unk_cda); rfu_LMAN_REQ_sendData(TRUE); } @@ -723,7 +768,7 @@ static bool32 sub_80F911C(void) { rfu_REQ_PARENT_resumeRetransmitAndChange(); } - Rfu.unk_0e = 1; + Rfu.unk_0e = TRUE; } } return FALSE; @@ -737,10 +782,10 @@ static bool32 sub_80F9204(void) u16 j; u8 retval; - if (Rfu.state >= 20 && Rfu.unk_0e == 1) + if (Rfu.state >= 20 && Rfu.unk_0e == TRUE) { rfu_waitREQComplete(); - while (Rfu.unk_cdb == 0) + while (!Rfu.unk_cdb) { if (Rfu.errorState != 0) { @@ -752,30 +797,30 @@ static bool32 sub_80F9204(void) if ((lman.parentAck_flag & Rfu.bm_PartnerFlags) == Rfu.bm_PartnerFlags) { Rfu.unk_cdc = 0; - gUnknown_203AC08.unk_06++; + sRfuDebug.unk_06++; flags = lman.acceptSlot_flag; for (i = 0; i < RFU_CHILD_MAX; i++) { if (flags & 1) { - if (Rfu.unk_14[i][1]) + if (Rfu.main_UNI_recvBuffer[i][1]) { - if (Rfu.unk_cee[i] != 0xFF && (Rfu.unk_14[i][0] >> 5) != ((Rfu.unk_cee[i] + 1) & 7)) + if (Rfu.unk_cee[i] != 0xFF && (Rfu.main_UNI_recvBuffer[i][0] >> 5) != ((Rfu.unk_cee[i] + 1) & 7)) { if (++Rfu.unk_cea[i] > 4) GetLinkmanErrorParams(0x8100); } else { - Rfu.unk_cee[i] = Rfu.unk_14[i][0] / 32; + Rfu.unk_cee[i] = Rfu.main_UNI_recvBuffer[i][0] / 32; Rfu.unk_cea[i] = 0; - Rfu.unk_14[i][0] &= 0x1f; + Rfu.main_UNI_recvBuffer[i][0] &= 0x1f; r0 = Rfu.linkPlayerIdx[i]; for (j = 0; j < 7; j++) { - gRecvCmds[r0][j] = (Rfu.unk_14[i][(j << 1) + 1] << 8) | Rfu.unk_14[i][(j << 1) + 0]; - Rfu.unk_14[i][(j << 1) + 1] = 0; - Rfu.unk_14[i][(j << 1) + 0] = 0; + gRecvCmds[r0][j] = (Rfu.main_UNI_recvBuffer[i][(j << 1) + 1] << 8) | Rfu.main_UNI_recvBuffer[i][(j << 1) + 0]; + Rfu.main_UNI_recvBuffer[i][(j << 1) + 1] = 0; + Rfu.main_UNI_recvBuffer[i][(j << 1) + 0] = 0; } } } @@ -783,58 +828,58 @@ static bool32 sub_80F9204(void) } flags >>= 1; } - sub_80F9038(); + MoveSendCmdToFirstRecvCmd(); RfuHandleReceiveCommand(0); CallRfuFunc(); - if (Rfu.unk_ce5 && !Rfu.unk_cd9) + if (Rfu.bmChatLeaderMaybe && !Rfu.linkClosing) { - gUnknown_203AC08.unk_0e = 0; + sRfuDebug.unk_0e = FALSE; rfu_clearSlot(TYPE_UNI_SEND | TYPE_UNI_RECV, Rfu.unk_cda); for (i = 0; i < RFU_CHILD_MAX; i++) { - if ((Rfu.unk_ce5 >> i) & 1) + if ((Rfu.bmChatLeaderMaybe >> i) & 1) { - rfu_setRecvBuffer(TYPE_UNI, i, Rfu.unk_14[i], sizeof(Rfu.unk_14[i])); + rfu_setRecvBuffer(TYPE_UNI, i, Rfu.main_UNI_recvBuffer[i], sizeof(Rfu.main_UNI_recvBuffer[i])); } } - sub_80F887C(Rfu.bm_PartnerFlags, Rfu.bm_PartnerFlags | Rfu.unk_ce5); - Rfu.unk_ce9 = Rfu.unk_ce5; - Rfu.bm_PartnerFlags |= Rfu.unk_ce5; - Rfu.unk_ce5 = 0; + ReassignPartnerIds(Rfu.bm_PartnerFlags, Rfu.bm_PartnerFlags | Rfu.bmChatLeaderMaybe); + Rfu.unk_ce9 = Rfu.bmChatLeaderMaybe; + Rfu.bm_PartnerFlags |= Rfu.bmChatLeaderMaybe; + Rfu.bmChatLeaderMaybe = 0; rfu_UNI_setSendData(Rfu.bm_PartnerFlags, Rfu.recvCmds, sizeof(Rfu.recvCmds)); - Rfu.unk_cda = sub_80F886C(Rfu.bm_PartnerFlags); + Rfu.unk_cda = CountTrailingZeroes(Rfu.bm_PartnerFlags); CreateTask(Task_ExchangeLinkPlayers, 0); } } else { Rfu.unk_cdc = 1; - Rfu.unk_0e = 0; + Rfu.unk_0e = FALSE; } - Rfu.unk_0e = 0; + Rfu.unk_0e = FALSE; } retval = Rfu.unk_cdc; return gRfuLinkStatus->sendSlotUNIFlag ? retval & 1 : FALSE; } -static void sub_80F94BC(u16 *a0, u8 *a1) +static void RfuBufferSendCmd(u16 *sendCmd, u8 *rfuSendBuf) { s32 i; - if (a0[0]) + if (sendCmd[0]) { - a0[0] |= (Rfu.unk_102 << 5); + sendCmd[0] |= (Rfu.unk_102 << 5); Rfu.unk_102 = (Rfu.unk_102 + 1) & 7; for (i = 0; i < 7; i++) { - a1[2 * i + 1] = a0[i] >> 8; - a1[2 * i + 0] = a0[i]; + rfuSendBuf[2 * i + 1] = sendCmd[i] >> 8; + rfuSendBuf[2 * i + 0] = sendCmd[i]; } } else { for (i = 0; i < 14; i++) - a1[i] = 0; + rfuSendBuf[i] = 0; } } @@ -842,16 +887,16 @@ static bool32 RfuProcessEnqueuedRecvBlock(void) { u8 i; u8 j; - u8 sp00[MAX_RFU_PLAYERS * (2 * (CMD_LENGTH - 1))]; - u8 sp48[2 * (CMD_LENGTH - 1)]; - u8 switchval; + u8 recvBuf[MAX_RFU_PLAYERS * (2 * (CMD_LENGTH - 1))]; + u8 sendBuf[2 * (CMD_LENGTH - 1)]; + u8 status; - RFU_queue_20_70_send(&Rfu.unk_124, sp00); + RfuRecvQueue_Dequeue(&Rfu.recvQueue, recvBuf); for (i = 0; i < MAX_RFU_PLAYERS; i++) { for (j = 0; j < CMD_LENGTH - 1; j++) { - gRecvCmds[i][j] = (sp00[i * 14 + (j << 1) + 1] << 8) | sp00[i * 14 + (j << 1) + 0]; + gRecvCmds[i][j] = (recvBuf[i * 14 + (j << 1) + 1] << 8) | recvBuf[i * 14 + (j << 1) + 0]; } } RfuHandleReceiveCommand(0); @@ -859,26 +904,30 @@ static bool32 RfuProcessEnqueuedRecvBlock(void) { rfu_REQ_disconnect(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag); rfu_waitREQComplete(); - switchval = RfuGetErrorStatus(); - if (switchval != 1 && switchval != 6 && switchval != 9) - RfuSetErrorStatus(2, 0x9000); + status = RfuGetStatus(); + if ( + status != RFU_STATUS_FATAL_ERROR + && status != RFU_STATUS_JOIN_GROUP_NO + && status != RFU_STATUS_LEAVE_GROUP + ) + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x9000); rfu_clearAllSlot(); gReceivedRemoteLinkPlayers = FALSE; Rfu.RfuFunc = NULL; if (Rfu.unk_ce4 == 1) { - RfuSetErrorStatus(2, 0x9000); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x9000); GetLinkmanErrorParams(0x9000); } lman.state = lman.next_state = 0; Rfu.unk_ce4 = 0; } - if (Rfu.unk_cd0) + if (Rfu.sem_UNI_SendRecv) { - Rfu.unk_cd0--; + Rfu.sem_UNI_SendRecv--; CallRfuFunc(); - sub_80F94BC(gSendCmd, sp48); - RFU_queue_40_14_recv(&Rfu.sendQueue, sp48); + RfuBufferSendCmd(gSendCmd, sendBuf); + RfuSendQueue_Enqueue(&Rfu.sendQueue, sendBuf); for (i = 0; i < CMD_LENGTH - 1; i++) gSendCmd[i] = 0; } @@ -889,47 +938,45 @@ static void HandleSendFailure(u8 unused, u32 flags) { s32 i, j, temp; - const u8 *r10 = Rfu.cmd_8800_sendbuf.payload; - for (i = 0; i < Rfu.cmd_8800_sendbuf.count; i++) + const u8 *payload = Rfu.sendBlock.payload; + for (i = 0; i < Rfu.sendBlock.count; i++) { if (!(flags & 1)) { - sResendBlock16[0] = RFUCMD_0x8900 | i; + sResendBlock16[0] = RFUCMD_SEND_BLOCK_STEP | i; for (j = 0; j < 7; j++) { temp = j << 1; - sResendBlock16[j + 1] = (r10[12 * i + temp + 1] << 8) | r10[12 * i + temp + 0]; + sResendBlock16[j + 1] = (payload[12 * i + temp + 1] << 8) | payload[12 * i + temp + 0]; } for (j = 0; j < 7; j++) { temp = j << 1; sResendBlock8[temp + 1] = sResendBlock16[j] >> 8; sResendBlock8[temp + 0] = sResendBlock16[j]; - - j++;j--; // Needed to match; } - RFU_queue_40_14_recv(&Rfu.sendQueue, sResendBlock8); - Rfu.cmd_8800_sendbuf.failedFlags |= (1 << i); + RfuSendQueue_Enqueue(&Rfu.sendQueue, sResendBlock8); + Rfu.sendBlock.failedFlags |= (1 << i); } flags >>= 1; } } -void Rfu_SetBlockReceivedFlag(u8 a0) +void Rfu_SetBlockReceivedFlag(u8 linkPlayerId) { - if (Rfu.parent_child == MODE_PARENT && a0) - Rfu.unk_61[a0] = 1; + if (Rfu.parent_child == MODE_PARENT && linkPlayerId != 0) + Rfu.numBlocksReceived[linkPlayerId] = 1; else - Rfu.unk_5c[a0] = 1; + Rfu.blockReceived[linkPlayerId] = TRUE; } -void Rfu_ResetBlockReceivedFlag(u8 a0) +void Rfu_ResetBlockReceivedFlag(u8 linkPlayerId) { - Rfu.unk_5c[a0] = 0; - Rfu.cmd_8800_recvbuf[a0].receiving = 0; + Rfu.blockReceived[linkPlayerId] = FALSE; + Rfu.recvBlock[linkPlayerId].receiving = RFU_RECV_IDLE; } -static u8 sub_80F9770(const u8 *a0) +static u8 RfuChildSetReceivedPlayerOrder(const u8 *template) { u8 i; @@ -937,20 +984,20 @@ static u8 sub_80F9770(const u8 *a0) return FALSE; for (i = 0; i < RFU_CHILD_MAX; i++) { - Rfu.linkPlayerIdx[i] = a0[i]; + Rfu.linkPlayerIdx[i] = template[i]; } - return a0[Rfu.child_slot]; + return template[Rfu.child_slot]; } static void RfuFunc_SendKeysToRfu(void) { - static u8 gUnknown_3001188; + static u8 heldKeyCount; if (gReceivedRemoteLinkPlayers && gHeldKeyCodeToSend != LINK_KEY_CODE_NULL && gLinkTransferringData != TRUE) { - gUnknown_3001188++; - gHeldKeyCodeToSend |= (gUnknown_3001188 << 8); + heldKeyCount++; + gHeldKeyCodeToSend |= (heldKeyCount << 8); RfuPrepareSendBuffer(RFUCMD_SEND_HELD_KEYS); } } @@ -971,7 +1018,7 @@ void StartSendingKeysToRfu(void) Rfu.RfuFunc = RfuFunc_SendKeysToRfu; } -void Rfu_set_zero(void) +void ClearLinkRfuCallback(void) { Rfu.RfuFunc = NULL; } @@ -985,38 +1032,38 @@ static void RfuHandleReceiveCommand(u8 unused) { switch (gRecvCmds[i][0] & 0xff00) { - case RFUCMD_0x7800: + case RFUCMD_PLAYERS_LIST_2: if (Rfu.parent_child == MODE_CHILD && gReceivedRemoteLinkPlayers) return; // fallthrough - case RFUCMD_0x7700: + case RFUCMD_PLAYERS_LIST: if (gRfuLinkStatus->parentChild == MODE_CHILD) { Rfu.playerCount = gRecvCmds[i][1]; - Rfu.unk_cce = sub_80F9770((u8 *)(gRecvCmds[i] + 2)); + Rfu.multiplayerId = RfuChildSetReceivedPlayerOrder((u8 *)(gRecvCmds[i] + 2)); } break; - case RFUCMD_0x8800: - if (Rfu.cmd_8800_recvbuf[i].receiving == 0) + case RFUCMD_SEND_BLOCK_INIT: + if (Rfu.recvBlock[i].receiving == RFU_RECV_IDLE) { - Rfu.cmd_8800_recvbuf[i].next = 0; - Rfu.cmd_8800_recvbuf[i].count = gRecvCmds[i][1]; - Rfu.cmd_8800_recvbuf[i].owner = gRecvCmds[i][2]; - Rfu.cmd_8800_recvbuf[i].receivedFlags = 0; - Rfu.cmd_8800_recvbuf[i].receiving = 1; - Rfu.unk_5c[i] = 0; + Rfu.recvBlock[i].next = 0; + Rfu.recvBlock[i].count = gRecvCmds[i][1]; + Rfu.recvBlock[i].owner = gRecvCmds[i][2]; + Rfu.recvBlock[i].receivedFlags = 0; + Rfu.recvBlock[i].receiving = RFU_RECV_RECEIVING; + Rfu.blockReceived[i] = FALSE; } break; - case RFUCMD_0x8900: - if (Rfu.cmd_8800_recvbuf[i].receiving == 1) + case RFUCMD_SEND_BLOCK_STEP: + if (Rfu.recvBlock[i].receiving == RFU_RECV_RECEIVING) { - Rfu.cmd_8800_recvbuf[i].next = gRecvCmds[i][0] & 0xff; - Rfu.cmd_8800_recvbuf[i].receivedFlags |= (1 << Rfu.cmd_8800_recvbuf[i].next); + Rfu.recvBlock[i].next = gRecvCmds[i][0] & 0xff; + Rfu.recvBlock[i].receivedFlags |= (1 << Rfu.recvBlock[i].next); for (j = 0; j < 6; j++) - gBlockRecvBuffer[i][Rfu.cmd_8800_recvbuf[i].next * 6 + j] = gRecvCmds[i][j + 1]; - if (Rfu.cmd_8800_recvbuf[i].receivedFlags == sAllBlocksReceived[Rfu.cmd_8800_recvbuf[i].count]) + gBlockRecvBuffer[i][Rfu.recvBlock[i].next * 6 + j] = gRecvCmds[i][j + 1]; + if (Rfu.recvBlock[i].receivedFlags == sAllBlocksReceived[Rfu.recvBlock[i].count]) { - Rfu.cmd_8800_recvbuf[i].receiving = 2; + Rfu.recvBlock[i].receiving = RFU_RECV_FINISHED; Rfu_SetBlockReceivedFlag(i); if (GetHostRFUtgtGname()->activity == (ACTIVITY_CHAT | IN_UNION_ROOM) && gReceivedRemoteLinkPlayers && Rfu.parent_child == MODE_CHILD) ValidateAndReceivePokemonSioInfo(gBlockRecvBuffer); @@ -1024,16 +1071,16 @@ static void RfuHandleReceiveCommand(u8 unused) } break; case RFUCMD_SEND_BLOCK_REQ: - Rfu_InitBlockSend(gUnknown_843EC64[gRecvCmds[i][1]].buffer, (u16)gUnknown_843EC64[gRecvCmds[i][1]].size); + Rfu_InitBlockSend(sBlockRequests[gRecvCmds[i][1]].address, (u16)sBlockRequests[gRecvCmds[i][1]].size); break; case RFUCMD_READY_CLOSE_LINK: - Rfu.cmd5f00Ack[i] = 1; + Rfu.readyCloseLink[i] = TRUE; break; case RFUCMD_READY_EXIT_STANDBY: - if (Rfu.cmd_6600_count == gRecvCmds[i][1]) - Rfu.cmd_6600_recvd[i] = 1; + if (Rfu.resendExitStandbyCount == gRecvCmds[i][1]) + Rfu.readyExitStandby[i] = TRUE; break; - case RFUCMD_0xED00: + case RFUCMD_PARENT_DISCONNECT: if (Rfu.parent_child == MODE_CHILD) { if (gReceivedRemoteLinkPlayers) @@ -1045,61 +1092,61 @@ static void RfuHandleReceiveCommand(u8 unused) Rfu.unk_ce4 = gRecvCmds[i][2]; } Rfu.playerCount = gRecvCmds[i][3]; - sub_80FA9D0(gRecvCmds[i][1]); + ClearSelectedLinkPlayerIds(gRecvCmds[i][1]); } } else { - RfuPrepareSendBuffer(RFUCMD_0xEE00); + RfuPrepareSendBuffer(RFUCMD_CHILD_DISCONNECT); gSendCmd[1] = gRecvCmds[i][1]; gSendCmd[2] = gRecvCmds[i][2]; gSendCmd[3] = gRecvCmds[i][3]; } break; - case RFUCMD_0xEE00: + case RFUCMD_CHILD_DISCONNECT: if (Rfu.parent_child == MODE_PARENT) { Rfu.bm_DisconnectSlot |= gRecvCmds[i][1]; Rfu.unk_ce4 = gRecvCmds[i][2]; - sub_80FA9D0(gRecvCmds[i][1]); + ClearSelectedLinkPlayerIds(gRecvCmds[i][1]); } break; case RFUCMD_SEND_HELD_KEYS: gLinkPartnersHeldKeys[i] = gRecvCmds[i][1]; break; } - if (Rfu.parent_child == MODE_PARENT && Rfu.unk_61[i]) + if (Rfu.parent_child == MODE_PARENT && Rfu.numBlocksReceived[i]) { - if (Rfu.unk_61[i] == 4) + if (Rfu.numBlocksReceived[i] == 4) { - Rfu.unk_5c[i] = 1; - Rfu.unk_61[i] = 0; + Rfu.blockReceived[i] = TRUE; + Rfu.numBlocksReceived[i] = 0; } else - Rfu.unk_61[i]++; + Rfu.numBlocksReceived[i]++; } } } -static bool8 Cmd8000recvIsFinished(void) +static bool8 AreNoPlayersReceiving(void) { s32 i; for (i = 0; i < 5; i++) { - if (Rfu.cmd_8800_recvbuf[i].receiving) + if (Rfu.recvBlock[i].receiving != RFU_RECV_IDLE) return FALSE; } return TRUE; } -static bool8 sub_80F9C78(void) +static bool8 AreAllPlayersFinishedReceiving(void) { s32 i; for (i = 0; i < Rfu.playerCount; i++) { - if (Rfu.cmd_8800_recvbuf[i].receiving != 2 || Rfu.unk_5c[i] != 1) + if (Rfu.recvBlock[i].receiving != RFU_RECV_FINISHED || Rfu.blockReceived[i] != TRUE) return FALSE; } return TRUE; @@ -1113,7 +1160,7 @@ static void ResetSendDataManager(struct RfuBlockSend *data) data->receivedFlags = 0; data->sending = 0; data->owner = 0; - data->receiving = 0; + data->receiving = RFU_RECV_IDLE; } u8 Rfu_GetBlockReceivedStatus(void) @@ -1123,7 +1170,7 @@ u8 Rfu_GetBlockReceivedStatus(void) for (i = 0; i < 5; i++) { - if (Rfu.cmd_8800_recvbuf[i].receiving == 2 && Rfu.unk_5c[i] == 1) + if (Rfu.recvBlock[i].receiving == RFU_RECV_FINISHED && Rfu.blockReceived[i] == TRUE) { flags |= (1 << i); } @@ -1140,18 +1187,18 @@ static void RfuPrepareSendBuffer(u16 command) gSendCmd[0] = command; switch (command) { - case RFUCMD_0x8800: - gSendCmd[1] = Rfu.cmd_8800_sendbuf.count; - gSendCmd[2] = Rfu.cmd_8800_sendbuf.owner + 0x80; + case RFUCMD_SEND_BLOCK_INIT: + gSendCmd[1] = Rfu.sendBlock.count; + gSendCmd[2] = Rfu.sendBlock.owner + 0x80; break; case RFUCMD_SEND_BLOCK_REQ: - if (Cmd8000recvIsFinished()) + if (AreNoPlayersReceiving()) gSendCmd[1] = Rfu.cmdA100_blockRequestType; break; - case RFUCMD_0x7700: - case RFUCMD_0x7800: + case RFUCMD_PLAYERS_LIST: + case RFUCMD_PLAYERS_LIST_2: tmp = Rfu.bm_PartnerFlags ^ Rfu.bm_DisconnectSlot; - Rfu.playerCount = gUnknown_843EC41[tmp] + 1; + Rfu.playerCount = sNumSetBits[tmp] + 1; gSendCmd[1] = Rfu.playerCount; buff = (u8 *)(gSendCmd + 2); for (i = 0; i < RFU_CHILD_MAX; i++) @@ -1159,111 +1206,111 @@ static void RfuPrepareSendBuffer(u16 command) break; case RFUCMD_READY_EXIT_STANDBY: case RFUCMD_READY_CLOSE_LINK: - gSendCmd[1] = Rfu.cmd_6600_count; + gSendCmd[1] = Rfu.resendExitStandbyCount; break; case RFUCMD_SEND_PACKET: for (i = 0; i < 6; i++) - gSendCmd[1 + i] = Rfu.unk_f2[i]; + gSendCmd[1 + i] = Rfu.packet[i]; break; case RFUCMD_SEND_HELD_KEYS: gSendCmd[1] = gHeldKeyCodeToSend; break; - case RFUCMD_0xEE00: + case RFUCMD_CHILD_DISCONNECT: break; - case RFUCMD_0xED00: + case RFUCMD_PARENT_DISCONNECT: break; } } void Rfu_SendPacket(void * data) { - if (gSendCmd[0] == 0 && !RfuIsErrorStatus1or2()) + if (IsSendCmdComplete() && !RfuHasErrored()) { - memcpy(Rfu.unk_f2, data, sizeof(Rfu.unk_f2)); + memcpy(Rfu.packet, data, sizeof(Rfu.packet)); RfuPrepareSendBuffer(RFUCMD_SEND_PACKET); } } bool32 Rfu_InitBlockSend(const u8 *src, size_t size) { - bool8 r4; + bool8 sizeHasModulo; AGB_ASSERT_EX(size<=252, ABSPATH("rfu.c"), 1793); if (Rfu.RfuFunc != NULL) return FALSE; if (gSendCmd[0] != 0) return FALSE; - if (Rfu.cmd_8800_sendbuf.sending != 0) + if (Rfu.sendBlock.sending != 0) { - gUnknown_203AC08.unk_83++; + sRfuDebug.unk_83++; return FALSE; } - r4 = (size % 12) != 0; - Rfu.cmd_8800_sendbuf.owner = GetMultiplayerId(); - Rfu.cmd_8800_sendbuf.sending = 1; - Rfu.cmd_8800_sendbuf.count = (size / 12) + r4; - Rfu.cmd_8800_sendbuf.next = 0; + sizeHasModulo = (size % 12) != 0; + Rfu.sendBlock.owner = GetMultiplayerId(); + Rfu.sendBlock.sending = 1; + Rfu.sendBlock.count = (size / 12) + sizeHasModulo; + Rfu.sendBlock.next = 0; if (size > 0x100) // should never be reached - Rfu.cmd_8800_sendbuf.payload = src; + Rfu.sendBlock.payload = src; else { if (src != gBlockSendBuffer) memcpy(gBlockSendBuffer, src, size); - Rfu.cmd_8800_sendbuf.payload = gBlockSendBuffer; + Rfu.sendBlock.payload = gBlockSendBuffer; } - RfuPrepareSendBuffer(RFUCMD_0x8800); - Rfu.RfuFunc = RfuFunc_HandleBlockSend; - Rfu.unk_5b = 0; + RfuPrepareSendBuffer(RFUCMD_SEND_BLOCK_INIT); + Rfu.RfuFunc = HandleBlockSend; + Rfu.sendBlockInitDelay = 0; return TRUE; } -static void RfuFunc_HandleBlockSend(void) +static void HandleBlockSend(void) { - if (gSendCmd[0] == 0) + if (IsSendCmdComplete()) { - RfuPrepareSendBuffer(RFUCMD_0x8800); + RfuPrepareSendBuffer(RFUCMD_SEND_BLOCK_INIT); if (Rfu.parent_child == MODE_PARENT) { - if (++Rfu.unk_5b > 2) - Rfu.RfuFunc = RfuFunc_SendNextBlock; + if (++Rfu.sendBlockInitDelay > 2) + Rfu.RfuFunc = SendNextBlock; } else { - if ((gRecvCmds[GetMultiplayerId()][0] & 0xff00) == RFUCMD_0x8800) - Rfu.RfuFunc = RfuFunc_SendNextBlock; + if ((gRecvCmds[GetMultiplayerId()][0] & 0xff00) == RFUCMD_SEND_BLOCK_INIT) + Rfu.RfuFunc = SendNextBlock; } } } -static void RfuFunc_SendNextBlock(void) +static void SendNextBlock(void) { s32 i; - const u8 *src = Rfu.cmd_8800_sendbuf.payload; - gSendCmd[0] = RFUCMD_0x8900 | Rfu.cmd_8800_sendbuf.next; + const u8 *src = Rfu.sendBlock.payload; + gSendCmd[0] = RFUCMD_SEND_BLOCK_STEP | Rfu.sendBlock.next; for (i = 0; i < 7; i++) - gSendCmd[i + 1] = (src[(i << 1) + Rfu.cmd_8800_sendbuf.next * 12 + 1] << 8) | src[(i << 1) + Rfu.cmd_8800_sendbuf.next * 12 + 0]; - Rfu.cmd_8800_sendbuf.next++; - if (Rfu.cmd_8800_sendbuf.count <= Rfu.cmd_8800_sendbuf.next) + gSendCmd[i + 1] = (src[(i << 1) + Rfu.sendBlock.next * 12 + 1] << 8) | src[(i << 1) + Rfu.sendBlock.next * 12 + 0]; + Rfu.sendBlock.next++; + if (Rfu.sendBlock.count <= Rfu.sendBlock.next) { - Rfu.cmd_8800_sendbuf.sending = 0; - Rfu.RfuFunc = RfuFunc_SendLastBlock; + Rfu.sendBlock.sending = 0; + Rfu.RfuFunc = SendLastBlock; } } -static void RfuFunc_SendLastBlock(void) +static void SendLastBlock(void) { - const u8 *src = Rfu.cmd_8800_sendbuf.payload; + const u8 *src = Rfu.sendBlock.payload; u8 mpId = GetMultiplayerId(); s32 i; if (Rfu.parent_child == MODE_CHILD) { - gSendCmd[0] = RFUCMD_0x8900 | (Rfu.cmd_8800_sendbuf.count - 1); + gSendCmd[0] = RFUCMD_SEND_BLOCK_STEP | (Rfu.sendBlock.count - 1); for (i = 0; i < 7; i++) - gSendCmd[i + 1] = (src[(i << 1) + (Rfu.cmd_8800_sendbuf.count - 1) * 12 + 1] << 8) | src[(i << 1) + (Rfu.cmd_8800_sendbuf.count - 1) * 12 + 0]; - if ((u8)gRecvCmds[mpId][0] == Rfu.cmd_8800_sendbuf.count - 1) + gSendCmd[i + 1] = (src[(i << 1) + (Rfu.sendBlock.count - 1) * 12 + 1] << 8) | src[(i << 1) + (Rfu.sendBlock.count - 1) * 12 + 0]; + if ((u8)gRecvCmds[mpId][0] == Rfu.sendBlock.count - 1) { - if (Rfu.cmd_8800_recvbuf[mpId].receivedFlags != sAllBlocksReceived[Rfu.cmd_8800_recvbuf[mpId].count]) + if (Rfu.recvBlock[mpId].receivedFlags != sAllBlocksReceived[Rfu.recvBlock[mpId].count]) { - HandleSendFailure(mpId, Rfu.cmd_8800_recvbuf[mpId].receivedFlags); - gUnknown_203AC08.unk_64++; + HandleSendFailure(mpId, Rfu.recvBlock[mpId].receivedFlags); + sRfuDebug.unk_64++; } else Rfu.RfuFunc = NULL; @@ -1273,14 +1320,14 @@ static void RfuFunc_SendLastBlock(void) Rfu.RfuFunc = NULL; } -bool8 LinkRfu_PrepareCmd0xA100(u8 blockRequestType) +bool8 Rfu_SendBlockRequest(u8 blockRequestType) { Rfu.cmdA100_blockRequestType = blockRequestType; RfuPrepareSendBuffer(RFUCMD_SEND_BLOCK_REQ); return TRUE; } -static void RfuFunc_End5F00_PowerDownRfu(void) +static void OnDisconnect_PowerDownRfu(void) { rfu_clearAllSlot(); rfu_LMAN_powerDownRFU(); @@ -1289,14 +1336,14 @@ static void RfuFunc_End5F00_PowerDownRfu(void) Rfu.RfuFunc = NULL; } -static void RfuFunc_End5F00_ParentDisconnect(void) +static void DisconnectRfu(void) { rfu_REQ_disconnect(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag); rfu_waitREQComplete(); - RfuFunc_End5F00_PowerDownRfu(); + OnDisconnect_PowerDownRfu(); } -static void RfuFunc_End5F00(void) +static void TryDisconnectRfu(void) { if (Rfu.parent_child == MODE_CHILD) { @@ -1304,7 +1351,7 @@ static void RfuFunc_End5F00(void) Rfu.unk_ce4 = 2; } else - Rfu.RfuFunc = RfuFunc_End5F00_ParentDisconnect; + Rfu.RfuFunc = DisconnectRfu; } void LinkRfu_FatalError(void) @@ -1314,7 +1361,8 @@ void LinkRfu_FatalError(void) Rfu.bm_DisconnectSlot = gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag; } -static void RfuFunc_WaitAck5F00(void) +// RFU equivalent of LinkCB_WaitCloseLink +static void WaitAllReadyToCloseLink(void) { s32 i; u8 playerCount = Rfu.playerCount; @@ -1322,7 +1370,7 @@ static void RfuFunc_WaitAck5F00(void) for (i = 0; i < MAX_RFU_PLAYERS; i++) { - if (Rfu.cmd5f00Ack[i]) + if (Rfu.readyCloseLink[i]) count++; } if (count == playerCount) @@ -1331,87 +1379,88 @@ static void RfuFunc_WaitAck5F00(void) if (Rfu.parent_child == MODE_CHILD) { Rfu.errorState = 3; - RfuFunc_End5F00(); + TryDisconnectRfu(); } else - Rfu.RfuFunc = RfuFunc_End5F00; + Rfu.RfuFunc = TryDisconnectRfu; } } -static void RfuFunc_BuildCommand5F00(void) +static void SendReadyCloseLink(void) { - if (gSendCmd[0] == 0 && !Rfu.unk_ce8) + if (IsSendCmdComplete() && !Rfu.foundNewLeaderMaybe) { RfuPrepareSendBuffer(RFUCMD_READY_CLOSE_LINK); - Rfu.RfuFunc = RfuFunc_WaitAck5F00; + Rfu.RfuFunc = WaitAllReadyToCloseLink; } } -static void Task_WaitRfuFuncAndSetBuildCmd5F00(u8 taskId) +static void Task_TryReadyCloseLink(u8 taskId) { if (Rfu.RfuFunc == NULL) { - Rfu.unk_cd9 = 1; - Rfu.RfuFunc = RfuFunc_BuildCommand5F00; + Rfu.linkClosing = TRUE; + Rfu.RfuFunc = SendReadyCloseLink; DestroyTask(taskId); } } -void Rfu_BeginBuildAndSendCommand5F(void) +void Rfu_SetCloseLinkCallback(void) { - if (!FuncIsActiveTask(Task_WaitRfuFuncAndSetBuildCmd5F00)) - CreateTask(Task_WaitRfuFuncAndSetBuildCmd5F00, 5); + if (!FuncIsActiveTask(Task_TryReadyCloseLink)) + CreateTask(Task_TryReadyCloseLink, 5); } -static void RfuFunc_Send6600_3(void) +static void SendReadyExitStandbyUntilAllReady(void) { u8 playerCount; u8 i; if (GetMultiplayerId() != 0) // child { - if (Rfu.unk_124.count == 0 && Rfu.cmd_6600_timer > 60) + if (Rfu.recvQueue.count == 0 && Rfu.resendExitStandbyTimer > 60) { RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); - Rfu.cmd_6600_timer = 0; + Rfu.resendExitStandbyTimer = 0; } } playerCount = GetLinkPlayerCount(); for (i = 0; i < playerCount; i++) { - if (Rfu.cmd_6600_recvd[i] == 0) + if (Rfu.readyExitStandby[i] == 0) break; } if (i == playerCount) { for (i = 0; i < MAX_RFU_PLAYERS; i++) - Rfu.cmd_6600_recvd[i] = 0; - Rfu.cmd_6600_count++; + Rfu.readyExitStandby[i] = 0; + Rfu.resendExitStandbyCount++; Rfu.RfuFunc = NULL; } - Rfu.cmd_6600_timer++; + Rfu.resendExitStandbyTimer++; } -static void RfuFunc_Send6600_2(void) +static void LinkLeaderReadyToExitStandby(void) { - if (Rfu.unk_124.count == 0 && gSendCmd[0] == 0) + if (Rfu.recvQueue.count == 0 && IsSendCmdComplete()) { RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); - Rfu.RfuFunc = RfuFunc_Send6600_3; + Rfu.RfuFunc = SendReadyExitStandbyUntilAllReady; } } -static void RfuFunc_Send6600_1(void) +// RFU equivalent of LinkCB_Standby and LinkCB_StandbyForAll +static void Rfu_LinkStandby(void) { u8 i; u8 playerCount; if (GetMultiplayerId() != 0) // child { - if (Rfu.unk_124.count == 0 && gSendCmd[0] == 0) + if (Rfu.recvQueue.count == 0 && IsSendCmdComplete()) { RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); - Rfu.RfuFunc = RfuFunc_Send6600_3; + Rfu.RfuFunc = SendReadyExitStandbyUntilAllReady; } } else // parent @@ -1419,15 +1468,15 @@ static void RfuFunc_Send6600_1(void) playerCount = GetLinkPlayerCount(); for (i = 1; i < playerCount; i++) { - if (Rfu.cmd_6600_recvd[i] == 0) + if (Rfu.readyExitStandby[i] == 0) break; } if (i == playerCount) { - if (Rfu.unk_124.count == 0 && gSendCmd[0] == 0) + if (Rfu.recvQueue.count == 0 && IsSendCmdComplete()) { RfuPrepareSendBuffer(RFUCMD_READY_EXIT_STANDBY); - Rfu.RfuFunc = RfuFunc_Send6600_2; + Rfu.RfuFunc = LinkLeaderReadyToExitStandby; } } } @@ -1437,12 +1486,12 @@ void Rfu_SetLinkStandbyCallback(void) { if (Rfu.RfuFunc == NULL) { - Rfu.RfuFunc = RfuFunc_Send6600_1; - Rfu.cmd_6600_timer = 0; + Rfu.RfuFunc = Rfu_LinkStandby; + Rfu.resendExitStandbyTimer = 0; } } -bool32 RfuSerialNumberIsValid(u32 serialNo) +bool32 IsRfuSerialNumberValid(u32 serialNo) { s32 i; for (i = 0; sAcceptedSerialNos[i] != serialNo; i++) @@ -1453,25 +1502,25 @@ bool32 RfuSerialNumberIsValid(u32 serialNo) return TRUE; } -u8 ToggleLMANlinkRecovery(bool32 a0) +u8 ToggleLMANlinkRecovery(bool32 enable) { - if (!a0) - return rfu_LMAN_setLinkRecovery(0, 0); - rfu_LMAN_setLinkRecovery(1, 600); + if (!enable) + return rfu_LMAN_setLinkRecovery(FALSE, 0); + rfu_LMAN_setLinkRecovery(TRUE, 600); return 0; } -void sub_80FA4A8(void) +void Rfu_UnionRoomChat_StopLinkManager(void) { - Rfu.unk_cd9 = 1; - rfu_LMAN_stopManager(0); + Rfu.linkClosing = TRUE; + rfu_LMAN_stopManager(FALSE); } u8 LinkRfu_GetMultiplayerId(void) { if (Rfu.parent_child == MODE_PARENT) return 0; - return Rfu.unk_cce; + return Rfu.multiplayerId; } u8 GetRfuPlayerCount(void) @@ -1490,22 +1539,23 @@ static void CallRfuFunc(void) Rfu.RfuFunc(); } -static bool8 sub_80FA528(void) +static bool8 CheckForLeavingGroupMembers(void) { s32 i; bool8 retval = FALSE; for (i = 0; i < RFU_CHILD_MAX; i++) { - if (Rfu.unk_cd1[i] < 5 || Rfu.unk_cd1[i] > 6) + if (Rfu.partnerSendStatuses[i] < RFU_STATUS_JOIN_GROUP_OK + || Rfu.partnerSendStatuses[i] > RFU_STATUS_JOIN_GROUP_NO) { if (gRfuSlotStatusNI[i]->recv.state == SLOT_STATE_RECV_SUCCESS || gRfuSlotStatusNI[i]->recv.state == SLOT_STATE_RECV_SUCCESS_AND_SENDSIDE_UNKNOWN) { - if (Rfu.unk_cd5[i] == 8) + if (Rfu.partnerRecvStatuses[i] == RFU_STATUS_LEAVE_GROUP_NOTICE) { - Rfu.unk_cd1[i] = 9; - Rfu.unk_cd5[i] = 10; + Rfu.partnerSendStatuses[i] = RFU_STATUS_LEAVE_GROUP; + Rfu.partnerRecvStatuses[i] = RFU_STATUS_10; rfu_clearSlot(TYPE_NI_RECV, i); - rfu_NI_setSendData(1 << i, 8, Rfu.unk_cd1 + i, 1); + rfu_NI_setSendData(1 << i, 8, &Rfu.partnerSendStatuses[i], 1); retval = TRUE; } @@ -1525,10 +1575,10 @@ bool32 sub_80FA5D4(void) s32 i; for (i = 0; i < RFU_CHILD_MAX; i++) { - if (Rfu.unk_cd5[i] == 11) + if (Rfu.partnerRecvStatuses[i] == RFU_STATUS_11) { flags |= (1 << i); - Rfu.unk_cd5[i] = 0; + Rfu.partnerRecvStatuses[i] = RFU_STATUS_OK; } } if (flags) @@ -1538,18 +1588,18 @@ bool32 sub_80FA5D4(void) } for (i = 0; i < RFU_CHILD_MAX; i++) { - if (Rfu.unk_cd5[i] == 10 || Rfu.unk_cd5[i] == 11) + if (Rfu.partnerRecvStatuses[i] == RFU_STATUS_10 || Rfu.partnerRecvStatuses[i] == RFU_STATUS_11) return TRUE; } return FALSE; } -bool32 TrainerIdAndNameStillInPartnersList(u16 trainerId, const u8 *trainerName) +bool32 CheckTrainerHasLeftByIdAndName(u16 trainerId, const u8 *trainerName) { u8 r1 = GetPartnerIndexByNameAndTrainerID(trainerName, trainerId); if (r1 == 0xFF) return TRUE; - if (Rfu.unk_cd1[r1] == 9) + if (Rfu.partnerSendStatuses[r1] == RFU_STATUS_LEAVE_GROUP) return TRUE; return FALSE; } @@ -1557,16 +1607,16 @@ bool32 TrainerIdAndNameStillInPartnersList(u16 trainerId, const u8 *trainerName) void SendByteToPartnerByIdAndName(u8 value, u16 trainerId, const u8 *trainerName) { u8 slotNo = GetPartnerIndexByNameAndTrainerID(trainerName, trainerId); - Rfu.unk_cd1[slotNo] = value; + Rfu.partnerSendStatuses[slotNo] = value; rfu_clearSlot(TYPE_NI_SEND, slotNo); - rfu_NI_setSendData(1 << slotNo, 8, Rfu.unk_cd1 + slotNo, 1); + rfu_NI_setSendData(1 << slotNo, 8, Rfu.partnerSendStatuses + slotNo, 1); } -void LinkRfuNIsend8(void) +void SendLeaveGroupNotice(void) { - Rfu.unk_c85 = 8; + Rfu.sendStatus = RFU_STATUS_LEAVE_GROUP_NOTICE; rfu_clearSlot(TYPE_NI_SEND, Rfu.child_slot); - rfu_NI_setSendData(1 << Rfu.child_slot, 8, &Rfu.unk_c85, 1); + rfu_NI_setSendData(1 << Rfu.child_slot, 8, &Rfu.sendStatus, 1); } u32 WaitSendByteToPartnerByIdAndName(u16 trainerId, const u8 *trainerName) @@ -1579,26 +1629,26 @@ u32 WaitSendByteToPartnerByIdAndName(u16 trainerId, const u8 *trainerName) return 0; } -static void sub_80FA738(void) +static void UpdateChildStatuses(void) { s32 i; - sub_80FA528(); + CheckForLeavingGroupMembers(); for (i = 0; i < RFU_CHILD_MAX; i++) { if (gRfuSlotStatusNI[i]->send.state == SLOT_STATE_SEND_SUCCESS || gRfuSlotStatusNI[i]->send.state == SLOT_STATE_SEND_FAILED) { - if (Rfu.unk_cd5[i] == 10) - Rfu.unk_cd5[i] = 11; + if (Rfu.partnerRecvStatuses[i] == RFU_STATUS_10) + Rfu.partnerRecvStatuses[i] = RFU_STATUS_11; rfu_clearSlot(TYPE_NI_SEND, i); } } } -static s32 sub_80FA788(void) +static s32 GetRfuRecvStatus(void) { - s32 retval = 0; - if (Rfu.unk_c85 == 8) + s32 retval = RFU_STATUS_OK; + if (Rfu.sendStatus == RFU_STATUS_LEAVE_GROUP_NOTICE) { if (gRfuSlotStatusNI[Rfu.child_slot]->send.state == SLOT_STATE_SEND_SUCCESS || gRfuSlotStatusNI[Rfu.child_slot]->send.state == SLOT_STATE_SEND_FAILED) rfu_clearSlot(TYPE_NI_SEND, Rfu.child_slot); @@ -1606,13 +1656,13 @@ static s32 sub_80FA788(void) if (gRfuSlotStatusNI[Rfu.child_slot]->recv.state == SLOT_STATE_RECV_SUCCESS || gRfuSlotStatusNI[Rfu.child_slot]->recv.state == SLOT_STATE_RECV_SUCCESS_AND_SENDSIDE_UNKNOWN) { rfu_clearSlot(TYPE_NI_RECV, Rfu.child_slot); - RfuSetErrorStatus(Rfu.unk_c86, 0); - retval = Rfu.unk_c86; + RfuSetStatus(Rfu.recvStatus, 0); + retval = Rfu.recvStatus; } else if (gRfuSlotStatusNI[Rfu.child_slot]->recv.state == SLOT_STATE_RECV_FAILED) { rfu_clearSlot(TYPE_NI_RECV, Rfu.child_slot); - retval = 6; + retval = RFU_STATUS_JOIN_GROUP_NO; } return retval; } @@ -1621,18 +1671,18 @@ static void sub_80FA834(u8 taskId) { s32 i; - if (Rfu.unk_f1 == 1 || Rfu.unk_f1 == 2) + if (Rfu.status == RFU_STATUS_FATAL_ERROR || Rfu.status == RFU_STATUS_CONNECTION_ERROR) { - Rfu.unk_ce8 = FALSE; + Rfu.foundNewLeaderMaybe = FALSE; DestroyTask(taskId); } switch (gTasks[taskId].data[0]) { case 0: - if (Cmd8000recvIsFinished()) + if (AreNoPlayersReceiving()) { ResetBlockReceivedFlags(); - PrepareLocalLinkPlayerBlock(); + LocalLinkPlayerToBlock(); gTasks[taskId].data[0]++; } break; @@ -1640,16 +1690,16 @@ static void sub_80FA834(u8 taskId) if (Rfu.parent_child == MODE_PARENT) { if (gReceivedRemoteLinkPlayers) - RfuPrepareSendBuffer(RFUCMD_0x7800); + RfuPrepareSendBuffer(RFUCMD_PLAYERS_LIST_2); else - RfuPrepareSendBuffer(RFUCMD_0x7700); + RfuPrepareSendBuffer(RFUCMD_PLAYERS_LIST); gTasks[taskId].data[0] = 101; } else gTasks[taskId].data[0] = 2; break; case 101: - if (gSendCmd[0] == 0) + if (IsSendCmdComplete()) gTasks[taskId].data[0] = 2; break; case 2: @@ -1659,7 +1709,7 @@ static void sub_80FA834(u8 taskId) case 3: if (Rfu.parent_child == MODE_PARENT) { - if (Cmd8000recvIsFinished()) + if (AreNoPlayersReceiving()) { Rfu.cmdA100_blockRequestType = 0; RfuPrepareSendBuffer(RFUCMD_SEND_BLOCK_REQ); @@ -1670,7 +1720,7 @@ static void sub_80FA834(u8 taskId) gTasks[taskId].data[0]++; break; case 4: - if (sub_80F9C78()) + if (AreAllPlayersFinishedReceiving()) gTasks[taskId].data[0]++; break; case 5: @@ -1684,7 +1734,7 @@ static void sub_80FA834(u8 taskId) case 6: DestroyTask(taskId); gReceivedRemoteLinkPlayers = TRUE; - Rfu.unk_ce8 = FALSE; + Rfu.foundNewLeaderMaybe = FALSE; rfu_LMAN_setLinkRecovery(1, 600); if (Rfu.unionRoomChatters) { @@ -1692,7 +1742,7 @@ static void sub_80FA834(u8 taskId) { if ((Rfu.unionRoomChatters >> i) & 1) { - Rfu.unk_ce5 = 1 << i; + Rfu.bmChatLeaderMaybe = 1 << i; Rfu.unionRoomChatters ^= (1 << i); } } @@ -1701,13 +1751,13 @@ static void sub_80FA834(u8 taskId) } } -static void sub_80FA9D0(u16 a0) +static void ClearSelectedLinkPlayerIds(u16 disconnectMask) { s32 i; for (i = 0; i < RFU_CHILD_MAX; i++) { - if ((a0 >> i) & 1) + if ((disconnectMask >> i) & 1) Rfu.linkPlayerIdx[i] = 0; } } @@ -1741,23 +1791,23 @@ static void Task_ExchangeLinkPlayers(u8 taskId) struct LinkPlayerBlock *r2; struct SioInfo *r5; u8 r4 = Rfu.linkPlayerIdx[gUnknown_843EC38[Rfu.unk_ce9]]; - if (Rfu.unk_f1 == 1 || Rfu.unk_f1 == 2) + if (Rfu.status == 1 || Rfu.status == 2) { - Rfu.unk_ce8 = FALSE; + Rfu.foundNewLeaderMaybe = FALSE; DestroyTask(taskId); } switch (gTasks[taskId].data[0]) { case 0: - if (gSendCmd[0] == 0) + if (IsSendCmdComplete()) { ResetBlockReceivedFlag(r4); - RfuPrepareSendBuffer(RFUCMD_0x7800); + RfuPrepareSendBuffer(RFUCMD_PLAYERS_LIST_2); gTasks[taskId].data[0]++; } break; case 1: - if (gSendCmd[0] == 0) + if (IsSendCmdComplete()) gTasks[taskId].data[0]++; break; case 2: @@ -1794,16 +1844,16 @@ static void Task_ExchangeLinkPlayers(u8 taskId) { CpuFill16(0, gBlockRecvBuffer, sizeof(struct SioInfo)); ResetBlockReceivedFlag(0); - Rfu.unk_ce8 = FALSE; + Rfu.foundNewLeaderMaybe = FALSE; if (Rfu.unionRoomChatters) { for (i = 0; i < RFU_CHILD_MAX; i++) { if ((Rfu.unionRoomChatters >> i) & 1) { - Rfu.unk_ce5 = 1 << i; + Rfu.bmChatLeaderMaybe = 1 << i; Rfu.unionRoomChatters ^= (1 << i); - Rfu.unk_ce8 = TRUE; + Rfu.foundNewLeaderMaybe = TRUE; break; } } @@ -1816,14 +1866,14 @@ static void Task_ExchangeLinkPlayers(u8 taskId) static void sub_80FACF0(u8 taskId) { - if (Rfu.unk_f1 == 1 || Rfu.unk_f1 == 2) + if (Rfu.status == RFU_STATUS_FATAL_ERROR || Rfu.status == RFU_STATUS_CONNECTION_ERROR) DestroyTask(taskId); switch (gTasks[taskId].data[0]) { case 0: - if (Rfu.playerCount) + if (Rfu.playerCount != 0) { - PrepareLocalLinkPlayerBlock(); + LocalLinkPlayerToBlock(); SendBlock(0, gBlockSendBuffer, sizeof(struct LinkPlayerBlock)); gTasks[taskId].data[0]++; } @@ -1852,15 +1902,20 @@ static void RfuCheckErrorStatus(void) gWirelessCommType = 2; SetMainCallback2(CB2_LinkError); gMain.savedCallback = CB2_LinkError; - SetLinkErrorFromRfu((Rfu.linkman_msg << 16) | (Rfu.linkman_param[0] << 8) | Rfu.linkman_param[1], Rfu.unk_124.count, Rfu.sendQueue.count, RfuGetErrorStatus() == 2); + SetLinkErrorFromRfu( + (Rfu.linkman_msg << 16) | (Rfu.linkman_param[0] << 8) | Rfu.linkman_param[1], + Rfu.recvQueue.count, + Rfu.sendQueue.count, + RfuGetStatus() == RFU_STATUS_CONNECTION_ERROR + ); Rfu.errorState = 2; CloseLink(); } - else if (Rfu.sendQueue.full == 1 || Rfu.unk_124.full == 1) + else if (Rfu.sendQueue.full == TRUE || Rfu.recvQueue.full == TRUE) { if (lman.childClockSlave_flag) rfu_LMAN_requestChangeAgbClockMaster(); - RfuSetErrorStatus(1, 0x7000); + RfuSetStatus(RFU_STATUS_FATAL_ERROR, 0x7000); GetLinkmanErrorParams(0x7000); } } @@ -1884,13 +1939,13 @@ bool32 LinkRfuMain1(void) { switch (Rfu.parent_child) { - case 1: + case MODE_PARENT: sub_80F911C(); break; - case 0: + case MODE_CHILD: retval = RfuProcessEnqueuedRecvBlock(); break; - case 2: + case MODE_P_C_SWITCH: rfu_REQ_recvData_then_sendData(); break; } @@ -1918,7 +1973,7 @@ static void CopyPlayerNameToUnameBuffer(void) void ClearAndInitHostRFUtgtGname(void) { memset(&gHostRFUtgtGnameBuffer, 0, RFU_GAME_NAME_LENGTH); - InitHostRFUtgtGname(&gHostRFUtgtGnameBuffer, 0, FALSE, 0); + InitHostRFUtgtGname(&gHostRFUtgtGnameBuffer, ACTIVITY_NONE, FALSE, 0); } void SetHostRFUtgtGname(u8 activity, u32 child_sprite_genders, u32 started) @@ -2036,9 +2091,9 @@ static void LmanCallback_Parent2(u8 msg, u8 param_count) struct GFtgtGname *structPtr = (void *)&gRfuLinkStatus->partner[i].gname; if (structPtr->activity == GetHostRFUtgtGname()->activity) { - Rfu.unk_cd1[i] = 0; - Rfu.unk_cd5[i] = 0; - rfu_setRecvBuffer(TYPE_NI, i, Rfu.unk_cd5 + i, 1); + Rfu.partnerSendStatuses[i] = RFU_STATUS_OK; + Rfu.partnerRecvStatuses[i] = RFU_STATUS_OK; + rfu_setRecvBuffer(TYPE_NI, i, Rfu.partnerRecvStatuses + i, 1); } else { @@ -2081,7 +2136,7 @@ static void LmanCallback_Parent2(u8 msg, u8 param_count) else sub_80FB174(); } - RfuSetErrorStatus(2, msg); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); break; case 0x34: break; @@ -2090,7 +2145,7 @@ static void LmanCallback_Parent2(u8 msg, u8 param_count) case LMAN_MSG_MANAGER_FORCED_STOPPED_AND_RFU_RESET: break; case LMAN_MSG_LMAN_API_ERROR_RETURN: - RfuSetErrorStatus(1, msg); + RfuSetStatus(RFU_STATUS_FATAL_ERROR, msg); GetLinkmanErrorParams(msg); Rfu.isShuttingDown = TRUE; break; @@ -2099,8 +2154,8 @@ static void LmanCallback_Parent2(u8 msg, u8 param_count) case LMAN_MSG_CLOCK_SLAVE_MS_CHANGE_ERROR_BY_DMA: case LMAN_MSG_RFU_FATAL_ERROR: GetLinkmanErrorParams(msg); - RfuSetErrorStatus(1, msg); - Rfu.unk_cdb = 1; + RfuSetStatus(RFU_STATUS_FATAL_ERROR, msg); + Rfu.unk_cdb = TRUE; break; } } @@ -2123,38 +2178,38 @@ static void LmanCallback_Child(u8 msg, u8 param_count) Rfu.child_slot = lman.param[0]; break; case LMAN_MSG_CONNECT_PARENT_FAILED: - RfuSetErrorStatus(2, msg); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); break; case LMAN_MSG_CHILD_NAME_SEND_COMPLETED: Rfu.state = 11; - Rfu.unk_c85 = 0; - Rfu.unk_c86 = 0; - rfu_setRecvBuffer(TYPE_NI, Rfu.child_slot, &Rfu.unk_c86, 1); + Rfu.sendStatus = RFU_STATUS_OK; + Rfu.recvStatus = RFU_STATUS_OK; + rfu_setRecvBuffer(TYPE_NI, Rfu.child_slot, &Rfu.recvStatus, 1); rfu_setRecvBuffer(TYPE_UNI, Rfu.child_slot, Rfu.unk_c3f, sizeof(Rfu.unk_c3f)); break; case LMAN_MSG_CHILD_NAME_SEND_FAILED_AND_DISCONNECTED: - RfuSetErrorStatus(2, msg); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); break; case LMAN_MSG_LINK_LOSS_DETECTED_AND_DISCONNECTED: Rfu.linkLossRecoveryState = 2; - if (Rfu.unk_c86 == 6) + if (Rfu.recvStatus == RFU_STATUS_JOIN_GROUP_NO) break; case LMAN_MSG_LINK_RECOVERY_FAILED_AND_DISCONNECTED: if (Rfu.linkLossRecoveryState != 2) Rfu.linkLossRecoveryState = 4; - if (Rfu.unk_c86 != 9) - RfuSetErrorStatus(2, msg); - rfu_dbg_print_str("LINK LOSS DISCONNECT!", 5, 5); + if (Rfu.recvStatus != RFU_STATUS_LEAVE_GROUP) + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); + Debug_PrintString("LINK LOSS DISCONNECT!", 5, 5); if (gReceivedRemoteLinkPlayers == 1) GetLinkmanErrorParams(msg); break; case LMAN_MSG_LINK_LOSS_DETECTED_AND_START_RECOVERY: Rfu.linkLossRecoveryState = 1; - rfu_dbg_print_str("LINK LOSS RECOVERY NOW", 5, 5); + Debug_PrintString("LINK LOSS RECOVERY NOW", 5, 5); break; case LMAN_MSG_LINK_RECOVERY_SUCCESSED: Rfu.linkLossRecoveryState = 3; - Rfu.unk_c3c = 1; + Rfu.linkRecovered = 1; break; case 0x34: break; @@ -2163,7 +2218,7 @@ static void LmanCallback_Child(u8 msg, u8 param_count) case LMAN_MSG_MANAGER_FORCED_STOPPED_AND_RFU_RESET: break; case LMAN_MSG_LMAN_API_ERROR_RETURN: - RfuSetErrorStatus(1, msg); + RfuSetStatus(RFU_STATUS_FATAL_ERROR, msg); GetLinkmanErrorParams(msg); Rfu.isShuttingDown = TRUE; break; @@ -2171,9 +2226,9 @@ static void LmanCallback_Child(u8 msg, u8 param_count) case LMAN_MSG_WATCH_DOG_TIMER_ERROR: case LMAN_MSG_CLOCK_SLAVE_MS_CHANGE_ERROR_BY_DMA: case LMAN_MSG_RFU_FATAL_ERROR: - RfuSetErrorStatus(1, msg); + RfuSetStatus(RFU_STATUS_FATAL_ERROR, msg); GetLinkmanErrorParams(msg); - Rfu.unk_cdb = 1; + Rfu.unk_cdb = TRUE; break; } } @@ -2220,20 +2275,20 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) Rfu.state = 17; break; case LMAN_MSG_NEW_CHILD_CONNECT_DETECTED: - RfuSetErrorStatus(4, 0); + RfuSetStatus(RFU_STATUS_NEW_CHILD_DETECTED, 0); break; case LMAN_MSG_NEW_CHILD_CONNECT_ACCEPTED: - if (GetHostRFUtgtGname()->activity == (ACTIVITY_CHAT | IN_UNION_ROOM) && Rfu.unk_cd9 == 0) + if (GetHostRFUtgtGname()->activity == (ACTIVITY_CHAT | IN_UNION_ROOM) && !Rfu.linkClosing) { u8 bmAcceptSlot = GetNewChildrenInUnionRoomChat(lman.param[0]); if (bmAcceptSlot != 0) { - r1 = 1 << sub_80F886C(bmAcceptSlot); - if (Rfu.unionRoomChatters == 0 && !Rfu.unk_ce8) + r1 = 1 << CountTrailingZeroes(bmAcceptSlot); + if (Rfu.unionRoomChatters == 0 && !Rfu.foundNewLeaderMaybe) { - Rfu.unk_ce5 = r1; + Rfu.bmChatLeaderMaybe = r1; Rfu.unionRoomChatters |= (r1 ^ bmAcceptSlot); - Rfu.unk_ce8 = TRUE; + Rfu.foundNewLeaderMaybe = TRUE; } else { @@ -2260,11 +2315,11 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) case LMAN_MSG_END_WAIT_CHILD_NAME: if (GetHostRFUtgtGname()->activity != (ACTIVITY_CHAT | IN_UNION_ROOM) && lman.acceptCount > 1) { - r1 = 1 << sub_80F886C(lman.param[0]); + r1 = 1 << CountTrailingZeroes(lman.param[0]); rfu_REQ_disconnect(lman.acceptSlot_flag ^ r1); rfu_waitREQComplete(); } - if (Rfu.state == 0xF) + if (Rfu.state == 15) Rfu.state = 16; break; case LMAN_MSG_PARENT_FOUND: @@ -2284,16 +2339,16 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) } else { - RfuSetErrorStatus(2, msg); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); } break; case LMAN_MSG_CHILD_NAME_SEND_COMPLETED: Rfu.state = 13; - RfuSetErrorStatus(3, 0); + RfuSetStatus(RFU_STATUS_CHILD_SEND_COMPLETE, 0); rfu_setRecvBuffer(TYPE_UNI, Rfu.child_slot, Rfu.unk_c3f, sizeof(Rfu.unk_c3f)); break; case LMAN_MSG_CHILD_NAME_SEND_FAILED_AND_DISCONNECTED: - RfuSetErrorStatus(2, msg); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); break; case LMAN_MSG_LINK_LOSS_DETECTED_AND_START_RECOVERY: if (lman.acceptSlot_flag & lman.param[0]) @@ -2302,7 +2357,7 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) case LMAN_MSG_LINK_RECOVERY_SUCCESSED: Rfu.linkLossRecoveryState = 3; if (gRfuLinkStatus->parentChild == MODE_CHILD) - Rfu.unk_c3c = 1; + Rfu.linkRecovered = 1; break; case LMAN_MSG_LINK_LOSS_DETECTED_AND_DISCONNECTED: Rfu.linkLossRecoveryState = 2; @@ -2330,7 +2385,7 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) if (gRfuLinkStatus->parentChild == MODE_NEUTRAL && lman.pcswitch_flag == 0 && FuncIsActiveTask(Task_LinkRfu_UnionRoomListen) == TRUE) Rfu.state = 17; - RfuSetErrorStatus(2, msg); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, msg); break; case LMAN_MSG_LINK_DISCONNECTED_BY_USER: Rfu.bm_DisconnectSlot = 0; @@ -2340,7 +2395,7 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) case LMAN_MSG_MANAGER_FORCED_STOPPED_AND_RFU_RESET: break; case LMAN_MSG_LMAN_API_ERROR_RETURN: - RfuSetErrorStatus(1, msg); + RfuSetStatus(RFU_STATUS_FATAL_ERROR, msg); GetLinkmanErrorParams(msg); Rfu.isShuttingDown = TRUE; break; @@ -2349,8 +2404,8 @@ static void LmanCallback_Parent(u8 msg, u8 param_count) case LMAN_MSG_CLOCK_SLAVE_MS_CHANGE_ERROR_BY_DMA: case LMAN_MSG_RFU_FATAL_ERROR: GetLinkmanErrorParams(msg); - RfuSetErrorStatus(1, msg); - Rfu.unk_cdb = 0; + RfuSetStatus(RFU_STATUS_FATAL_ERROR, msg); + Rfu.unk_cdb = FALSE; break; } } @@ -2360,29 +2415,29 @@ void sub_80FB9D0(void) Rfu.unk_ce4 = 2; } -void RfuSetErrorStatus(u8 a0, u16 msg) +void RfuSetStatus(u8 status, u16 msg) { - Rfu.unk_f1 = a0; + Rfu.status = status; Rfu.linkman_msg = msg; } -u8 RfuGetErrorStatus(void) +u8 RfuGetStatus(void) { - return Rfu.unk_f1; + return Rfu.status; } -bool32 RfuIsErrorStatus1or2(void) +bool32 RfuHasErrored(void) { - u32 var = RfuGetErrorStatus(); - if (var == 1 || var == 2) + u32 status = RfuGetStatus(); + if (status == RFU_STATUS_FATAL_ERROR || status == RFU_STATUS_CONNECTION_ERROR) return TRUE; else return FALSE; } -bool32 GetRfuUnkCE8(void) +bool32 RfuHasFoundNewLeader(void) { - return Rfu.unk_ce8; + return Rfu.foundNewLeaderMaybe; } bool8 Rfu_IsMaster(void) @@ -2418,7 +2473,7 @@ static void sub_80FBA78(void) SetVBlankCallback(sub_80FBA64); if (IsWirelessAdapterConnected()) { - gLinkType = LINKTYPE_0x1111; + gLinkType = LINKTYPE_TRADE; SetWirelessCommType1(); OpenLink(); SeedRng(gMain.vblankCounter2); @@ -2443,13 +2498,13 @@ bool32 IsUnionRoomListenTaskActive(void) void LinkRfu_CreateIdleTask(void) { if (!FuncIsActiveTask(Task_idle)) - Rfu.unk_66 = CreateTask(Task_idle, 0); + Rfu.idleTaskId = CreateTask(Task_idle, 0); } void LinkRfu_DestroyIdleTask(void) { if (FuncIsActiveTask(Task_idle) == TRUE) - DestroyTask(Rfu.unk_66); + DestroyTask(Rfu.idleTaskId); } static void sub_80FBB74(void) @@ -2488,7 +2543,7 @@ void InitializeRfuLinkManager_EnterUnionRoom(void) sRfuReqConfig = sRfuReqConfigTemplate; sRfuReqConfig.linkRecovery_enable = 0; sRfuReqConfig.linkRecovery_period = 600; - Rfu.unk_67 = CreateTask(Task_LinkRfu_UnionRoomListen, 1); + Rfu.searchTaskId = CreateTask(Task_LinkRfu_UnionRoomListen, 1); } static u16 ReadU16(const void *ptr) @@ -2512,7 +2567,7 @@ static u8 GetPartnerIndexByNameAndTrainerID(const u8 *trainerName, u16 trainerId for (i = 0; i < RFU_CHILD_MAX; i++) { u16 partnerTrainerId = ReadU16(((struct GFtgtGname *)gRfuLinkStatus->partner[i].gname)->unk_00.playerTrainerId); - if (RfuSerialNumberIsValid(gRfuLinkStatus->partner[i].serialNo) + if (IsRfuSerialNumberValid(gRfuLinkStatus->partner[i].serialNo) && !StringCompare(trainerName, gRfuLinkStatus->partner[i].uname) && trainerId == partnerTrainerId) { @@ -2532,7 +2587,7 @@ static void RfuReqDisconnectSlot(u32 bmDisconnectSlot) Rfu.bm_PartnerFlags &= ~(bmDisconnectSlot); rfu_clearSlot(TYPE_UNI_SEND, Rfu.unk_cda); rfu_UNI_setSendData(Rfu.bm_PartnerFlags, Rfu.recvCmds, 70); - Rfu.unk_cda = sub_80F886C(Rfu.bm_PartnerFlags); + Rfu.unk_cda = CountTrailingZeroes(Rfu.bm_PartnerFlags); } void RequestDisconnectSlotByTrainerNameAndId(const u8 *trainerName, u16 trainerId) @@ -2561,12 +2616,12 @@ void sub_80FBD6C(u32 a0) static void sub_80FBDB8(u8 taskId) { - if (gSendCmd[0] == 0 && !Rfu.unk_ce8) + if (IsSendCmdComplete() && !Rfu.foundNewLeaderMaybe) { - RfuPrepareSendBuffer(RFUCMD_0xED00); + RfuPrepareSendBuffer(RFUCMD_PARENT_DISCONNECT); gSendCmd[1] = gTasks[taskId].data[0]; gSendCmd[2] = gTasks[taskId].data[1]; - Rfu.playerCount -= gUnknown_843EC41[gTasks[taskId].data[0]]; + Rfu.playerCount -= sNumSetBits[gTasks[taskId].data[0]]; gSendCmd[3] = Rfu.playerCount; DestroyTask(taskId); } @@ -2592,7 +2647,7 @@ static void Task_RfuReconnectWithParent(u8 taskId) { s16 *data = gTasks[taskId].data; - if (RfuStateIs7AndPlayerIsChild()) + if (ContactedByParentAttemptingToReconnect()) { u8 id = GetPartnerIndexByNameAndTrainerID((u8*)data, ReadU16(&data[8])); if (id != 0xFF) @@ -2609,7 +2664,7 @@ static void Task_RfuReconnectWithParent(u8 taskId) } else { - RfuSetErrorStatus(2, 0x7000); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x7000); DestroyTask(taskId); } } @@ -2626,7 +2681,7 @@ static void Task_RfuReconnectWithParent(u8 taskId) if (data[15] > 240) { - RfuSetErrorStatus(2, 0x7000); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x7000); DestroyTask(taskId); } } @@ -2636,7 +2691,7 @@ void CreateTask_RfuReconnectWithParent(const u8 *trainerName, u16 trainerId) u8 taskId; s16 *data; - Rfu.unk_f1 = 0; + Rfu.status = RFU_STATUS_OK; taskId = CreateTask(Task_RfuReconnectWithParent, 3); data = gTasks[taskId].data; StringCopy((u8*)(data), trainerName); @@ -2656,7 +2711,7 @@ static bool32 ShouldRejectPartnerConnectionBasedOnActivity(s16 activity, struct } else if (activity == (ACTIVITY_TRADE | IN_UNION_ROOM)) { - struct GFtgtGname *myTradeGname = (struct GFtgtGname *)&Rfu.unk_104.gname; + struct GFtgtGname *myTradeGname = (struct GFtgtGname *)&Rfu.tgtData.gname; if (myTradeGname->species == SPECIES_EGG) { if (partnerGname->species == myTradeGname->species) @@ -2677,19 +2732,19 @@ static bool32 ShouldRejectPartnerConnectionBasedOnActivity(s16 activity, struct static void sub_80FC028(u8 taskId) { - if (Rfu.unk_f1 == 4) + if (Rfu.status == RFU_STATUS_NEW_CHILD_DETECTED) DestroyTask(taskId); if (++gTasks[taskId].data[0] > 300) { - RfuSetErrorStatus(2, 0x7000); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x7000); DestroyTask(taskId); } if (Rfu.parentId != 0 && lman.parent_child == MODE_CHILD) { - u16 trainerId = ReadU16(((struct GFtgtGname *)&Rfu.unk_104.gname)->unk_00.playerTrainerId); - u8 id = GetPartnerIndexByNameAndTrainerID(Rfu.unk_104.uname, trainerId); + u16 trainerId = ReadU16(((struct GFtgtGname *)&Rfu.tgtData.gname)->unk_00.playerTrainerId); + u8 id = GetPartnerIndexByNameAndTrainerID(Rfu.tgtData.uname, trainerId); if (id != 0xFF) { if (!ShouldRejectPartnerConnectionBasedOnActivity(gTasks[taskId].data[1], (struct GFtgtGname *)&gRfuLinkStatus->partner[id].gname)) @@ -2702,7 +2757,7 @@ static void sub_80FC028(u8 taskId) } else { - RfuSetErrorStatus(2, 0x7000); + RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x7000); DestroyTask(taskId); } } @@ -2714,9 +2769,9 @@ void sub_80FC114(const u8 *name, struct GFtgtGname *structPtr, u8 activity) u8 taskId, taskId2; Rfu.unk_ccf = 0; - Rfu.unk_f1 = 0; - StringCopy(Rfu.unk_104.uname, name); - memcpy(Rfu.unk_104.gname, structPtr, RFU_GAME_NAME_LENGTH); + Rfu.status = RFU_STATUS_OK; + StringCopy(Rfu.tgtData.uname, name); + memcpy(Rfu.tgtData.gname, structPtr, RFU_GAME_NAME_LENGTH); rfu_LMAN_forceChangeSP(); taskId = CreateTask(sub_80FC028, 2); gTasks[taskId].data[1] = activity; @@ -2733,7 +2788,7 @@ void sub_80FC114(const u8 *name, struct GFtgtGname *structPtr, u8 activity) } } -bool8 sub_80FC1B0(void) +bool8 IsRfuRecoveringFromLinkLoss(void) { if (Rfu.linkLossRecoveryState == 1) return TRUE; @@ -2747,19 +2802,19 @@ bool32 sub_80FC1CC(void) for (i = 0; i < RFU_CHILD_MAX; i++) { - if ((lman.acceptSlot_flag >> i) & 1 && Rfu.unk_cd1[i] == 0) + if ((lman.acceptSlot_flag >> i) & 1 && Rfu.partnerSendStatuses[i] == 0) return FALSE; } return TRUE; } -static void rfu_dbg_clear(void) +static void Debug_PrintEmpty(void) { s32 i; for (i = 0; i < 20; i++) - rfu_dbg_print_str(" ", 0, i); + Debug_PrintString(" ", 0, i); } static const char gUnknown_843EE47[16] = { @@ -2775,44 +2830,44 @@ static const char gUnknown_843EE57[9] = { static const char gUnknown_843EE60[] = {' ', '\0'}; static const char gUnknown_843EE62[] = {'*', '\0'}; -static void rfu_dbg_print_status(void) +static void Debug_PrintStatus(void) { s32 i, j; - rfu_dbg_print_num(GetBlockReceivedStatus(), 0x1C, 0x13, 2); - rfu_dbg_print_num(gRfuLinkStatus->connSlotFlag, 0x14, 1, 1); - rfu_dbg_print_num(gRfuLinkStatus->linkLossSlotFlag, 0x17, 1, 1); + Debug_PrintNum(GetBlockReceivedStatus(), 0x1C, 0x13, 2); + Debug_PrintNum(gRfuLinkStatus->connSlotFlag, 0x14, 1, 1); + Debug_PrintNum(gRfuLinkStatus->linkLossSlotFlag, 0x17, 1, 1); if (Rfu.parent_child == MODE_PARENT) { for (i = 0; i < RFU_CHILD_MAX; i++) { if ((gRfuLinkStatus->getNameFlag >> i) & 1) { - rfu_dbg_print_num(gRfuLinkStatus->partner[i].serialNo, 1, i + 3, 4); - rfu_dbg_print_str((void*) &gRfuLinkStatus->partner[i].gname, 6, i + 3); - rfu_dbg_print_str(gRfuLinkStatus->partner[i].uname, 0x16, i + 3); + Debug_PrintNum(gRfuLinkStatus->partner[i].serialNo, 1, i + 3, 4); + Debug_PrintString((void *) &gRfuLinkStatus->partner[i].gname, 6, i + 3); + Debug_PrintString(gRfuLinkStatus->partner[i].uname, 0x16, i + 3); } } for (i = 0; i < RFU_CHILD_MAX; i++) { for (j = 0; j < 14; j++) { - rfu_dbg_print_num(Rfu.unk_14[i][j], j * 2, i + 11, 2); + Debug_PrintNum(Rfu.main_UNI_recvBuffer[i][j], j * 2, i + 11, 2); } } - rfu_dbg_print_str("NOWSLOT", 1, 0xF); + Debug_PrintString("NOWSLOT", 1, 0xF); } else if (gRfuLinkStatus->connSlotFlag != 0 && gRfuLinkStatus->getNameFlag != 0) { for (i = 0; i < RFU_CHILD_MAX; i++) { - rfu_dbg_print_num(0, 1, i + 3, 4); - rfu_dbg_print_str(gUnknown_843EE47, 6, i + 3); - rfu_dbg_print_str(gUnknown_843EE57, 0x16, i + 3); + Debug_PrintNum(0, 1, i + 3, 4); + Debug_PrintString(gUnknown_843EE47, 6, i + 3); + Debug_PrintString(gUnknown_843EE57, 0x16, i + 3); } - rfu_dbg_print_num(gRfuLinkStatus->partner[Rfu.child_slot].serialNo, 1, 3, 4); - rfu_dbg_print_str(gRfuLinkStatus->partner[Rfu.child_slot].gname, 6, 3); - rfu_dbg_print_str(gRfuLinkStatus->partner[Rfu.child_slot].uname, 0x16, 3); + Debug_PrintNum(gRfuLinkStatus->partner[Rfu.child_slot].serialNo, 1, 3, 4); + Debug_PrintString(gRfuLinkStatus->partner[Rfu.child_slot].gname, 6, 3); + Debug_PrintString(gRfuLinkStatus->partner[Rfu.child_slot].uname, 0x16, 3); } else { @@ -2820,16 +2875,16 @@ static void rfu_dbg_print_status(void) { if (gRfuLinkStatus->partner[i].slot != 0xFF) { - rfu_dbg_print_num(gRfuLinkStatus->partner[i].serialNo, 1, i + 3, 4); - rfu_dbg_print_num(gRfuLinkStatus->partner[i].id, 6, i + 3, 4); - rfu_dbg_print_str(gRfuLinkStatus->partner[i].uname, 0x16, i + 3); + Debug_PrintNum(gRfuLinkStatus->partner[i].serialNo, 1, i + 3, 4); + Debug_PrintNum(gRfuLinkStatus->partner[i].id, 6, i + 3, 4); + Debug_PrintString(gRfuLinkStatus->partner[i].uname, 0x16, i + 3); } } for (; i < RFU_CHILD_MAX; i++) { - rfu_dbg_print_num(0, 1, i + 3, 4); - rfu_dbg_print_str(gUnknown_843EE47, 6, i + 3); - rfu_dbg_print_str(gUnknown_843EE57, 0x16, i + 3); + Debug_PrintNum(0, 1, i + 3, 4); + Debug_PrintString(gUnknown_843EE47, 6, i + 3); + Debug_PrintString(gUnknown_843EE57, 0x16, i + 3); } } } @@ -2848,14 +2903,14 @@ static const char gUnknown_843EEA8[][8] = { "SEARCH" }; -static u32 sub_80FC44C(void) +static u32 GetRfuSendQueueLength(void) { return Rfu.sendQueue.count; } u32 GetRfuRecvQueueLength(void) { - return Rfu.unk_124.count; + return Rfu.recvQueue.count; } static void Task_idle(u8 taskId) diff --git a/src/link_rfu_3.c b/src/link_rfu_3.c index 7aac44593..48fb7fe88 100644 --- a/src/link_rfu_3.c +++ b/src/link_rfu_3.c @@ -163,7 +163,7 @@ static const struct SpriteTemplate sWirelessStatusIndicatorSpriteTemplate = { SpriteCallbackDummy }; -void RFU_queue_20_70_reset(struct UnkRfuStruct_2_Sub_124 *queue) +void RfuRecvQueue_Reset(struct RfuRecvQueue *ptr) { s32 i; s32 j; @@ -172,16 +172,16 @@ void RFU_queue_20_70_reset(struct UnkRfuStruct_2_Sub_124 *queue) { for (j = 0; j < 70; j++) { - queue->slots[i][j] = 0; + ptr->slots[i][j] = 0; } } - queue->send_slot = 0; - queue->recv_slot = 0; - queue->count = 0; - queue->full = 0; + ptr->send_slot = 0; + ptr->recv_slot = 0; + ptr->count = 0; + ptr->full = 0; } -void RFU_queue_40_14_reset(struct RfuSendQueue *ptr) +void RfuSendQueue_Reset(struct RfuSendQueue *ptr) { s32 i; s32 j; @@ -217,20 +217,20 @@ static void RFU_queue_2_256_reset(struct UnkRfuStruct_Sub_Unused *ptr) ptr->full = 0; } -void RFU_queue_20_70_recv(struct UnkRfuStruct_2_Sub_124 *queue, u8 *data) +void RfuRecvQueue_Enqueue(struct RfuRecvQueue *q1, u8 *q2) { s32 i; u16 imeBak; u8 count; - if (queue->count < 20) + if (q1->count < 20) { imeBak = REG_IME; REG_IME = 0; count = 0; for (i = 0; i < 70; i += 14) { - if (data[i] == 0 && data[i + 1] == 0) + if (q2[i] == 0 && q2[i + 1] == 0) { count++; } @@ -239,36 +239,36 @@ void RFU_queue_20_70_recv(struct UnkRfuStruct_2_Sub_124 *queue, u8 *data) { for (i = 0; i < 70; i++) { - queue->slots[queue->recv_slot][i] = data[i]; + q1->slots[q1->recv_slot][i] = q2[i]; } - queue->recv_slot++; - queue->recv_slot %= 20; - queue->count++; + q1->recv_slot++; + q1->recv_slot %= 20; + q1->count++; for (i = 0; i < 70; i++) { - data[i] = 0; + q2[i] = 0; } } REG_IME = imeBak; } else { - queue->full = 1; + q1->full = 1; } } -void RFU_queue_40_14_recv(struct RfuSendQueue *queue, u8 *data) +void RfuSendQueue_Enqueue(struct RfuSendQueue *a0, u8 *a1) { s32 i; u16 imeBak; - if (queue->count < 40) + if (a0->count < 40) { imeBak = REG_IME; REG_IME = 0; for (i = 0; i < 14; i++) { - if (data[i] != 0) + if (a1[i] != 0) { break; } @@ -277,57 +277,57 @@ void RFU_queue_40_14_recv(struct RfuSendQueue *queue, u8 *data) { for (i = 0; i < 14; i++) { - queue->slots[queue->recv_slot][i] = data[i]; + a0->slots[a0->recv_slot][i] = a1[i]; } - queue->recv_slot++; - queue->recv_slot %= 40; - queue->count++; + a0->recv_slot++; + a0->recv_slot %= 40; + a0->count++; for (i = 0; i < 14; i++) { - data[i] = 0; + a1[i] = 0; } } REG_IME = imeBak; } else { - queue->full = 1; + a0->full = 1; } } -bool8 RFU_queue_20_70_send(struct UnkRfuStruct_2_Sub_124 *queue, u8 *dest) +bool8 RfuRecvQueue_Dequeue(struct RfuRecvQueue *a0, u8 *a1) { u16 imeBak; s32 i; imeBak = REG_IME; REG_IME = 0; - if (queue->recv_slot == queue->send_slot || queue->full) + if (a0->recv_slot == a0->send_slot || a0->full) { for (i = 0; i < 70; i++) { - dest[i] = 0; + a1[i] = 0; } REG_IME = imeBak; return FALSE; } for (i = 0; i < 70; i++) { - dest[i] = queue->slots[queue->send_slot][i]; + a1[i] = a0->slots[a0->send_slot][i]; } - queue->send_slot++; - queue->send_slot %= 20; - queue->count--; + a0->send_slot++; + a0->send_slot %= 20; + a0->count--; REG_IME = imeBak; return TRUE; } -bool8 RFU_queue_40_14_send(struct RfuSendQueue *queue, u8 *dest) +bool8 RfuSendQueue_Dequeue(struct RfuSendQueue *q1, u8 *q2) { s32 i; u16 imeBak; - if (queue->recv_slot == queue->send_slot || queue->full != 0) + if (q1->recv_slot == q1->send_slot || q1->full != 0) { return FALSE; } @@ -335,60 +335,60 @@ bool8 RFU_queue_40_14_send(struct RfuSendQueue *queue, u8 *dest) REG_IME = 0; for (i = 0; i < 14; i++) { - dest[i] = queue->slots[queue->send_slot][i]; + q2[i] = q1->slots[q1->send_slot][i]; } - queue->send_slot++; - queue->send_slot %= 40; - queue->count--; + q1->send_slot++; + q1->send_slot %= 40; + q1->count--; REG_IME = imeBak; return TRUE; } -void RFU_queue_2_14_recv(struct UnkRfuStruct_2_Sub_c1c *queue, const u8 *data) +void RfuBackupQueue_Enqueue(struct RfuBackupQueue *q1, const u8 *q2) { s32 i; - if (data[1] == 0) + if (q2[1] == 0) { - RFU_queue_2_14_send(queue, NULL); + RfuBackupQueue_Dequeue(q1, NULL); } else { for (i = 0; i < 14; i++) { - queue->slots[queue->recv_slot][i] = data[i]; + q1->slots[q1->recv_slot][i] = q2[i]; } - queue->recv_slot++; - queue->recv_slot %= 2; - if (queue->count < 2) + q1->recv_slot++; + q1->recv_slot %= 2; + if (q1->count < 2) { - queue->count++; + q1->count++; } else { - queue->send_slot = queue->recv_slot; + q1->send_slot = q1->recv_slot; } } } -bool8 RFU_queue_2_14_send(struct UnkRfuStruct_2_Sub_c1c *queue, u8 *dest) +bool8 RfuBackupQueue_Dequeue(struct RfuBackupQueue *q1, u8 *q2) { s32 i; - if (queue->count == 0) + if (q1->count == 0) { return FALSE; } - if (dest != NULL) + if (q2 != NULL) { for (i = 0; i < 14; i++) { - dest[i] = queue->slots[queue->send_slot][i]; + q2[i] = q1->slots[q1->send_slot][i]; } } - queue->send_slot++; - queue->send_slot %= 2; - queue->count--; + q1->send_slot++; + q1->send_slot %= 2; + q1->count--; return TRUE; } @@ -572,7 +572,7 @@ bool8 LinkRfu_GetNameIfCompatible(struct GFtgtGname *gname, u8 *uname, u8 idx) if (lman.parent_child == MODE_PARENT) { retVal = TRUE; - if (RfuSerialNumberIsValid(gRfuLinkStatus->partner[idx].serialNo) && ((gRfuLinkStatus->getNameFlag >> idx) & 1)) + if (IsRfuSerialNumberValid(gRfuLinkStatus->partner[idx].serialNo) && ((gRfuLinkStatus->getNameFlag >> idx) & 1)) { memcpy(gname, &gRfuLinkStatus->partner[idx].gname, RFU_GAME_NAME_LENGTH); memcpy(uname, gRfuLinkStatus->partner[idx].uname, RFU_USER_NAME_LENGTH); @@ -586,7 +586,7 @@ bool8 LinkRfu_GetNameIfCompatible(struct GFtgtGname *gname, u8 *uname, u8 idx) else { retVal = FALSE; - if (RfuSerialNumberIsValid(gRfuLinkStatus->partner[idx].serialNo)) + if (IsRfuSerialNumberValid(gRfuLinkStatus->partner[idx].serialNo)) { memcpy(gname, &gRfuLinkStatus->partner[idx].gname, RFU_GAME_NAME_LENGTH); memcpy(uname, gRfuLinkStatus->partner[idx].uname, RFU_USER_NAME_LENGTH); @@ -722,7 +722,7 @@ void UpdateWirelessStatusIndicatorSprite(void) { signalStrength = GetParentSignalStrength(); } - if (sub_80FC1B0() == TRUE) + if (IsRfuRecoveringFromLinkLoss() == TRUE) { sprite->data[0] = 4; } @@ -766,7 +766,7 @@ void UpdateWirelessStatusIndicatorSprite(void) gMain.oamBuffer[125].paletteNum = sprite->oam.paletteNum; gMain.oamBuffer[125].tileNum = sprite->data[6] + sprite->anims[sprite->data[2]][sprite->data[4]].frame.imageValue; CpuCopy16(gMain.oamBuffer + 125, (struct OamData *)OAM + 125, sizeof(struct OamData)); - if (RfuGetErrorStatus() == 1) + if (RfuGetStatus() == 1) { DestroyWirelessStatusIndicatorSprite(); } diff --git a/src/mystery_gift_menu.c b/src/mystery_gift_menu.c index 2c455b57a..8290930d7 100644 --- a/src/mystery_gift_menu.c +++ b/src/mystery_gift_menu.c @@ -1270,7 +1270,7 @@ void task00_mystery_gift(u8 taskId) switch (mevent_client_do_exec(&data->curPromptWindowId)) { case 6: // done - Rfu_BeginBuildAndSendCommand5F(); + Rfu_SetCloseLinkCallback(); data->prevPromptWindowId = data->curPromptWindowId; data->state = 13; break; @@ -1633,7 +1633,7 @@ void task00_mystery_gift(u8 taskId) } break; case 33: - Rfu_BeginBuildAndSendCommand5F(); + Rfu_SetCloseLinkCallback(); StringCopy(gStringVar1, gLinkPlayers[1].name); data->state = 34; break; diff --git a/src/pokemon_jump_2.c b/src/pokemon_jump_2.c index 2fe066da1..a771b8fcc 100644 --- a/src/pokemon_jump_2.c +++ b/src/pokemon_jump_2.c @@ -1882,7 +1882,7 @@ static int sub_81497A8(void) static bool32 sub_8149804(void) { - return !Rfu.unk_124.count && !Rfu.sendQueue.count; + return !Rfu.recvQueue.count && !Rfu.sendQueue.count; } static int sub_8149834(u8 *arg0) diff --git a/src/union_room.c b/src/union_room.c index 876e11e19..025ec0ee8 100644 --- a/src/union_room.c +++ b/src/union_room.c @@ -861,7 +861,9 @@ static void Task_TryBecomeLinkLeader(u8 taskId) } break; case 11: - switch (UnionRoomHandleYesNo(&data->textState, TrainerIdAndNameStillInPartnersList(ReadAsU16(data->field_0->arr[data->playerCount].gname_uname.gname.unk_00.playerTrainerId), data->field_0->arr[data->playerCount].gname_uname.uname))) + switch (UnionRoomHandleYesNo(&data->textState, CheckTrainerHasLeftByIdAndName( + ReadAsU16(data->field_0->arr[data->playerCount].gname_uname.gname.unk_00.playerTrainerId), + data->field_0->arr[data->playerCount].gname_uname.uname))) { case 0: LoadWirelessStatusIndicatorSpriteGfx(); @@ -928,7 +930,7 @@ static void Task_TryBecomeLinkLeader(u8 taskId) else if (val == 2) { // Disconnect - RfuSetErrorStatus(0, 0); + RfuSetStatus(0, 0); data->state = 4; } break; @@ -1027,7 +1029,7 @@ static void Task_TryBecomeLinkLeader(u8 taskId) gSpecialVar_Result = 8; break; case 26: - if (RfuIsErrorStatus1or2()) + if (RfuHasErrored()) { data->state = 29; } @@ -1152,7 +1154,7 @@ static bool8 Leader_SetStateIfMemberListChanged(struct UnkStruct_Leader * data, data->state = state1; break; case UNION_ROOM_SPAWN_OUT: - RfuSetErrorStatus(0, 0); + RfuSetStatus(0, 0); RedrawListMenu(data->listTaskId); data->state = state2; return TRUE; @@ -1387,7 +1389,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) if (gReceivedRemoteLinkPlayers) { sPlayerCurrActivity = data->field_0->arr[data->leaderId].gname_uname.gname.activity; - RfuSetErrorStatus(0, 0); + RfuSetStatus(0, 0); switch (sPlayerCurrActivity) { case ACTIVITY_BATTLE: @@ -1407,7 +1409,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) } } - switch (RfuGetErrorStatus()) + switch (RfuGetStatus()) { case 1: data->state = 12; @@ -1421,7 +1423,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) GetGroupLeaderSentAnOKMessage(gStringVar4, sPlayerCurrActivity); if (PrintOnTextbox(&data->textState, gStringVar4)) { - RfuSetErrorStatus(7, 0); + RfuSetStatus(7, 0); StringCopy(gStringVar1, sUnionRoomActivityStringPtrs[sPlayerCurrActivity]); StringExpandPlaceholders(gStringVar4, gUnknown_8457700); } @@ -1432,7 +1434,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) { if (PrintOnTextbox(&data->textState, gStringVar4)) { - RfuSetErrorStatus(12, 0); + RfuSetStatus(12, 0); data->delayBeforePrint = 0; } } @@ -1443,7 +1445,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) break; } - if (!RfuGetErrorStatus() && JOY_NEW(B_BUTTON)) + if (!RfuGetStatus() && JOY_NEW(B_BUTTON)) data->state = 7; break; case 7: @@ -1451,10 +1453,10 @@ static void Task_TryJoinLinkGroup(u8 taskId) data->state = 8; break; case 8: - switch (UnionRoomHandleYesNo(&data->textState, RfuGetErrorStatus())) + switch (UnionRoomHandleYesNo(&data->textState, RfuGetStatus())) { case 0: - LinkRfuNIsend8(); + SendLeaveGroupNotice(); data->state = 9; RedrawListMenu(data->listTaskId); break; @@ -1470,7 +1472,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) } break; case 9: - if (RfuGetErrorStatus()) + if (RfuGetStatus()) data->state = 6; break; case 10: @@ -1494,7 +1496,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) break; case 13: DestroyWirelessStatusIndicatorSprite(); - if (PrintOnTextbox(&data->textState, gUnknown_8457754[RfuGetErrorStatus()])) + if (PrintOnTextbox(&data->textState, gUnknown_8457754[RfuGetStatus()])) { gSpecialVar_Result = 6; data->state = 23; @@ -1507,7 +1509,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) break; case 15: DestroyWirelessStatusIndicatorSprite(); - if (PrintOnTextbox(&data->textState, gUnknown_8457754[RfuGetErrorStatus()])) + if (PrintOnTextbox(&data->textState, gUnknown_8457754[RfuGetStatus()])) { gSpecialVar_Result = 8; data->state = 23; @@ -2180,7 +2182,7 @@ static void Task_MEvent_Leader(u8 taskId) } else if (val == 2) { - RfuSetErrorStatus(0, 0); + RfuSetStatus(0, 0); data->state = 2; } break; @@ -2228,7 +2230,7 @@ static void Task_MEvent_Leader(u8 taskId) } break; case 15: - if (RfuGetErrorStatus() == 1 || RfuGetErrorStatus() == 2) + if (RfuGetStatus() == 1 || RfuGetStatus() == 2) { data->state = 13; } @@ -2370,7 +2372,7 @@ static void Task_CardOrNewsWithFriend(u8 taskId) data->state = 10; } - switch (RfuGetErrorStatus()) + switch (RfuGetStatus()) { case 1: case 2: @@ -2379,7 +2381,7 @@ static void Task_CardOrNewsWithFriend(u8 taskId) break; case 5: AddTextPrinterToWindow1(gUnknown_84576AC); - RfuSetErrorStatus(0, 0); + RfuSetStatus(0, 0); break; } break; @@ -2396,7 +2398,7 @@ static void Task_CardOrNewsWithFriend(u8 taskId) data->state++; break; case 9: - if (MG_PrintTextOnWindow1AndWaitButton(&data->textState, gUnknown_8457838[RfuGetErrorStatus()])) + if (MG_PrintTextOnWindow1AndWaitButton(&data->textState, gUnknown_8457838[RfuGetStatus()])) { DestroyWirelessStatusIndicatorSprite(); DestroyTask(taskId); @@ -2535,7 +2537,7 @@ static void Task_CardOrNewsOverWireless(u8 taskId) data->state = 12; } - switch (RfuGetErrorStatus()) + switch (RfuGetStatus()) { case 1: case 2: @@ -2544,7 +2546,7 @@ static void Task_CardOrNewsOverWireless(u8 taskId) break; case 5: AddTextPrinterToWindow1(gUnknown_845777C); - RfuSetErrorStatus(0, 0); + RfuSetStatus(0, 0); break; } break; @@ -2837,7 +2839,7 @@ static void Task_RunUnionRoom(u8 taskId) break; case 25: UR_RunTextPrinters_CheckPrinter0Active(); - switch (RfuGetErrorStatus()) + switch (RfuGetStatus()) { case 4: HandleCancelTrade(TRUE); @@ -3032,7 +3034,7 @@ static void Task_RunUnionRoom(u8 taskId) } break; case 21: - switch (RfuGetErrorStatus()) + switch (RfuGetStatus()) { case 4: HandleCancelTrade(TRUE); @@ -3054,7 +3056,7 @@ static void Task_RunUnionRoom(u8 taskId) taskData[3]++; break; case 22: - if (RfuIsErrorStatus1or2()) + if (RfuHasErrored()) { playerGender = GetUnionRoomPlayerGender(taskData[1], data->field_0); UpdateGameDataWithActivitySpriteGendersFlag(ACTIVITY_PLYRTALK | IN_UNION_ROOM, 0, TRUE); @@ -3073,7 +3075,7 @@ static void Task_RunUnionRoom(u8 taskId) data->recvActivityRequest[0] = 0; break; case 12: - if (RfuIsErrorStatus1or2()) + if (RfuHasErrored()) { HandleCancelTrade(FALSE); data->state = 2; diff --git a/src/union_room_chat.c b/src/union_room_chat.c index 85df5cd39..524ce7e89 100644 --- a/src/union_room_chat.c +++ b/src/union_room_chat.c @@ -324,7 +324,7 @@ static void ChatEntryRoutine_Join(void) sWork->routineState++; // fall through case 1: - if (IsLinkTaskFinished() && !GetRfuUnkCE8()) + if (IsLinkTaskFinished() && !RfuHasFoundNewLeader()) { if (SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) sWork->routineState++; @@ -527,14 +527,14 @@ static void ChatEntryRoutine_AskQuitChatting(void) sWork->routineState = 3; break; case 0: - sub_80FA4A8(); + Rfu_UnionRoomChat_StopLinkManager(); PrepareSendBuffer_Disband(sWork->sendMessageBuffer); sWork->routineState = 4; break; } break; case 4: - if (IsLinkTaskFinished() && !GetRfuUnkCE8() && SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) + if (IsLinkTaskFinished() && !RfuHasFoundNewLeader() && SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) { if (sWork->multiplayerId == 0) sWork->routineState = 6; @@ -577,15 +577,15 @@ static void ChatEntryRoutine_ExitChat(void) } break; case 3: - if (IsLinkTaskFinished() && !GetRfuUnkCE8() && SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) + if (IsLinkTaskFinished() && !RfuHasFoundNewLeader() && SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) sWork->routineState++; break; case 4: - if ((GetBlockReceivedStatus() & 1) && !GetRfuUnkCE8()) + if ((GetBlockReceivedStatus() & 1) && !RfuHasFoundNewLeader()) sWork->routineState++; break; case 5: - if (IsLinkTaskFinished() && !GetRfuUnkCE8()) + if (IsLinkTaskFinished() && !RfuHasFoundNewLeader()) { SetCloseLinkCallback(); sWork->exitDelayTimer = 0; @@ -620,7 +620,7 @@ static void ChatEntryRoutine_Drop(void) } break; case 1: - if (!RunDisplaySubtask(0) && IsLinkTaskFinished() && !GetRfuUnkCE8()) + if (!RunDisplaySubtask(0) && IsLinkTaskFinished() && !RfuHasFoundNewLeader()) { SetCloseLinkCallback(); sWork->exitDelayTimer = 0; @@ -666,7 +666,7 @@ static void ChatEntryRoutine_Disbanded(void) } break; case 2: - if (RunDisplaySubtask(0) != TRUE && IsLinkTaskFinished() && !GetRfuUnkCE8()) + if (RunDisplaySubtask(0) != TRUE && IsLinkTaskFinished() && !RfuHasFoundNewLeader()) { SetCloseLinkCallback(); sWork->exitDelayTimer = 0; @@ -704,7 +704,7 @@ static void ChatEntryRoutine_SendMessage(void) sWork->routineState++; // fall through case 1: - if (IsLinkTaskFinished() == TRUE && !GetRfuUnkCE8() && SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) + if (IsLinkTaskFinished() == TRUE && !RfuHasFoundNewLeader() && SendBlock(0, sWork->sendMessageBuffer, sizeof(sWork->sendMessageBuffer))) sWork->routineState++; break; case 2: @@ -1355,7 +1355,7 @@ static void Task_ReceiveChatMessage(u8 taskId) } tBlockReceivedStatus = GetBlockReceivedStatus(); - if (!tBlockReceivedStatus && GetRfuUnkCE8()) + if (!tBlockReceivedStatus && RfuHasFoundNewLeader()) return; tI = 0; @@ -1409,7 +1409,7 @@ static void Task_ReceiveChatMessage(u8 taskId) // You're the leader, and the person who left is not you if (GetLinkPlayerCount() == 2) { - sub_80FA4A8(); + Rfu_UnionRoomChat_StopLinkManager(); sWork->exitType = CHATEXIT_LEADER_LAST; DestroyTask(taskId); return; @@ -1433,7 +1433,7 @@ static void Task_ReceiveChatMessage(u8 taskId) DestroyTask(taskId); break; case 2: - if (!GetRfuUnkCE8()) + if (!RfuHasFoundNewLeader()) { if (sWork->multiplayerId == 0) sub_80FB030(sWork->linkPlayerCount); From c7e8b0857a1a56c9e1e656e55dd7fe33de98f161 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Tue, 1 Jun 2021 16:27:38 -0400 Subject: [PATCH 13/21] Sync link_rfu_3.c from Emerald --- include/link_rfu.h | 25 ++- src/link_rfu_3.c | 540 ++++++++++++++++++++++++++++----------------- 2 files changed, 357 insertions(+), 208 deletions(-) diff --git a/include/link_rfu.h b/include/link_rfu.h index 03f9a1f06..6d7e54129 100644 --- a/include/link_rfu.h +++ b/include/link_rfu.h @@ -31,6 +31,9 @@ #define BACKUP_QUEUE_NUM_SLOTS 2 #define BACKUP_QUEUE_SLOT_LENGTH 14 +#define UNUSED_QUEUE_NUM_SLOTS 2 +#define UNUSED_QUEUE_SLOT_LENGTH 256 + #define RFU_PACKET_SIZE 6 #define RFU_STATUS_OK 0 @@ -57,7 +60,7 @@ struct GFtgtGnameSub u16 language:4; u16 hasNews:1; u16 hasCard:1; - u16 unk_00_6:1; + u16 unknown:1; u16 isChampion:1; u16 hasNationalDex:1; u16 gameClear:1; @@ -125,9 +128,9 @@ struct RfuBackupQueue /* 0x1e */ vu8 count; }; -struct UnkRfuStruct_Sub_Unused +struct RfuUnusedQueue { - /* 0x000 */ u8 slots[2][256]; + /* 0x000 */ u8 slots[UNUSED_QUEUE_NUM_SLOTS][UNUSED_QUEUE_SLOT_LENGTH]; /* 0x200 */ vu8 recv_slot; /* 0x201 */ vu8 send_slot; /* 0x202 */ vu8 count; @@ -246,17 +249,17 @@ void UpdateWirelessStatusIndicatorSprite(void); void InitRFU(void); bool32 RfuHasErrored(void); -void RfuRecvQueue_Reset(struct RfuRecvQueue *ptr); -void RfuSendQueue_Reset(struct RfuSendQueue *ptr); +void RfuRecvQueue_Reset(struct RfuRecvQueue *queue); +void RfuSendQueue_Reset(struct RfuSendQueue *queue); void RfuSetStatus(u8 status, u16 msg); u8 RfuGetStatus(void); -void RfuRecvQueue_Enqueue(struct RfuRecvQueue *q1, u8 *q2); -bool8 RfuSendQueue_Dequeue(struct RfuSendQueue *q1, u8 *q2); -bool8 RfuBackupQueue_Dequeue(struct RfuBackupQueue *q1, u8 *q2); -void RfuBackupQueue_Enqueue(struct RfuBackupQueue *q1, const u8 *q2); -bool8 RfuRecvQueue_Dequeue(struct RfuRecvQueue * a0, u8 *a1); -void RfuSendQueue_Enqueue(struct RfuSendQueue * a0, u8 *a1); +void RfuRecvQueue_Enqueue(struct RfuRecvQueue *queue, u8 *src); +bool8 RfuSendQueue_Dequeue(struct RfuSendQueue *queue, u8 *dest); +bool8 RfuBackupQueue_Dequeue(struct RfuBackupQueue *queue, u8 *dest); +void RfuBackupQueue_Enqueue(struct RfuBackupQueue *queue, const u8 *dest); +bool8 RfuRecvQueue_Dequeue(struct RfuRecvQueue * queue, u8 *dest); +void RfuSendQueue_Enqueue(struct RfuSendQueue * queue, u8 *src); void InitHostRFUtgtGname(struct GFtgtGname *data, u8 activity, bool32 started, s32 child_sprite_genders); void UpdateGameData_GroupLockedIn(bool8 started); bool32 IsRfuSerialNumberValid(u32 serialNo); diff --git a/src/link_rfu_3.c b/src/link_rfu_3.c index 48fb7fe88..91695dfc9 100644 --- a/src/link_rfu_3.c +++ b/src/link_rfu_3.c @@ -13,22 +13,83 @@ static const u16 gWirelessLinkIconPalette[] = INCBIN_U16("graphics/interface/wir static const u32 gWirelessLinkIconPic[] = INCBIN_U32("graphics/interface/wireless_link_icon.4bpp.lz"); static const u8 sWireless_ASCIItoRSETable[] = { - 0xff, 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a, 0x37, + EOS, + 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a, 0x37, 0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f, - 0x00, 0xab, 0xb5, 0xb6, 0xb1, 0x00, 0x00, 0x00, - 0x00, 0x00, 0xb2, 0xf1, 0x00, 0xae, 0xad, 0xba, - 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7, 0xa8, - 0xa9, 0xaa, 0x00, 0x9b, 0x9c, 0x9d, 0x9e, 0x9f, - 0x00, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf, 0xc0, 0xc1, - 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, - 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf, 0xd0, 0xd1, - 0xd2, 0xd3, 0xd4, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, - 0x00, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xdb, - 0xdc, 0xdd, 0xde, 0xdf, 0xe0, 0xe1, 0xe2, 0xe3, - 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xeb, - 0xec, 0xed, 0xee, 0x2d, 0x2f, 0x30, 0x31, 0x32, + [' '] = CHAR_SPACE, + ['!'] = CHAR_EXCL_MARK, + 0xb5, 0xb6, 0xb1, 0x00, 0x00, 0x00, + 0x00, 0x00, 0xb2, 0xf1, 0x00, + ['-'] = CHAR_HYPHEN, + ['.'] = CHAR_PERIOD, + ['/'] = CHAR_SLASH, + ['0'] = CHAR_0, + ['1'] = CHAR_1, + ['2'] = CHAR_2, + ['3'] = CHAR_3, + ['4'] = CHAR_4, + ['5'] = CHAR_5, + ['6'] = CHAR_6, + ['7'] = CHAR_7, + ['8'] = CHAR_8, + ['9'] = CHAR_9, + 0x00, 0x9b, 0x9c, 0x9d, 0x9e, 0x9f, 0x00, + ['A'] = CHAR_A, + ['B'] = CHAR_B, + ['C'] = CHAR_C, + ['D'] = CHAR_D, + ['E'] = CHAR_E, + ['F'] = CHAR_F, + ['G'] = CHAR_G, + ['H'] = CHAR_H, + ['I'] = CHAR_I, + ['J'] = CHAR_J, + ['K'] = CHAR_K, + ['L'] = CHAR_L, + ['M'] = CHAR_M, + ['N'] = CHAR_N, + ['O'] = CHAR_O, + ['P'] = CHAR_P, + ['Q'] = CHAR_Q, + ['R'] = CHAR_R, + ['S'] = CHAR_S, + ['T'] = CHAR_T, + ['U'] = CHAR_U, + ['V'] = CHAR_V, + ['W'] = CHAR_W, + ['X'] = CHAR_X, + ['Y'] = CHAR_Y, + ['Z'] = CHAR_Z, + 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0x00, + ['a'] = CHAR_a, + ['b'] = CHAR_b, + ['c'] = CHAR_c, + ['d'] = CHAR_d, + ['e'] = CHAR_e, + ['f'] = CHAR_f, + ['g'] = CHAR_g, + ['h'] = CHAR_h, + ['i'] = CHAR_i, + ['j'] = CHAR_j, + ['k'] = CHAR_k, + ['l'] = CHAR_l, + ['m'] = CHAR_m, + ['n'] = CHAR_n, + ['o'] = CHAR_o, + ['p'] = CHAR_p, + ['q'] = CHAR_q, + ['r'] = CHAR_r, + ['s'] = CHAR_s, + ['t'] = CHAR_t, + ['u'] = CHAR_u, + ['v'] = CHAR_v, + ['w'] = CHAR_w, + ['x'] = CHAR_x, + ['y'] = CHAR_y, + ['z'] = CHAR_z, + 0x2d, 0x2f, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x50, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, @@ -48,53 +109,118 @@ static const u8 sWireless_ASCIItoRSETable[] = { }; static const u8 sWireless_RSEtoASCIITable[] = { - 0x20, 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c, - 0x8d, 0x8e, 0x8f, 0x90, 0x91, 0x92, 0x93, 0x94, - 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a, 0x9b, 0x9c, - 0x9d, 0x9e, 0x9f, 0xa0, 0xe0, 0xe1, 0xe2, 0xe3, - 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xeb, - 0xec, 0xed, 0xee, 0xef, 0xf0, 0x7b, 0xf1, 0x7c, - 0x7d, 0x7e, 0x7f, 0x80, 0x81, 0x82, 0x83, 0x07, - 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, - 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, - 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f, - 0x84, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6, 0xb7, - 0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf, - 0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, - 0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf, - 0xd0, 0xd1, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, - 0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xa6, 0xdd, 0xa7, - 0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xf2, - 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa, - 0xfb, 0xfc, 0xfd, 0xfe, 0xff, 0x01, 0x02, 0x03, - 0x04, 0x05, 0x06, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, - 0xaf, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, - 0x37, 0x38, 0x39, 0x21, 0xdf, 0xa1, 0xb0, 0xa5, - 0xde, 0x24, 0x2a, 0xa2, 0xa3, 0x22, 0x23, 0x20, - 0xa4, 0x20, 0x2f, 0x41, 0x42, 0x43, 0x44, 0x45, - 0x46, 0x47, 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, - 0x4e, 0x4f, 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, - 0x56, 0x57, 0x58, 0x59, 0x5a, 0x61, 0x62, 0x63, - 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6a, 0x6b, - 0x6c, 0x6d, 0x6e, 0x6f, 0x70, 0x71, 0x72, 0x73, - 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7a, 0x20, - 0x20, 0x2b, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f, 0x20, - 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x00 + [CHAR_SPACE] = ' ', + 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, + 0x8e, 0x8f, 0x90, 0x91, 0x92, 0x93, 0x94, 0x95, + 0x96, 0x97, 0x98, 0x99, 0x9a, 0x9b, 0x9c, 0x9d, + 0x9e, 0x9f, 0xa0, 0xe0, 0xe1, 0xe2, 0xe3, 0xe4, + 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xeb, 0xec, + 0xed, 0xee, 0xef, 0xf0, 0x7b, 0xf1, 0x7c, 0x7d, + 0x7e, 0x7f, 0x80, 0x81, 0x82, 0x83, 0x07, 0x08, + 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, + 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, + 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f, 0x84, + 0xb1, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6, 0xb7, 0xb8, + 0xb9, 0xba, 0xbb, 0xbc, 0xbd, 0xbe, 0xbf, 0xc0, + 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, + 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf, 0xd0, + 0xd1, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, + 0xd9, 0xda, 0xdb, 0xdc, 0xa6, 0xdd, 0xa7, 0xa8, + 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xf2, 0xf3, + 0xf4, 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa, 0xfb, + 0xfc, 0xfd, 0xfe, 0xff, 0x01, 0x02, 0x03, 0x04, + 0x05, 0x06, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, 0xaf, + [CHAR_0] = '0', + [CHAR_1] = '1', + [CHAR_2] = '2', + [CHAR_3] = '3', + [CHAR_4] = '4', + [CHAR_5] = '5', + [CHAR_6] = '6', + [CHAR_7] = '7', + [CHAR_8] = '8', + [CHAR_9] = '9', + [CHAR_EXCL_MARK] = '!', + 0xdf, 0xa1, 0xb0, 0xa5, 0xde, 0x24, 0x2a, + 0xa2, 0xa3, 0x22, 0x23, 0x20, 0xa4, 0x20, + [CHAR_SLASH] = '/', + [CHAR_A] = 'A', + [CHAR_B] = 'B', + [CHAR_C] = 'C', + [CHAR_D] = 'D', + [CHAR_E] = 'E', + [CHAR_F] = 'F', + [CHAR_G] = 'G', + [CHAR_H] = 'H', + [CHAR_I] = 'I', + [CHAR_J] = 'J', + [CHAR_K] = 'K', + [CHAR_L] = 'L', + [CHAR_M] = 'M', + [CHAR_N] = 'N', + [CHAR_O] = 'O', + [CHAR_P] = 'P', + [CHAR_Q] = 'Q', + [CHAR_R] = 'R', + [CHAR_S] = 'S', + [CHAR_T] = 'T', + [CHAR_U] = 'U', + [CHAR_V] = 'V', + [CHAR_W] = 'W', + [CHAR_X] = 'X', + [CHAR_Y] = 'Y', + [CHAR_Z] = 'Z', + [CHAR_a] = 'a', + [CHAR_b] = 'b', + [CHAR_c] = 'c', + [CHAR_d] = 'd', + [CHAR_e] = 'e', + [CHAR_f] = 'f', + [CHAR_g] = 'g', + [CHAR_h] = 'h', + [CHAR_i] = 'i', + [CHAR_j] = 'j', + [CHAR_k] = 'k', + [CHAR_l] = 'l', + [CHAR_m] = 'm', + [CHAR_n] = 'n', + [CHAR_o] = 'o', + [CHAR_p] = 'p', + [CHAR_q] = 'q', + [CHAR_r] = 'r', + [CHAR_s] = 's', + [CHAR_t] = 't', + [CHAR_u] = 'u', + [CHAR_v] = 'v', + [CHAR_w] = 'w', + [CHAR_x] = 'x', + [CHAR_y] = 'y', + [CHAR_z] = 'z', + 0x20, 0x20, 0x2b, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f, + [CHAR_DYNAMIC_PLACEHOLDER] = ' ', + [CHAR_KEYPAD_ICON] = ' ', + [CHAR_EXTRA_EMOJI] = ' ', + [CHAR_PROMPT_SCROLL] = ' ', + [CHAR_PROMPT_CLEAR] = ' ', + [EXT_CTRL_CODE_BEGIN] = ' ', + [PLACEHOLDER_BEGIN] = ' ', + [CHAR_NEWLINE] = ' ', + [EOS] = 0 }; static const struct OamData sWirelessStatusIndicatorOamData = - { - .y = 0, - .affineMode = ST_OAM_AFFINE_OFF, - .objMode = ST_OAM_OBJ_NORMAL, - .bpp = ST_OAM_4BPP, - .shape = SPRITE_SHAPE(16x16), - .x = 0, - .size = SPRITE_SIZE(16x16), - .tileNum = 0, - .priority = 0, - .paletteNum = 0, - }; +{ + .y = 0, + .affineMode = ST_OAM_AFFINE_OFF, + .objMode = ST_OAM_OBJ_NORMAL, + .bpp = ST_OAM_4BPP, + .shape = SPRITE_SHAPE(16x16), + .x = 0, + .size = SPRITE_SIZE(16x16), + .tileNum = 0, + .priority = 0, + .paletteNum = 0, +}; static const union AnimCmd sWirelessStatusIndicatorAnim0[] = { // 3 bars @@ -154,265 +280,267 @@ static const struct SpritePalette sWirelessStatusIndicatorSpritePalette = { }; static const struct SpriteTemplate sWirelessStatusIndicatorSpriteTemplate = { - 0xD431, - 0xD432, - &sWirelessStatusIndicatorOamData, - sWirelessStatusIndicatorAnims, - NULL, - gDummySpriteAffineAnimTable, - SpriteCallbackDummy + .tileTag = 0xD431, + .paletteTag = 0xD432, + .oam = &sWirelessStatusIndicatorOamData, + .anims = sWirelessStatusIndicatorAnims, + .images = NULL, + .affineAnims = gDummySpriteAffineAnimTable, + .callback = SpriteCallbackDummy }; -void RfuRecvQueue_Reset(struct RfuRecvQueue *ptr) +// A bunch of FIFO queues + +void RfuRecvQueue_Reset(struct RfuRecvQueue *queue) { s32 i; s32 j; - for (i = 0; i < 20; i++) + for (i = 0; i < RECV_QUEUE_NUM_SLOTS; i++) { - for (j = 0; j < 70; j++) + for (j = 0; j < RECV_QUEUE_SLOT_LENGTH; j++) { - ptr->slots[i][j] = 0; + queue->slots[i][j] = 0; } } - ptr->send_slot = 0; - ptr->recv_slot = 0; - ptr->count = 0; - ptr->full = 0; + queue->send_slot = 0; + queue->recv_slot = 0; + queue->count = 0; + queue->full = FALSE; } -void RfuSendQueue_Reset(struct RfuSendQueue *ptr) +void RfuSendQueue_Reset(struct RfuSendQueue *queue) { s32 i; s32 j; - for (i = 0; i < 40; i++) + for (i = 0; i < SEND_QUEUE_NUM_SLOTS; i++) { - for (j = 0; j < 14; j++) + for (j = 0; j < SEND_QUEUE_SLOT_LENGTH; j++) { - ptr->slots[i][j] = 0; + queue->slots[i][j] = 0; } } - ptr->send_slot = 0; - ptr->recv_slot = 0; - ptr->count = 0; - ptr->full = 0; + queue->send_slot = 0; + queue->recv_slot = 0; + queue->count = 0; + queue->full = FALSE; } -static void RFU_queue_2_256_reset(struct UnkRfuStruct_Sub_Unused *ptr) +static void RfuUnusedQueue_Reset(struct RfuUnusedQueue *queue) { s32 i; s32 j; - for (i = 0; i < 2; i++) + for (i = 0; i < UNUSED_QUEUE_NUM_SLOTS; i++) { - for (j = 0; j < 256; j++) + for (j = 0; j < UNUSED_QUEUE_SLOT_LENGTH; j++) { - ptr->slots[i][j] = 0; + queue->slots[i][j] = 0; } } - ptr->send_slot = 0; - ptr->recv_slot = 0; - ptr->count = 0; - ptr->full = 0; + queue->send_slot = 0; + queue->recv_slot = 0; + queue->count = 0; + queue->full = FALSE; } -void RfuRecvQueue_Enqueue(struct RfuRecvQueue *q1, u8 *q2) +void RfuRecvQueue_Enqueue(struct RfuRecvQueue *queue, u8 *src) { s32 i; u16 imeBak; u8 count; - if (q1->count < 20) + if (queue->count < RECV_QUEUE_NUM_SLOTS) { imeBak = REG_IME; REG_IME = 0; count = 0; - for (i = 0; i < 70; i += 14) + for (i = 0; i < RECV_QUEUE_SLOT_LENGTH; i += RECV_QUEUE_SLOT_LENGTH / MAX_RFU_PLAYERS) { - if (q2[i] == 0 && q2[i + 1] == 0) + if (src[i] == 0 && src[i + 1] == 0) { count++; } } - if (count != 5) + if (count != MAX_RFU_PLAYERS) { - for (i = 0; i < 70; i++) + for (i = 0; i < RECV_QUEUE_SLOT_LENGTH; i++) { - q1->slots[q1->recv_slot][i] = q2[i]; + queue->slots[queue->recv_slot][i] = src[i]; } - q1->recv_slot++; - q1->recv_slot %= 20; - q1->count++; - for (i = 0; i < 70; i++) + queue->recv_slot++; + queue->recv_slot %= RECV_QUEUE_NUM_SLOTS; + queue->count++; + for (i = 0; i < RECV_QUEUE_SLOT_LENGTH; i++) { - q2[i] = 0; + src[i] = 0; } } REG_IME = imeBak; } else { - q1->full = 1; + queue->full = TRUE; } } -void RfuSendQueue_Enqueue(struct RfuSendQueue *a0, u8 *a1) +void RfuSendQueue_Enqueue(struct RfuSendQueue *queue, u8 *src) { s32 i; u16 imeBak; - if (a0->count < 40) + if (queue->count < SEND_QUEUE_NUM_SLOTS) { imeBak = REG_IME; REG_IME = 0; - for (i = 0; i < 14; i++) + for (i = 0; i < SEND_QUEUE_SLOT_LENGTH; i++) { - if (a1[i] != 0) + if (src[i] != 0) { break; } } - if (i != 14) + if (i != SEND_QUEUE_SLOT_LENGTH) { - for (i = 0; i < 14; i++) + for (i = 0; i < SEND_QUEUE_SLOT_LENGTH; i++) { - a0->slots[a0->recv_slot][i] = a1[i]; + queue->slots[queue->recv_slot][i] = src[i]; } - a0->recv_slot++; - a0->recv_slot %= 40; - a0->count++; - for (i = 0; i < 14; i++) + queue->recv_slot++; + queue->recv_slot %= SEND_QUEUE_NUM_SLOTS; + queue->count++; + for (i = 0; i < SEND_QUEUE_SLOT_LENGTH; i++) { - a1[i] = 0; + src[i] = 0; } } REG_IME = imeBak; } else { - a0->full = 1; + queue->full = TRUE; } } -bool8 RfuRecvQueue_Dequeue(struct RfuRecvQueue *a0, u8 *a1) +bool8 RfuRecvQueue_Dequeue(struct RfuRecvQueue *queue, u8 *dest) { u16 imeBak; s32 i; imeBak = REG_IME; REG_IME = 0; - if (a0->recv_slot == a0->send_slot || a0->full) + if (queue->recv_slot == queue->send_slot || queue->full) { - for (i = 0; i < 70; i++) + for (i = 0; i < RECV_QUEUE_SLOT_LENGTH; i++) { - a1[i] = 0; + dest[i] = 0; } REG_IME = imeBak; return FALSE; } - for (i = 0; i < 70; i++) + for (i = 0; i < RECV_QUEUE_SLOT_LENGTH; i++) { - a1[i] = a0->slots[a0->send_slot][i]; + dest[i] = queue->slots[queue->send_slot][i]; } - a0->send_slot++; - a0->send_slot %= 20; - a0->count--; + queue->send_slot++; + queue->send_slot %= RECV_QUEUE_NUM_SLOTS; + queue->count--; REG_IME = imeBak; return TRUE; } -bool8 RfuSendQueue_Dequeue(struct RfuSendQueue *q1, u8 *q2) +bool8 RfuSendQueue_Dequeue(struct RfuSendQueue *queue, u8 *dest) { s32 i; u16 imeBak; - if (q1->recv_slot == q1->send_slot || q1->full != 0) + if (queue->recv_slot == queue->send_slot || queue->full) { return FALSE; } imeBak = REG_IME; REG_IME = 0; - for (i = 0; i < 14; i++) + for (i = 0; i < SEND_QUEUE_SLOT_LENGTH; i++) { - q2[i] = q1->slots[q1->send_slot][i]; + dest[i] = queue->slots[queue->send_slot][i]; } - q1->send_slot++; - q1->send_slot %= 40; - q1->count--; + queue->send_slot++; + queue->send_slot %= SEND_QUEUE_NUM_SLOTS; + queue->count--; REG_IME = imeBak; return TRUE; } -void RfuBackupQueue_Enqueue(struct RfuBackupQueue *q1, const u8 *q2) +void RfuBackupQueue_Enqueue(struct RfuBackupQueue *queue, const u8 *dest) { s32 i; - if (q2[1] == 0) + if (dest[1] == 0) { - RfuBackupQueue_Dequeue(q1, NULL); + RfuBackupQueue_Dequeue(queue, NULL); } else { - for (i = 0; i < 14; i++) + for (i = 0; i < BACKUP_QUEUE_SLOT_LENGTH; i++) { - q1->slots[q1->recv_slot][i] = q2[i]; + queue->slots[queue->recv_slot][i] = dest[i]; } - q1->recv_slot++; - q1->recv_slot %= 2; - if (q1->count < 2) + queue->recv_slot++; + queue->recv_slot %= BACKUP_QUEUE_NUM_SLOTS; + if (queue->count < BACKUP_QUEUE_NUM_SLOTS) { - q1->count++; + queue->count++; } else { - q1->send_slot = q1->recv_slot; + queue->send_slot = queue->recv_slot; } } } -bool8 RfuBackupQueue_Dequeue(struct RfuBackupQueue *q1, u8 *q2) +bool8 RfuBackupQueue_Dequeue(struct RfuBackupQueue *queue, u8 *dest) { s32 i; - if (q1->count == 0) + if (queue->count == 0) { return FALSE; } - if (q2 != NULL) + if (dest != NULL) { - for (i = 0; i < 14; i++) + for (i = 0; i < BACKUP_QUEUE_SLOT_LENGTH; i++) { - q2[i] = q1->slots[q1->send_slot][i]; + dest[i] = queue->slots[queue->send_slot][i]; } } - q1->send_slot++; - q1->send_slot %= 2; - q1->count--; + queue->send_slot++; + queue->send_slot %= BACKUP_QUEUE_NUM_SLOTS; + queue->count--; return TRUE; } -static void RFU_queue_2_256_recv(struct UnkRfuStruct_Sub_Unused *queue, u8 *data) +static void RfuUnusedQueue_Dequeue(struct RfuUnusedQueue *queue, u8 *dest) { s32 i; - if (queue->count < 2) + if (queue->count < UNUSED_QUEUE_NUM_SLOTS) { - for (i = 0; i < 256; i++) + for (i = 0; i < UNUSED_QUEUE_SLOT_LENGTH; i++) { - queue->slots[queue->recv_slot][i] = data[i]; + queue->slots[queue->recv_slot][i] = dest[i]; } queue->recv_slot++; - queue->recv_slot %= 2; + queue->recv_slot %= UNUSED_QUEUE_NUM_SLOTS; queue->count++; } else { - queue->full = 1; + queue->full = TRUE; } } -static bool8 RFU_queue_2_256_send(struct UnkRfuStruct_Sub_Unused *queue, u8 *send) +static bool8 RfuUnusedQueue_Enqueue(struct RfuUnusedQueue *queue, u8 *dest) { s32 i; @@ -420,16 +548,17 @@ static bool8 RFU_queue_2_256_send(struct UnkRfuStruct_Sub_Unused *queue, u8 *sen { return FALSE; } - for (i = 0; i < 256; i++) + for (i = 0; i < UNUSED_QUEUE_SLOT_LENGTH; i++) { - send[i] = queue->slots[queue->send_slot][i]; + dest[i] = queue->slots[queue->send_slot][i]; } queue->send_slot++; - queue->send_slot %= 2; + queue->send_slot %= UNUSED_QUEUE_NUM_SLOTS; queue->count--; return TRUE; } +UNUSED static void sub_80FC9B8(u8 *q1, u8 mode) { s32 i; @@ -476,26 +605,26 @@ static void sub_80FC9B8(u8 *q1, u8 mode) } } -static void PkmnStrToASCII(u8 *q1, const u8 *q2) +static void PkmnStrToASCII(u8 *dest, const u8 *src) { s32 i; - for (i = 0; q2[i] != EOS; i++) + for (i = 0; src[i] != EOS; i++) { - q1[i] = sWireless_RSEtoASCIITable[q2[i]]; + dest[i] = sWireless_RSEtoASCIITable[src[i]]; } - q1[i] = 0; + dest[i] = 0; } -static void ASCIIToPkmnStr(u8 *q1, const u8 *q2) +static void ASCIIToPkmnStr(u8 *dest, const u8 *src) { s32 i; - for (i = 0; q2[i] != 0; i++) + for (i = 0; src[i] != 0; i++) { - q1[i] = sWireless_ASCIItoRSETable[q2[i]]; + dest[i] = sWireless_ASCIItoRSETable[src[i]]; } - q1[i] = EOS; + dest[i] = EOS; } static u8 GetConnectedChildStrength(u8 maxFlags) @@ -552,7 +681,7 @@ void InitHostRFUtgtGname(struct GFtgtGname *data, u8 activity, bool32 started, s data->unk_00.version = GAME_VERSION; data->unk_00.hasNews = FALSE; data->unk_00.hasCard = FALSE; - data->unk_00.unk_00_6 = 0; + data->unk_00.unknown = FALSE; data->unk_00.isChampion = FlagGet(FLAG_SYS_CAN_LINK_WITH_RS); data->unk_00.hasNationalDex = IsNationalPokedexEnabled(); data->unk_00.gameClear = FlagGet(FLAG_SYS_GAME_CLEAR); @@ -609,7 +738,7 @@ bool8 LinkRfu_GetNameIfCompatible(struct GFtgtGname *gname, u8 *uname, u8 idx) bool8 LinkRfu_GetNameIfSerial7F7D(struct GFtgtGname *gname, u8 *uname, u8 idx) { bool8 retVal = FALSE; - if (gRfuLinkStatus->partner[idx].serialNo == 0x7F7D) + if (gRfuLinkStatus->partner[idx].serialNo == RFU_SERIAL_7F7D) { memcpy(gname, gRfuLinkStatus->partner[idx].gname, RFU_GAME_NAME_LENGTH); memcpy(uname, gRfuLinkStatus->partner[idx].uname, RFU_USER_NAME_LENGTH); @@ -629,37 +758,46 @@ void LinkRfu3_SetGnameUnameFromStaticBuffers(struct GFtgtGname *gname, u8 *uname memcpy(uname, gHostRFUtgtUnameBuffer, RFU_USER_NAME_LENGTH); } +#define sNextAnimNum data[0] +#define sSavedAnimNum data[1] +#define sCurrAnimNum data[2] +#define sFrameDelay data[3] +#define sFrameIdx data[4] +#define sTileStart data[6] +#define sValidator data[7] +#define STATUS_INDICATOR_ACTIVE 0x1234 // Used to validate active indicator + void CreateWirelessStatusIndicatorSprite(u8 x, u8 y) { u8 sprId; if (x == 0 && y == 0) { - x = 0xE7; - y = 0x08; + x = 231; + y = 8; } if (gRfuLinkStatus->parentChild == MODE_PARENT) { sprId = CreateSprite(&sWirelessStatusIndicatorSpriteTemplate, x, y, 0); - gSprites[sprId].data[7] = 0x1234; - gSprites[sprId].data[6] = GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag); + gSprites[sprId].sValidator = STATUS_INDICATOR_ACTIVE; + gSprites[sprId].sTileStart = GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag); gSprites[sprId].invisible = TRUE; gWirelessStatusIndicatorSpriteId = sprId; } else { gWirelessStatusIndicatorSpriteId = CreateSprite(&sWirelessStatusIndicatorSpriteTemplate, x, y, 0); - gSprites[gWirelessStatusIndicatorSpriteId].data[7] = 0x1234; - gSprites[gWirelessStatusIndicatorSpriteId].data[6] = GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag); + gSprites[gWirelessStatusIndicatorSpriteId].sValidator = STATUS_INDICATOR_ACTIVE; + gSprites[gWirelessStatusIndicatorSpriteId].sTileStart = GetSpriteTileStartByTag(sWirelessStatusIndicatorSpriteSheet.tag); gSprites[gWirelessStatusIndicatorSpriteId].invisible = TRUE; } } void DestroyWirelessStatusIndicatorSprite(void) { - if (gSprites[gWirelessStatusIndicatorSpriteId].data[7] == 0x1234) + if (gSprites[gWirelessStatusIndicatorSpriteId].sValidator == STATUS_INDICATOR_ACTIVE) { - gSprites[gWirelessStatusIndicatorSpriteId].data[7] = 0; + gSprites[gWirelessStatusIndicatorSpriteId].sValidator = 0; DestroySprite(&gSprites[gWirelessStatusIndicatorSpriteId]); gMain.oamBuffer[125] = gDummyOamData; CpuCopy16(&gDummyOamData, (struct OamData *)OAM + 125, sizeof(struct OamData)); @@ -693,17 +831,17 @@ static u8 GetParentSignalStrength(void) static void SetAndRestartWirelessStatusIndicatorAnim(struct Sprite *sprite, s32 signalStrengthAnimNum) { - if (sprite->data[2] != signalStrengthAnimNum) + if (sprite->sCurrAnimNum != signalStrengthAnimNum) { - sprite->data[2] = signalStrengthAnimNum; - sprite->data[3] = 0; - sprite->data[4] = 0; + sprite->sCurrAnimNum = signalStrengthAnimNum; + sprite->sFrameDelay = 0; + sprite->sFrameIdx = 0; } } void UpdateWirelessStatusIndicatorSprite(void) { - if (gWirelessStatusIndicatorSpriteId != 0xFF && gSprites[gWirelessStatusIndicatorSpriteId].data[7] == 0x1234) + if (gWirelessStatusIndicatorSpriteId != 0xFF && gSprites[gWirelessStatusIndicatorSpriteId].sValidator == STATUS_INDICATOR_ACTIVE) { struct Sprite *sprite = &gSprites[gWirelessStatusIndicatorSpriteId]; u8 signalStrength = RFU_LINK_ICON_LEVEL4_MAX; @@ -724,55 +862,63 @@ void UpdateWirelessStatusIndicatorSprite(void) } if (IsRfuRecoveringFromLinkLoss() == TRUE) { - sprite->data[0] = 4; + sprite->sNextAnimNum = 4; } else if (signalStrength <= RFU_LINK_ICON_LEVEL1_MAX) { - sprite->data[0] = 3; + sprite->sNextAnimNum = 3; } else if (signalStrength >= RFU_LINK_ICON_LEVEL2_MIN && signalStrength <= RFU_LINK_ICON_LEVEL2_MAX) { - sprite->data[0] = 2; + sprite->sNextAnimNum = 2; } else if (signalStrength >= RFU_LINK_ICON_LEVEL3_MIN && signalStrength <= RFU_LINK_ICON_LEVEL3_MAX) { - sprite->data[0] = 1; + sprite->sNextAnimNum = 1; } else if (signalStrength >= RFU_LINK_ICON_LEVEL4_MIN) { - sprite->data[0] = 0; + sprite->sNextAnimNum = 0; } - if (sprite->data[0] != sprite->data[1]) + if (sprite->sNextAnimNum != sprite->sSavedAnimNum) { - SetAndRestartWirelessStatusIndicatorAnim(sprite, sprite->data[0]); - sprite->data[1] = sprite->data[0]; + SetAndRestartWirelessStatusIndicatorAnim(sprite, sprite->sNextAnimNum); + sprite->sSavedAnimNum = sprite->sNextAnimNum; } - if (sprite->anims[sprite->data[2]][sprite->data[4]].frame.duration < sprite->data[3]) + if (sprite->anims[sprite->sCurrAnimNum][sprite->sFrameIdx].frame.duration < sprite->sFrameDelay) { - sprite->data[4]++; - sprite->data[3] = 0; - if (sprite->anims[sprite->data[2]][sprite->data[4]].type == -2) + sprite->sFrameIdx++; + sprite->sFrameDelay = 0; + if (sprite->anims[sprite->sCurrAnimNum][sprite->sFrameIdx].type == -2) // ANIMCMD_JUMP { - sprite->data[4] = 0; + sprite->sFrameIdx = 0; } } else { - sprite->data[3]++; + sprite->sFrameDelay++; } gMain.oamBuffer[125] = sWirelessStatusIndicatorOamData; gMain.oamBuffer[125].x = sprite->pos1.x + sprite->centerToCornerVecX; gMain.oamBuffer[125].y = sprite->pos1.y + sprite->centerToCornerVecY; gMain.oamBuffer[125].paletteNum = sprite->oam.paletteNum; - gMain.oamBuffer[125].tileNum = sprite->data[6] + sprite->anims[sprite->data[2]][sprite->data[4]].frame.imageValue; + gMain.oamBuffer[125].tileNum = sprite->sTileStart + sprite->anims[sprite->sCurrAnimNum][sprite->sFrameIdx].frame.imageValue; CpuCopy16(gMain.oamBuffer + 125, (struct OamData *)OAM + 125, sizeof(struct OamData)); - if (RfuGetStatus() == 1) + if (RfuGetStatus() == RFU_STATUS_FATAL_ERROR) { DestroyWirelessStatusIndicatorSprite(); } } } +#undef sNextAnimNum +#undef sSavedAnimNum +#undef sCurrAnimNum +#undef sFrameDelay +#undef sFrameIdx +#undef sTileStart +#undef sValidator + static void CopyTrainerRecord(struct TrainerNameRecord *dest, u32 trainerId, const u8 *name) { int i; From c9ef0d1b7ae8cc68b4ef832f4a3c1f9cd85f716d Mon Sep 17 00:00:00 2001 From: Kurausukun Date: Tue, 1 Jun 2021 17:16:24 -0400 Subject: [PATCH 14/21] re-add const to gEvolutionTable in daycare.c --- src/daycare.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/daycare.c b/src/daycare.c index e29c0fc70..1c3f24ba3 100644 --- a/src/daycare.c +++ b/src/daycare.c @@ -32,7 +32,7 @@ // Combination of RSE's Day-Care (re-used on Four Island), FRLG's Day-Care, and egg_hatch.c -extern struct Evolution gEvolutionTable[][EVOS_PER_MON]; +extern const struct Evolution gEvolutionTable[][EVOS_PER_MON]; struct EggHatchData { From b3dfc556b1019b2610cb903ef888ff61c94372a8 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Wed, 2 Jun 2021 13:18:59 -0400 Subject: [PATCH 15/21] Minor aesthetic tweaks RE review --- src/link_rfu_2.c | 6 ++---- src/union_room.c | 16 ++++++++-------- 2 files changed, 10 insertions(+), 12 deletions(-) diff --git a/src/link_rfu_2.c b/src/link_rfu_2.c index 8b37c5214..76db5d1b0 100644 --- a/src/link_rfu_2.c +++ b/src/link_rfu_2.c @@ -905,11 +905,9 @@ static bool32 RfuProcessEnqueuedRecvBlock(void) rfu_REQ_disconnect(gRfuLinkStatus->connSlotFlag | gRfuLinkStatus->linkLossSlotFlag); rfu_waitREQComplete(); status = RfuGetStatus(); - if ( - status != RFU_STATUS_FATAL_ERROR + if (status != RFU_STATUS_FATAL_ERROR && status != RFU_STATUS_JOIN_GROUP_NO - && status != RFU_STATUS_LEAVE_GROUP - ) + && status != RFU_STATUS_LEAVE_GROUP) RfuSetStatus(RFU_STATUS_CONNECTION_ERROR, 0x9000); rfu_clearAllSlot(); gReceivedRemoteLinkPlayers = FALSE; diff --git a/src/union_room.c b/src/union_room.c index 025ec0ee8..575fcd60e 100644 --- a/src/union_room.c +++ b/src/union_room.c @@ -930,7 +930,7 @@ static void Task_TryBecomeLinkLeader(u8 taskId) else if (val == 2) { // Disconnect - RfuSetStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); data->state = 4; } break; @@ -1154,7 +1154,7 @@ static bool8 Leader_SetStateIfMemberListChanged(struct UnkStruct_Leader * data, data->state = state1; break; case UNION_ROOM_SPAWN_OUT: - RfuSetStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); RedrawListMenu(data->listTaskId); data->state = state2; return TRUE; @@ -1389,7 +1389,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) if (gReceivedRemoteLinkPlayers) { sPlayerCurrActivity = data->field_0->arr[data->leaderId].gname_uname.gname.activity; - RfuSetStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); switch (sPlayerCurrActivity) { case ACTIVITY_BATTLE: @@ -1423,7 +1423,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) GetGroupLeaderSentAnOKMessage(gStringVar4, sPlayerCurrActivity); if (PrintOnTextbox(&data->textState, gStringVar4)) { - RfuSetStatus(7, 0); + RfuSetStatus(RFU_STATUS_WAIT_ACK_JOIN_GROUP, 0); StringCopy(gStringVar1, sUnionRoomActivityStringPtrs[sPlayerCurrActivity]); StringExpandPlaceholders(gStringVar4, gUnknown_8457700); } @@ -1434,7 +1434,7 @@ static void Task_TryJoinLinkGroup(u8 taskId) { if (PrintOnTextbox(&data->textState, gStringVar4)) { - RfuSetStatus(12, 0); + RfuSetStatus(RFU_STATUS_ACK_JOIN_GROUP, 0); data->delayBeforePrint = 0; } } @@ -2182,7 +2182,7 @@ static void Task_MEvent_Leader(u8 taskId) } else if (val == 2) { - RfuSetStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); data->state = 2; } break; @@ -2381,7 +2381,7 @@ static void Task_CardOrNewsWithFriend(u8 taskId) break; case 5: AddTextPrinterToWindow1(gUnknown_84576AC); - RfuSetStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); break; } break; @@ -2546,7 +2546,7 @@ static void Task_CardOrNewsOverWireless(u8 taskId) break; case 5: AddTextPrinterToWindow1(gUnknown_845777C); - RfuSetStatus(0, 0); + RfuSetStatus(RFU_STATUS_OK, 0); break; } break; From 0d3661f364e5f82cc1ae21e0d660a63dfdad26ab Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 3 Jun 2021 12:32:14 -0400 Subject: [PATCH 16/21] Rename funcs and data in tileset_anims.c --- src/tileset_anims.c | 256 ++++++++++++++++++++++---------------------- 1 file changed, 130 insertions(+), 126 deletions(-) diff --git a/src/tileset_anims.c b/src/tileset_anims.c index 04e129049..fb18bbc0d 100644 --- a/src/tileset_anims.c +++ b/src/tileset_anims.c @@ -17,117 +17,121 @@ static void (*sSecondaryTilesetAnimCallback)(u16); static void _InitPrimaryTilesetAnimation(void); static void _InitSecondaryTilesetAnimation(void); -static const u16 gUnknown_83A73E0[] = INCBIN_U16("graphics/tileset_anims/anim_0_0.bin"); -static const u16 gUnknown_83A7460[] = INCBIN_U16("graphics/tileset_anims/anim_0_1.bin"); -static const u16 gUnknown_83A74E0[] = INCBIN_U16("graphics/tileset_anims/anim_0_2.bin"); -static const u16 gUnknown_83A7560[] = INCBIN_U16("graphics/tileset_anims/anim_0_3.bin"); -static const u16 gUnknown_83A75E0[] = INCBIN_U16("graphics/tileset_anims/anim_0_4.bin"); +// palette: general 00 +static const u16 sTilesetAnims_General_Flower_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_0_0.bin"); +static const u16 sTilesetAnims_General_Flower_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_0_1.bin"); +static const u16 sTilesetAnims_General_Flower_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_0_2.bin"); +static const u16 sTilesetAnims_General_Flower_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_0_3.bin"); +static const u16 sTilesetAnims_General_Flower_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_0_4.bin"); -static const u16 *const gUnknown_83A7660[] = { - gUnknown_83A73E0, - gUnknown_83A7460, - gUnknown_83A74E0, - gUnknown_83A7560, - gUnknown_83A75E0 +static const u16 *const sTilesetAnims_General_Flower[] = { + sTilesetAnims_General_Flower_Frame0, + sTilesetAnims_General_Flower_Frame1, + sTilesetAnims_General_Flower_Frame2, + sTilesetAnims_General_Flower_Frame3, + sTilesetAnims_General_Flower_Frame4 }; -static const u16 gUnknown_83A7674[] = INCBIN_U16("graphics/tileset_anims/anim_1_0.bin"); -static const u16 gUnknown_83A7C74[] = INCBIN_U16("graphics/tileset_anims/anim_1_1.bin"); -static const u16 gUnknown_83A8274[] = INCBIN_U16("graphics/tileset_anims/anim_1_2.bin"); -static const u16 gUnknown_83A8874[] = INCBIN_U16("graphics/tileset_anims/anim_1_3.bin"); -static const u16 gUnknown_83A8E74[] = INCBIN_U16("graphics/tileset_anims/anim_1_4.bin"); -static const u16 gUnknown_83A9474[] = INCBIN_U16("graphics/tileset_anims/anim_1_5.bin"); -static const u16 gUnknown_83A9A74[] = INCBIN_U16("graphics/tileset_anims/anim_1_6.bin"); -static const u16 gUnknown_83AA074[] = INCBIN_U16("graphics/tileset_anims/anim_1_7.bin"); +// palette: general 04 +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_1_0.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_1_1.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_1_2.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_1_3.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_1_4.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame5[] = INCBIN_U16("graphics/tileset_anims/anim_1_5.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame6[] = INCBIN_U16("graphics/tileset_anims/anim_1_6.bin"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame7[] = INCBIN_U16("graphics/tileset_anims/anim_1_7.bin"); -static const u16 *const gUnknown_83AA654[] = { - gUnknown_83A7674, - gUnknown_83A7C74, - gUnknown_83A8274, - gUnknown_83A8874, - gUnknown_83A8E74, - gUnknown_83A9474, - gUnknown_83A9A74, - gUnknown_83AA074 +static const u16 *const sTilesetAnims_General_Water_Current_LandWatersEdge[] = { + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame0, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame1, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame2, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame3, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame4, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame5, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame6, + sTilesetAnims_General_Water_Current_LandWatersEdge_Frame7 }; -static const u16 gUnknown_83AA674[] = INCBIN_U16("graphics/tileset_anims/anim_2_0.bin"); -static const u16 gUnknown_83AA8B4[] = INCBIN_U16("graphics/tileset_anims/anim_2_1.bin"); -static const u16 gUnknown_83AAAF4[] = INCBIN_U16("graphics/tileset_anims/anim_2_2.bin"); -static const u16 gUnknown_83AAD34[] = INCBIN_U16("graphics/tileset_anims/anim_2_3.bin"); -static const u16 gUnknown_83AAF74[] = INCBIN_U16("graphics/tileset_anims/anim_2_4.bin"); -static const u16 gUnknown_83AB1B4[] = INCBIN_U16("graphics/tileset_anims/anim_2_5.bin"); -static const u16 gUnknown_83AB3F4[] = INCBIN_U16("graphics/tileset_anims/anim_2_6.bin"); -static const u16 gUnknown_83AB634[] = INCBIN_U16("graphics/tileset_anims/anim_2_7.bin"); +// palette: general 04 +static const u16 sTilesetAnims_General_SandWatersEdge_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_2_0.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_2_1.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_2_2.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_2_3.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_2_4.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame5[] = INCBIN_U16("graphics/tileset_anims/anim_2_5.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame6[] = INCBIN_U16("graphics/tileset_anims/anim_2_6.bin"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame7[] = INCBIN_U16("graphics/tileset_anims/anim_2_7.bin"); -static const u16 *const gUnknown_83AB874[] = { - gUnknown_83AA674, - gUnknown_83AA8B4, - gUnknown_83AAAF4, - gUnknown_83AAD34, - gUnknown_83AAF74, - gUnknown_83AB1B4, - gUnknown_83AB3F4, - gUnknown_83AB634 +static const u16 *const sTilesetAnims_General_SandWatersEdge[] = { + sTilesetAnims_General_SandWatersEdge_Frame0, + sTilesetAnims_General_SandWatersEdge_Frame1, + sTilesetAnims_General_SandWatersEdge_Frame2, + sTilesetAnims_General_SandWatersEdge_Frame3, + sTilesetAnims_General_SandWatersEdge_Frame4, + sTilesetAnims_General_SandWatersEdge_Frame5, + sTilesetAnims_General_SandWatersEdge_Frame6, + sTilesetAnims_General_SandWatersEdge_Frame7 }; -static const u16 gUnknown_83AB894[] = INCBIN_U16("graphics/tileset_anims/anim_3_0.bin"); -static const u16 gUnknown_83AB994[] = INCBIN_U16("graphics/tileset_anims/anim_3_1.bin"); -static const u16 gUnknown_83ABA94[] = INCBIN_U16("graphics/tileset_anims/anim_3_2.bin"); -static const u16 gUnknown_83ABB94[] = INCBIN_U16("graphics/tileset_anims/anim_3_3.bin"); -static const u16 gUnknown_83ABC94[] = INCBIN_U16("graphics/tileset_anims/anim_3_4.bin"); +// palette: general 00 +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_3_0.bin"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_3_1.bin"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_3_2.bin"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_3_3.bin"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_3_4.bin"); static const u16 gUnknown_83ABD94[16] = {}; -static const u16 *const gUnknown_83ABDB4[] = { - gUnknown_83AB894, - gUnknown_83AB994, - gUnknown_83ABA94, - gUnknown_83ABB94, - gUnknown_83ABC94 +static const u16 *const sTilesetAnims_CeladonCity_Fountain[] = { + sTilesetAnims_CeladonCity_Fountain_Frame0, + sTilesetAnims_CeladonCity_Fountain_Frame1, + sTilesetAnims_CeladonCity_Fountain_Frame2, + sTilesetAnims_CeladonCity_Fountain_Frame3, + sTilesetAnims_CeladonCity_Fountain_Frame4 }; -static const u16 gUnknown_83ABDC8[] = INCBIN_U16("graphics/tileset_anims/anim_4_0.bin"); -static const u16 gUnknown_83ABEC8[] = INCBIN_U16("graphics/tileset_anims/anim_4_1.bin"); -static const u16 gUnknown_83ABFC8[] = INCBIN_U16("graphics/tileset_anims/anim_4_2.bin"); -static const u16 gUnknown_83AC0C8[] = INCBIN_U16("graphics/tileset_anims/anim_4_3.bin"); -static const u16 gUnknown_83AC1C8[0x10] = {}; +static const u16 sTilesetAnims_SilphCo_Fountain_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_4_0.bin"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_4_1.bin"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_4_2.bin"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_4_3.bin"); +static const u16 gUnknown_83AC1C8[16] = {}; -static const u16 *const gUnknown_83AC1E8[] = { - gUnknown_83ABDC8, - gUnknown_83ABEC8, - gUnknown_83ABFC8, - gUnknown_83AC0C8 +static const u16 *const sTilesetAnims_SilphCo_Fountain[] = { + sTilesetAnims_SilphCo_Fountain_Frame0, + sTilesetAnims_SilphCo_Fountain_Frame1, + sTilesetAnims_SilphCo_Fountain_Frame2, + sTilesetAnims_SilphCo_Fountain_Frame3 }; -static const u16 gUnknown_83AC1F8[] = INCBIN_U16("graphics/tileset_anims/anim_5_0.bin"); -static const u16 gUnknown_83AC2F8[] = INCBIN_U16("graphics/tileset_anims/anim_5_1.bin"); -static const u16 gUnknown_83AC3F8[] = INCBIN_U16("graphics/tileset_anims/anim_5_2.bin"); -static const u16 gUnknown_83AC4F8[] = INCBIN_U16("graphics/tileset_anims/anim_5_3.bin"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_5_0.bin"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_5_1.bin"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_5_2.bin"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_5_3.bin"); -static const u16 *const gUnknown_83AC5F8[] = { - gUnknown_83AC1F8, - gUnknown_83AC2F8, - gUnknown_83AC3F8, - gUnknown_83AC4F8 +static const u16 *const sTilesetAnims_MtEmber_Steam[] = { + sTilesetAnims_MtEmber_Steam_Frame0, + sTilesetAnims_MtEmber_Steam_Frame1, + sTilesetAnims_MtEmber_Steam_Frame2, + sTilesetAnims_MtEmber_Steam_Frame3 }; -static const u16 gUnknown_83AC608[] = INCBIN_U16("graphics/tileset_anims/anim_6_0.bin"); -static const u16 gUnknown_83AC6E8[] = INCBIN_U16("graphics/tileset_anims/anim_6_1.bin"); +static const u16 sTilesetAnims_VermilionGym_MotorizedDoor_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_6_0.bin"); +static const u16 sTilesetAnims_VermilionGym_MotorizedDoor_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_6_1.bin"); -static const u16 *const gUnknown_83AC7C8[] = { - gUnknown_83AC608, - gUnknown_83AC6E8 +static const u16 *const sTilesetAnims_VermilionGym_MotorizedDoor[] = { + sTilesetAnims_VermilionGym_MotorizedDoor_Frame0, + sTilesetAnims_VermilionGym_MotorizedDoor_Frame1 }; -static const u16 gUnknown_83AC7D0[] = INCBIN_U16("graphics/tileset_anims/anim_7_0.bin"); -static const u16 gUnknown_83AC850[] = INCBIN_U16("graphics/tileset_anims/anim_7_1.bin"); -static const u16 gUnknown_83AC8D0[] = INCBIN_U16("graphics/tileset_anims/anim_7_2.bin"); +static const u16 sTilesetAnims_CeladonGym_Flowers_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_7_0.bin"); +static const u16 sTilesetAnims_CeladonGym_Flowers_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_7_1.bin"); +static const u16 sTilesetAnims_CeladonGym_Flowers_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_7_2.bin"); -static const u16 *const gUnknown_83AC950[] = { - gUnknown_83AC7D0, - gUnknown_83AC850, - gUnknown_83AC8D0, - gUnknown_83AC850 +static const u16 *const sTilesetAnims_CeladonGym_Flowers[] = { + sTilesetAnims_CeladonGym_Flowers_Frame0, + sTilesetAnims_CeladonGym_Flowers_Frame1, + sTilesetAnims_CeladonGym_Flowers_Frame2, + sTilesetAnims_CeladonGym_Flowers_Frame1 }; static void ResetTilesetAnimBuffer(void) @@ -201,128 +205,128 @@ static void _InitSecondaryTilesetAnimation(void) gMapHeader.mapLayout->secondaryTileset->callback(); } -static void sub_80700A4(u16 timer) +static void QueueAnimTiles_General_Flower(u16 timer) { - AppendTilesetAnimToBuffer(gUnknown_83A7660[timer % NELEMS(gUnknown_83A7660)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(508)), 0x80); + AppendTilesetAnimToBuffer(sTilesetAnims_General_Flower[timer % NELEMS(sTilesetAnims_General_Flower)], (u16 *)(BG_CHAR_ADDR(0) + TILE_OFFSET_4BPP(508)), 4 * TILE_SIZE_4BPP); } -static void sub_80700D0(u16 timer) +static void QueueAnimTiles_General_Water_Current_LandWatersEdge(u16 timer) { - AppendTilesetAnimToBuffer(gUnknown_83AA654[timer % NELEMS(gUnknown_83AA654)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(416)), 0x600); + AppendTilesetAnimToBuffer(sTilesetAnims_General_Water_Current_LandWatersEdge[timer % NELEMS(sTilesetAnims_General_Water_Current_LandWatersEdge)], (u16 *)(BG_CHAR_ADDR(0) + TILE_OFFSET_4BPP(416)), 48 * TILE_SIZE_4BPP); } -static void sub_80700F8(u16 timer) +static void QueueAnimTiles_General_SandWatersEdge(u16 timer) { - AppendTilesetAnimToBuffer(gUnknown_83AB874[timer % NELEMS(gUnknown_83AB874)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(464)), 0x240); + AppendTilesetAnimToBuffer(sTilesetAnims_General_SandWatersEdge[timer % NELEMS(sTilesetAnims_General_SandWatersEdge)], (u16 *)(BG_CHAR_ADDR(0) + TILE_OFFSET_4BPP(464)), 18 * TILE_SIZE_4BPP); } -static void sub_8070120(u16 timer) +static void TilesetAnim_General(u16 timer) { if (timer % 8 == 0) - sub_80700F8(timer >> 3); + QueueAnimTiles_General_SandWatersEdge(timer >> 3); if (timer % 16 == 1) - sub_80700D0(timer >> 4); + QueueAnimTiles_General_Water_Current_LandWatersEdge(timer >> 4); if (timer % 16 == 2) - sub_80700A4(timer >> 4); + QueueAnimTiles_General_Flower(timer >> 4); } void InitTilesetAnim_General(void) { sPrimaryTilesetAnimCounter = 0; sPrimaryTilesetAnimCounterMax = 640; - sPrimaryTilesetAnimCallback = sub_8070120; + sPrimaryTilesetAnimCallback = TilesetAnim_General; } -static void sub_807017C(u16 timer) +static void QueueAnimTiles_CeladonCity_Fountain(u16 timer) { - AppendTilesetAnimToBuffer(gUnknown_83ABDB4[timer % NELEMS(gUnknown_83ABDB4)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(744)), 0x100); + AppendTilesetAnimToBuffer(sTilesetAnims_CeladonCity_Fountain[timer % NELEMS(sTilesetAnims_CeladonCity_Fountain)], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(232)), 8 * TILE_SIZE_4BPP); } -static void sub_80701AC(u16 timer) +static void TilesetAnim_CeladonCity(u16 timer) { if (timer % 12 == 0) - sub_807017C(timer / 12); + QueueAnimTiles_CeladonCity_Fountain(timer / 12); } void InitTilesetAnim_CeladonCity(void) { sSecondaryTilesetAnimCounter = 0; sSecondaryTilesetAnimCounterMax = 120; - sSecondaryTilesetAnimCallback = sub_80701AC; + sSecondaryTilesetAnimCallback = TilesetAnim_CeladonCity; } -static void sub_80701FC(u16 timer) +static void QueueAnimTiles_SilphCo_Fountain(u16 timer) { - AppendTilesetAnimToBuffer(gUnknown_83AC1E8[timer % NELEMS(gUnknown_83AC1E8)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(976)), 0x100); + AppendTilesetAnimToBuffer(sTilesetAnims_SilphCo_Fountain[timer % NELEMS(sTilesetAnims_SilphCo_Fountain)], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(464)), 8 * TILE_SIZE_4BPP); } -static void sub_8070224(u16 timer) +static void TilesetAnim_SilphCo(u16 timer) { if (timer % 10 == 0) - sub_80701FC(timer / 10); + QueueAnimTiles_SilphCo_Fountain(timer / 10); } void InitTilesetAnim_SilphCo(void) { sSecondaryTilesetAnimCounter = 0; sSecondaryTilesetAnimCounterMax = 160; - sSecondaryTilesetAnimCallback = sub_8070224; + sSecondaryTilesetAnimCallback = TilesetAnim_SilphCo; } -static void sub_8070274(u16 timer) +static void QueueAnimTiles_MtEmber_Steam(u16 timer) { - AppendTilesetAnimToBuffer(gUnknown_83AC5F8[timer % NELEMS(gUnknown_83AC5F8)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(896)), 0x100); + AppendTilesetAnimToBuffer(sTilesetAnims_MtEmber_Steam[timer % NELEMS(sTilesetAnims_MtEmber_Steam)], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(384)), 8 * TILE_SIZE_4BPP); } -static void sub_807029C(u16 timer) +static void TilesetAnim_MtEmber(u16 timer) { if (timer % 16 == 0) - sub_8070274(timer >> 4); + QueueAnimTiles_MtEmber_Steam(timer >> 4); } void InitTilesetAnim_MtEmber(void) { sSecondaryTilesetAnimCounter = 0; sSecondaryTilesetAnimCounterMax = 256; - sSecondaryTilesetAnimCallback = sub_807029C; + sSecondaryTilesetAnimCallback = TilesetAnim_MtEmber; } -static void sub_80702DC(u16 timer) +static void QueueAnimTiles_VermilionGym_MotorizedDoor(u16 timer) { - u16 i = timer % NELEMS(gUnknown_83AC7C8); + u16 i = timer % NELEMS(sTilesetAnims_VermilionGym_MotorizedDoor); - AppendTilesetAnimToBuffer(gUnknown_83AC7C8[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(880)), 0xE0); + AppendTilesetAnimToBuffer(sTilesetAnims_VermilionGym_MotorizedDoor[i], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(368)), 7 * TILE_SIZE_4BPP); } -static void sub_8070304(u16 timer) +static void TilesetAnim_VermilionGym(u16 timer) { if (timer % 2 == 0) - sub_80702DC(timer >> 1); + QueueAnimTiles_VermilionGym_MotorizedDoor(timer >> 1); } void InitTilesetAnim_VermilionGym(void) { sSecondaryTilesetAnimCounter = 0; sSecondaryTilesetAnimCounterMax = 240; - sSecondaryTilesetAnimCallback = sub_8070304; + sSecondaryTilesetAnimCallback = TilesetAnim_VermilionGym; } -static void sub_8070340(u16 timer) +static void QueueAnimTiles_CeladonGym_Flowers(u16 timer) { - u16 i = timer % NELEMS(gUnknown_83AC950); + u16 i = timer % NELEMS(sTilesetAnims_CeladonGym_Flowers); - AppendTilesetAnimToBuffer(gUnknown_83AC950[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(739)), 0x80); + AppendTilesetAnimToBuffer(sTilesetAnims_CeladonGym_Flowers[i], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(227)), 4 * TILE_SIZE_4BPP); } -static void sub_8070368(u16 timer) +static void TilesetAnim_CeladonGym(u16 timer) { if (timer % 16 == 0) - sub_8070340(timer >> 4); + QueueAnimTiles_CeladonGym_Flowers(timer >> 4); } void InitTilesetAnim_CeladonGym(void) { sSecondaryTilesetAnimCounter = 0; sSecondaryTilesetAnimCounterMax = 256; - sSecondaryTilesetAnimCallback = sub_8070368; + sSecondaryTilesetAnimCallback = TilesetAnim_CeladonGym; } From ffb21d41b58f8c51006f656344c37cb43cf60f83 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 3 Jun 2021 12:43:17 -0400 Subject: [PATCH 17/21] Tileset anims to PNG --- graphics/tileset_anims/anim_0_0.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_0_1.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_0_2.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_0_3.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_0_4.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_1_0.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_1.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_2.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_3.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_4.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_5.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_6.bin | Bin 1536 -> 0 bytes graphics/tileset_anims/anim_1_7.bin | Bin 1504 -> 0 bytes graphics/tileset_anims/anim_2_0.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_1.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_2.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_3.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_4.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_5.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_6.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_2_7.bin | Bin 576 -> 0 bytes graphics/tileset_anims/anim_3_0.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_3_1.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_3_2.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_3_3.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_3_4.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_4_0.bin | 1 - graphics/tileset_anims/anim_4_1.bin | 1 - graphics/tileset_anims/anim_4_2.bin | 1 - graphics/tileset_anims/anim_4_3.bin | 1 - graphics/tileset_anims/anim_5_0.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_5_1.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_5_2.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_5_3.bin | Bin 256 -> 0 bytes graphics/tileset_anims/anim_6_0.bin | Bin 224 -> 0 bytes graphics/tileset_anims/anim_6_1.bin | Bin 224 -> 0 bytes graphics/tileset_anims/anim_7_0.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_7_1.bin | Bin 128 -> 0 bytes graphics/tileset_anims/anim_7_2.bin | Bin 128 -> 0 bytes .../anim_celadoncity_fountain_frame0.png | Bin 0 -> 191 bytes .../anim_celadoncity_fountain_frame1.png | Bin 0 -> 177 bytes .../anim_celadoncity_fountain_frame2.png | Bin 0 -> 209 bytes .../anim_celadoncity_fountain_frame3.png | Bin 0 -> 235 bytes .../anim_celadoncity_fountain_frame4.png | Bin 0 -> 219 bytes .../anim_celadongym_flowers_frame0.png | Bin 0 -> 171 bytes .../anim_celadongym_flowers_frame1.png | Bin 0 -> 171 bytes .../anim_celadongym_flowers_frame2.png | Bin 0 -> 157 bytes .../anim_general_flower_frame0.png | Bin 0 -> 166 bytes .../anim_general_flower_frame1.png | Bin 0 -> 165 bytes .../anim_general_flower_frame2.png | Bin 0 -> 162 bytes .../anim_general_flower_frame3.png | Bin 0 -> 162 bytes .../anim_general_flower_frame4.png | Bin 0 -> 163 bytes .../anim_general_sandwatersedge_frame0.png | Bin 0 -> 407 bytes .../anim_general_sandwatersedge_frame1.png | Bin 0 -> 419 bytes .../anim_general_sandwatersedge_frame2.png | Bin 0 -> 434 bytes .../anim_general_sandwatersedge_frame3.png | Bin 0 -> 460 bytes .../anim_general_sandwatersedge_frame4.png | Bin 0 -> 444 bytes .../anim_general_sandwatersedge_frame5.png | Bin 0 -> 448 bytes .../anim_general_sandwatersedge_frame6.png | Bin 0 -> 445 bytes .../anim_general_sandwatersedge_frame7.png | Bin 0 -> 408 bytes ...al_water_current_landwatersedge_frame0.png | Bin 0 -> 577 bytes ...al_water_current_landwatersedge_frame1.png | Bin 0 -> 586 bytes ...al_water_current_landwatersedge_frame2.png | Bin 0 -> 767 bytes ...al_water_current_landwatersedge_frame3.png | Bin 0 -> 783 bytes ...al_water_current_landwatersedge_frame4.png | Bin 0 -> 831 bytes ...al_water_current_landwatersedge_frame5.png | Bin 0 -> 856 bytes ...al_water_current_landwatersedge_frame6.png | Bin 0 -> 811 bytes ...al_water_current_landwatersedge_frame7.png | Bin 0 -> 748 bytes .../anim_mtember_steam_frame0.png | Bin 0 -> 175 bytes .../anim_mtember_steam_frame1.png | Bin 0 -> 171 bytes .../anim_mtember_steam_frame2.png | Bin 0 -> 173 bytes .../anim_mtember_steam_frame3.png | Bin 0 -> 171 bytes .../anim_silphco_fountain_frame0.png | Bin 0 -> 222 bytes .../anim_silphco_fountain_frame1.png | Bin 0 -> 208 bytes .../anim_silphco_fountain_frame2.png | Bin 0 -> 213 bytes .../anim_silphco_fountain_frame3.png | Bin 0 -> 204 bytes ...anim_vermiliongym_motorizeddoor_frame0.png | Bin 0 -> 138 bytes ...anim_vermiliongym_motorizeddoor_frame1.png | Bin 0 -> 146 bytes graphics_file_rules.mk | 4 + src/tileset_anims.c | 78 +++++++++--------- 80 files changed, 43 insertions(+), 43 deletions(-) delete mode 100644 graphics/tileset_anims/anim_0_0.bin delete mode 100644 graphics/tileset_anims/anim_0_1.bin delete mode 100644 graphics/tileset_anims/anim_0_2.bin delete mode 100644 graphics/tileset_anims/anim_0_3.bin delete mode 100644 graphics/tileset_anims/anim_0_4.bin delete mode 100644 graphics/tileset_anims/anim_1_0.bin delete mode 100644 graphics/tileset_anims/anim_1_1.bin delete mode 100644 graphics/tileset_anims/anim_1_2.bin delete mode 100644 graphics/tileset_anims/anim_1_3.bin delete mode 100644 graphics/tileset_anims/anim_1_4.bin delete mode 100644 graphics/tileset_anims/anim_1_5.bin delete mode 100644 graphics/tileset_anims/anim_1_6.bin delete mode 100644 graphics/tileset_anims/anim_1_7.bin delete mode 100644 graphics/tileset_anims/anim_2_0.bin delete mode 100644 graphics/tileset_anims/anim_2_1.bin delete mode 100644 graphics/tileset_anims/anim_2_2.bin delete mode 100644 graphics/tileset_anims/anim_2_3.bin delete mode 100644 graphics/tileset_anims/anim_2_4.bin delete mode 100644 graphics/tileset_anims/anim_2_5.bin delete mode 100644 graphics/tileset_anims/anim_2_6.bin delete mode 100644 graphics/tileset_anims/anim_2_7.bin delete mode 100644 graphics/tileset_anims/anim_3_0.bin delete mode 100644 graphics/tileset_anims/anim_3_1.bin delete mode 100644 graphics/tileset_anims/anim_3_2.bin delete mode 100644 graphics/tileset_anims/anim_3_3.bin delete mode 100644 graphics/tileset_anims/anim_3_4.bin delete mode 100644 graphics/tileset_anims/anim_4_0.bin delete mode 100644 graphics/tileset_anims/anim_4_1.bin delete mode 100644 graphics/tileset_anims/anim_4_2.bin delete mode 100644 graphics/tileset_anims/anim_4_3.bin delete mode 100644 graphics/tileset_anims/anim_5_0.bin delete mode 100644 graphics/tileset_anims/anim_5_1.bin delete mode 100644 graphics/tileset_anims/anim_5_2.bin delete mode 100644 graphics/tileset_anims/anim_5_3.bin delete mode 100644 graphics/tileset_anims/anim_6_0.bin delete mode 100644 graphics/tileset_anims/anim_6_1.bin delete mode 100644 graphics/tileset_anims/anim_7_0.bin delete mode 100644 graphics/tileset_anims/anim_7_1.bin delete mode 100644 graphics/tileset_anims/anim_7_2.bin create mode 100644 graphics/tileset_anims/anim_celadoncity_fountain_frame0.png create mode 100644 graphics/tileset_anims/anim_celadoncity_fountain_frame1.png create mode 100644 graphics/tileset_anims/anim_celadoncity_fountain_frame2.png create mode 100644 graphics/tileset_anims/anim_celadoncity_fountain_frame3.png create mode 100644 graphics/tileset_anims/anim_celadoncity_fountain_frame4.png create mode 100644 graphics/tileset_anims/anim_celadongym_flowers_frame0.png create mode 100644 graphics/tileset_anims/anim_celadongym_flowers_frame1.png create mode 100644 graphics/tileset_anims/anim_celadongym_flowers_frame2.png create mode 100644 graphics/tileset_anims/anim_general_flower_frame0.png create mode 100644 graphics/tileset_anims/anim_general_flower_frame1.png create mode 100644 graphics/tileset_anims/anim_general_flower_frame2.png create mode 100644 graphics/tileset_anims/anim_general_flower_frame3.png create mode 100644 graphics/tileset_anims/anim_general_flower_frame4.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame0.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame1.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame2.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame3.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame4.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame5.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame6.png create mode 100644 graphics/tileset_anims/anim_general_sandwatersedge_frame7.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame0.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame6.png create mode 100644 graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.png create mode 100644 graphics/tileset_anims/anim_mtember_steam_frame0.png create mode 100644 graphics/tileset_anims/anim_mtember_steam_frame1.png create mode 100644 graphics/tileset_anims/anim_mtember_steam_frame2.png create mode 100644 graphics/tileset_anims/anim_mtember_steam_frame3.png create mode 100644 graphics/tileset_anims/anim_silphco_fountain_frame0.png create mode 100644 graphics/tileset_anims/anim_silphco_fountain_frame1.png create mode 100644 graphics/tileset_anims/anim_silphco_fountain_frame2.png create mode 100644 graphics/tileset_anims/anim_silphco_fountain_frame3.png create mode 100644 graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame0.png create mode 100644 graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png diff --git a/graphics/tileset_anims/anim_0_0.bin b/graphics/tileset_anims/anim_0_0.bin deleted file mode 100644 index 38ac085bdceedcd705047b83966d6844443fa468..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 128 zcmXYpp$)(=3`RDq6Z~&`0h~e1a3}VOc|L(#2)iNIq)nSP1wLd4Wy#677u6$L zO3WfW>z_CUBsuI+kT+EjvG3vXHIVs^aaW*qz|&C_b~~x(vj(COMs2P2W!U@$8BjGY diff --git a/graphics/tileset_anims/anim_0_2.bin b/graphics/tileset_anims/anim_0_2.bin deleted file mode 100644 index 8bfe63cd213b09535d4f810aadba6d172b7d0dc4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 128 zcmZ9EAr8PG5Cm7$A^If*4srj37r+?=hP!Xn^9d}WRA9QvWHZ@hfsp~L5rr5V1w^qMs^)bf07CF4O^D@u? diff --git a/graphics/tileset_anims/anim_0_3.bin b/graphics/tileset_anims/anim_0_3.bin deleted file mode 100644 index 13522349b7ec248a69c495358410cd212abc776d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 128 zcmX|(u?fI15Cc`D`ywm3_|Apr^9rBFg)3`~^j_jy<9r}Qa3DA#;1AJgxJFRfSVyyK w{5FbwunAse)g(3qdrqr(nnj_yuB1kGjRX_ diff --git a/graphics/tileset_anims/anim_1_0.bin b/graphics/tileset_anims/anim_1_0.bin deleted file mode 100644 index fb05bd03cb4351f3431903e21e87760c1c7fe012..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1536 zcmcIkzi-n(7`+Zu2o}7St^a~|I<$X47CS3Tu1mJkddU#Bk7QxAVPbQQgw(CgF{eX6 ziND~=j+9$iq2WC{rfvX5Ldw& z%NRJyvZJmH@s>Ko@AvxMpZN}KumRP$G447kSlrA zR6gsU9%q9z>sxy|m=9B{YUip$9bKztnQmKW4c1~!*5(;_7M_WP`t!9I{Vi{qf ziEp7J8q~I}tHnDG)9e~XMgyc>o7A?fF9}tQ6`WJo!6vy3lQ%B diff --git a/graphics/tileset_anims/anim_1_1.bin b/graphics/tileset_anims/anim_1_1.bin deleted file mode 100644 index d67987eca9a5a72d635e9370f1a70e550da37bf5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1536 zcmcIjy>8nu5M~M_Lpw23kRhEW_$8})N1} zSt8dGcLY5ieXYmIY#3`qJwqJg=^bL4;&FdGNRv3-w9Yel7SH6_yarwiuZd@GTJLK- zPG*>DJnhqm&4g_>SlhHdK>9}<#^XEGF&jj-*<@|gdbI#n6$ThY6R=JXd8=P#jAE?D zgCBIxxmD`^H{zqS)|Jkcj4x&R!x7f$bGp-v@7DhMSyd1GANPp2SH^U>mhSwwf9Wz{ k0*weVz@BVOSP4q%!!tnxSpWb4 diff --git a/graphics/tileset_anims/anim_1_2.bin b/graphics/tileset_anims/anim_1_2.bin deleted file mode 100644 index 813f9391438104e3cd62dd63de4b822394e57004..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1536 zcmbu9zi-n}5XT=#6bY6-kL?t%C=-7Hs7tplw%05^FIig2K1Ip`(<5Ez7Q@7r8i|== z=6L9nkl0;zB=Q%4%J(jD45d;BPWjr;_qn_GDo#y+RUb9V3}>nn9ePOu=x(NQxt)_WIly=gdpzcAcBQD9ek5o7anZ{l0o+ z%xtmN`J3`_?c9@7=k}fZ7`XD2wFo(@+~VELIXj!b+J(~ucCfCCstdPQ&D>t?=BK5* zxNocddryNcHtoiSVb})NhSu7F4Fe1Y!2$C@$J;Rc3OGOvu0n07d}yB|5gHu#vL~(h zhrzS8H0Gq|5-VJFi2Gq1+6kte1omuVZ8<5+GDCgZ&c7WD!xq798=OJqdY?yRj-tq* ze+Gv>LjTsvNI304xZu!Dl#)R=cPNG^-5H^OBlK^C{vn7VG9w5V%|#5_55*7AKZE`m zDjsT0;f41EjXgKsGy5XRGtOg93d++WiwS%weEJ7Z!SULq%Q1KZ&fqA(%$mR9neslr zL4DTxEcq%JOZ!vAcK|ck}L1N9?A*d+zwp>+3HbE4cLjbGR`KF0Z`* zv4Y*jtJSI!`%qQiC0-1P`n7#)+h4cwcD1^a0O2;2zYJ>~ez)0O{GS{xg@ULn+qs47 Ld>xl>@PF(#&;!qN diff --git a/graphics/tileset_anims/anim_1_3.bin b/graphics/tileset_anims/anim_1_3.bin deleted file mode 100644 index df560357cc9924b4fe26977a8f47f22397950701..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1536 zcmbu9zi!k(5XPN?L!x4r<`m>&U6GD(B~_#}*U{K+-FVzwh2mYECxuDa^wVn-DgmFoi;p zOGQ|TQqEzA5JLvy;LgF)8*fDHaxj!3!NhPh;-k=TZLhQUr=Dl+%R_6QS$lj~RbR2J zUo6+3R!=-{ankGbL-l%X?ellmj;;M7ZS_qEgp@0LQZB5Oi{qoGDiEF&s;`TxCw6i-UvBuRL~2)k3D8xjFj+~(?*ngjZ#?E6i3e$YDl#_ zK<$I7+Rsp*y7Rk>IPV)(XjTTu*=>9^>F+ZkFCp?UKM(VJgZU+xUxJY^rx8Stpb&~6 z8es|}jAN8wehJ2wV159GVOI+m&c*yjl=i~>Jj~A{{kW^iyeMi{7~^!DXC{kG98;d^ zSww}SO;OJrxEpv1PT(7G2kzXx9GQP{6hM8$`G)g#FG}lK6lav1I5OJg8K22#a|~jM z&*ZZWdf;BKcnxmA3$#w=IljA7Zsr3_tSuUT?lvf<=ZDNDC&Sb!`&HnuiM zNNj+a z3{@<{p2EvfR3Pj{DC3Jki~$H~L<*c7I3I*R+#+x4GvwZhg=91fnH`Y0ZoQUg1qVF&ARJ( zN8S;6BgBjqVrC5arf*J~LY&lnaaQ+d1)5^^yy>@|*M?&?E&FRUwC1lmNmdG!Q&!&a@PqTkae7K6eMa8Dtrv1!D1LnYvsb)p`B#bDrHqP zij@MdV(<$5BwhgEGw^CmzS1YqC(s9(9d;AwgCqlw&oAu2{}}%5O@FI`1YQ%)Nsepa zTIfmdjB8MtU8oGa0zZi&Ii@Fhk~YIyG24)Ha}D@@N1X(Gki=Xg{JZe)!oR)gU-l1E zG&WdRMKEVFM#2ZB7B*5Dcuc#P;MIf)dXrcKc+^spKuZMJoemPrU(|r_g72cNv+0lB zO6)L1hv=CJz`RH$`UklG8TKE|f}cd09haq)u%^<}hzKC+qJQjvT-kQuc??l|)Bm1f zEv_ok)TV#LHhxu#@7|=iRzWvvSI__A=ZN?7`S)cNKbFhl7xOL8fBn3_|GLTN%jF#l yRy-!LH`adfsz7pcXDw`&%Q>!Xyyv>O5XE1Y{wucen*#bUsAFv7%U|LDkG}z+IKr<0 diff --git a/graphics/tileset_anims/anim_1_5.bin b/graphics/tileset_anims/anim_1_5.bin deleted file mode 100644 index 4e5e0e24725efeb9c34bfcdecf7c00bf1fecded7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1536 zcmbVMF>ljQ5Pl$<0hXo{f(bKrsMM&fki6NdRjC6@>@|xoiwB06JVnYKh6@--NpjPZLo9 ztt2K-$F%J?iM%F^C??Wa1W}VZy4i$D^9KNuRVZrIfFX*_k( zOYx2Ir$sTDl_gvtj`P#mYzY2LTq?ZW+?#G3@69$&dRKbfo0Z3V(@Pb5wt>BCJ`!^s zFM*ZLNzZAdJy4r8?X|&AlS)toDv&~^sB(%br{!iUI`6X;suvV0%uiu{EsO_BqJqaY zrJ7Vzn4iM@6y{gM{A!rr%5(TU$Jkl|VtxwqQ!R>>YC)C4{8li(70j=O`6N`MJ8k%zCAZWdwJhUNV>bXE07vxL)d{(p;$1&NZ>XQU?J*nQ^dsbt=lT1{&lPsn ze;@sut(;A)xgP~E4BC)*@g?lxC1x!4G9Es00DRv>V;8uK&(YNp@`K+qZAK4#b^emS zlS{QpC|H|4ZP@j(=Y=pL06M?we-RIyfa6d&5qlXgXN2?b1UZE}IJ6y|baphEeLn)X zslE$57{7&N%-KS2!xw%x-%ge}A~*LJ>jf@8XO43|W4G>as$TlVMRGd L9cTU({{Qn2ty|Ks diff --git a/graphics/tileset_anims/anim_1_6.bin b/graphics/tileset_anims/anim_1_6.bin deleted file mode 100644 index bb716829f5946da5374ea079c2d21b0b165fa666..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1536 zcmbW1F;Ck-6vvNB&CpI^WI|?SK;knTiI6fd5NFL`pBImDPDl)8JHpa3#pMeGSE@v( zf;(Etz?1q3O!rE-U!aZqf0sB(Arexb{CAG~-TU9WdooJ-N~t#F`W_@bx2^h3Ot?)5 zzaE%`8r8sNaMm$|;ACrH2Maq!zB<5U)NZSG2QOBD=|&|_2^;UPg)m0EGiKYE;aMEt zj?6F}4bxA_8zBaxnXW&^Z&PD-FO0$Sb<@Om^*WY(NX+PFV9d>6c)ocR-)*0rJ7U|} zU~4lnTgkv|rDk}Mn%h@#l5UtUyF%107CA>zJQQX5t3)_>b{uCvMo6tCL0GObA-M}dyC?kJ`Gap)?_z$JJyBiv`d1Ma)b zqrmcIJ~*v%&hNt?3Q13B!4Ht%P?6v8TwcRo?Ae32>}jG?O{hsLP+PvtXST{``M7`f$Nh&L3?OxY{3eC4RQyepM0n@a5yI;dZ}@&%VO{fByw)y84R% diff --git a/graphics/tileset_anims/anim_1_7.bin b/graphics/tileset_anims/anim_1_7.bin deleted file mode 100644 index c49e57e7fcd915118d0818195435144d3f3f6f4e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1504 zcma)5v2NQi5M_osMZ45nkZ$<}eSnAL7ep-@yog#f6fkHm9-NJ}myUKjb#qjpK(@r{ zYJ2GYg7N_YtfhO@ca#_?ZqoKaPdf44J@Q0RDj;bY;wcklK&2zZVX8F7#ypKa#F4}zc$fD2vDrMk(f3kMp}=UzJ#8xqkrb0T{R@#8BZ<0^e6)?>>M-?B5Xk z$GYl)@>t;OgA!CdPvmGY9Aa05qYRxFdvYyuu}wW#_ppBg`zONil~Bj53PF<{kufxm zbZQc5@YiUw&7{&hwWT;A?R5iPLzgCDod`N*sE-fp4|LkVU$_4F`E44RX;l61jF9Nshbq9CviJf!^A<;n?f$Yp0Y+^nwrW0=yW+ z8T!W=-YB$^jiE~{mIpZ*Li0!wrZLCedX76fVaWue-2{WonDq!YCM7;E37o|^k)YSNHRsyH?`iH=j&vGEwKe~AsoVvOPH zHbjqVdrorYrjo)|h5e{6h_dRy^0mCQ zB6$u(*4I*Qd+%tus-;?IBCD);9=w&?#mZXj8Ti#w$*|63Xr;)lY;s%Mo^0(o4W8PU zUALOXHK>tN-wHKm9(QAepFT(U^_TBMx4ZMqPjI;J@-N3sH+P5mrcrb3Pm~HD@V+^D z|8QuW+wGleMwnOaPf(=kku|{|!QTx2X7D$IKcDLW#C?LSBXJ*E0%!>$_>15#f@6Ze b795BoKm>mQ)CKStz#qXMne>cI-={=B9U%xY diff --git a/graphics/tileset_anims/anim_2_1.bin b/graphics/tileset_anims/anim_2_1.bin deleted file mode 100644 index 74424fff906233f1648a92efdffc3a2732a64675..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 576 zcmaixu}T9$5QZm063}W>T7+aRZ6pzF#e`gIv!u1Tu?@L!gPnHc*(f%5`U01;ij~Pd z%RNHw8T{{}pddKxH?TWD|HAyvXLgQxiYCsv1=>ia?rZ@9aiPeRMT93JK6?wuJ;+1A zuDU=R4n@M#Kzwhw@I!Cpb69D(1|rz{@OPEJpat;v04yEV^|&NbrCZgWYJ8U@>r~@B zjq|r`pD0RqEMJm?T=n=t73ZU)$;KE+o-$2Wk?Jan?>n!_rgwL5sb?FNwWfNQMS7TP z{E+K)@|z()LVkq&=qmJx;E6(XE!Z}ZUlZ0;MHWb#Ja|_136Od3{r~^~ diff --git a/graphics/tileset_anims/anim_2_2.bin b/graphics/tileset_anims/anim_2_2.bin deleted file mode 100644 index 7b2e609c3e7432b123d8f514458b9cbff8358780..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 576 zcmYL`F;fCD5QSHfVMZG^B~+Kzp*lud6$XdSCPPbeu|;6WT&dLxjdT|~yW{)=D*wX% z{);c1LT0{XFYjeDxo7R&+*;cM%YZS~8eO2(Pl2CN@cNRP{yITw29ST06CSu=CQTA_#(o-z2>ORaw(M(|(`D(k)8;aeO8(c=-Gm0`c5ZYuVk z*-;PPpzj%B9hI6>T$?K1q|83`-anwfJ=}jNI=Y0pEY$}1>YbAwP3)48A0fYc{NQN- z*#zA+h!&WTA0a~ zK)<3NkbmJOL0G!+v+wh@qmvAs%aVn&Hh~_XEVb6A1`A_m7RsiWr^Z-U2@8k9p-55` zf8L)z!!|r)7ARu)wx2qi4UyYNZhtYe$qUQxb)h3B#k$Ew>Q*}YwR8@$5ihF~ z{%D`X>ffdkBV;Z);%aEEIP!T{=f3bG=SG!}h9jdvp&??eRMCxn*XOm*y>ZC5gHT1w zQ02>z^XHQFvSc+bb<_xTh`q|Idz3<5j7!c3rPi4B7*{VfGL$Y-WT)Pbo{(?r`|A%M zn}=#VRz*0|D?=SO|2cQ`m^cDI0>4M_n}FX0Y$|^mKqeqyAz&f!3BWG^zo6=wfNLcJ d5HuQ^Lo|VifUO07EwDR<2>i&*&Iob!_ywSZyhZ>3 diff --git a/graphics/tileset_anims/anim_2_4.bin b/graphics/tileset_anims/anim_2_4.bin deleted file mode 100644 index c350f70ec2bb5eb92cbc50d4a61397a47b38d67a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 576 zcmX|;u};G<5QYz-bbtkCLLi2kg(U+yB-FVTh^>po+Qnu?qKeg#?I;V7rN_or%ESir zE!gue{BBAueX-;J?xN_6*UpWjbBsqE#OrVYs&Nb<5u*#|edjB7KA%QSzC`TZCwjy{}?X|^5kXtvDhJ+ z&RgDJb$2Op_$ab3@|BDJ7=x1Mh0H&vBKdUou-CPQa?@?+V(MHD7E?J`%1l%qw#?i9 z7U!Fo8vEN=)BP=NX&I}>ti4)Uwa0@P2Tfs{A~)6^+vAigbDb)Q%vfm6trp z%X&q@^<7c+`puejPIv!#s!ctq_Xu=>t#yKrPP8RryTSa>Y?iUj5p#2@x}j8U|8wZ* zHadbog1-^`jo@zte<^nv@EwA(HNFEa9camh@Hd28fN%|7h=xA(!e0h|8T@7NNAO3X K+NRJ+DbXKtYsC`) diff --git a/graphics/tileset_anims/anim_2_5.bin b/graphics/tileset_anims/anim_2_5.bin deleted file mode 100644 index 71636ac22733f66d1443c732635b7fcea95682c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 576 zcmYk3u};G<5QYzmS_zh>BTSf)p;A)`u^|-^bz`x*c8OUlwX&5FrlTxSmY639Wn!cB zS;`wENIXEz@1%mB^q*qi<vfhWJ~5q1-o#$4t_v06Ka7K9K#q7(Z1xo;`! zuG7!kv;MmMocwE+tlg}iZ{(lXZQO13_;gcNHv~TdKLS4* bDose<8~o}(R|mg3tO@+6XBu?2SAF>xcIfnX diff --git a/graphics/tileset_anims/anim_2_6.bin b/graphics/tileset_anims/anim_2_6.bin deleted file mode 100644 index 79e125e620fd72ac258dac222e765a443e6e9d4b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 576 zcmZvZF;Buk7=}MI*hD87naD9RU?`E51cG66xv;wQT$@0+u*voTi!$}}4-}km68c-} zKcN1Dp6@|oV)RR&=Ig!JyK5h%`rQD?VB$*|v_Kp5wG5OVI;7NE$}yTTny%JEzo&J} z?`qZa@gx<774l$&<_3-GjkKDyv{LP{Qnw?82231MDkZT2mJHn5bgZW}5i>n9SDB-k zF}s+fB#x4|%_Y$yKCyl=R|#`{$&Blx%w}IIVaoG{&G~gj+oGtmF3dag>yB5aBJP3usDKFZWO0(ZSS-25nyrm z{2#WB#tXmjj{oBw)Wfeh8Kz!#OII*tpp=td|WDGpzx0xvr{x&84YJ^U+)q<@FDn z*XqhJ7X@J6-Eegny`$y2;d+-dZ}akb`c@s*TVpV1>PB3*IP{1N;`@E5^f1b;4Hc|dvuEd(tD pKOX#f@aLf?11f?$a=;%wqLCs%1b-9wo4_Af68wQN$+1g`z5z6w3flkx diff --git a/graphics/tileset_anims/anim_3_0.bin b/graphics/tileset_anims/anim_3_0.bin deleted file mode 100644 index 6a911444bd920cb82b90611400bb5fb99c8d8614..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmZw8F%E+;3DDy9Ye+ z@vZKEL+}O+o^p#Qzcxx<6UpJsP0ZRw;e6)U7qW}G e-BcP6wTKi`vEFnt#`ha;bH8Ikt*VVCX3HNV#9*ZW diff --git a/graphics/tileset_anims/anim_3_1.bin b/graphics/tileset_anims/anim_3_1.bin deleted file mode 100644 index a66f3382d899a2175db06691bb7152274845148b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmZvUu?@md3`D=gLP+jH)`&OorAZyrP~#$7(79!VNGQc0ii<>=@bC2O;?6FmC6TMV za(6o|B|EufN9WB`M#!qRPKr9I)e!^1j=wYUkW}jh_UYB;I$*B&ar72;qruVR-bkGJ VySejEI0;`k&VAq+aE8pN?F*qNVj=(l diff --git a/graphics/tileset_anims/anim_3_2.bin b/graphics/tileset_anims/anim_3_2.bin deleted file mode 100644 index ed7890e8380dc17810174b6b419f1da2edf61f06..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmZvUAritc5JfY?2_g#DU}jyR$JnAP@}nvcB;0_A-U7FlBVa1lF;myOupl%2fBu^H z_dB;Gq9Z-!=WXhow6v4fET>gy1bu+_2x#b`4Ay;s9vJIO1RV*Mj)3Ki(El;|LD5`Q rFP=3vev04{fjaDO>W5@MX$DfMQ}@f=HcGaXJlU!Hz@s1=G-jH=$uVF9 diff --git a/graphics/tileset_anims/anim_3_3.bin b/graphics/tileset_anims/anim_3_3.bin deleted file mode 100644 index 5cfdc3ebdd4f77d0af3f2b49154544bd9ec6b04d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmZvRF$w}P6hs4_AVuyW{7&~0Tl{EanMt#jZY*rYU+5|9(t3miwaAu=#U94LjUem{ zZy0#SOoeDp*F1LG8j}|^%L{E@QYK2&C3FY)(jb(mZ1rydy5*dRGEzkWkIJJhBLVLM zyvpDM1_W*bcwGY@8z8P`Sy?O5S@_ViN6+wgz#ZZ3g$W~n8 diff --git a/graphics/tileset_anims/anim_3_4.bin b/graphics/tileset_anims/anim_3_4.bin deleted file mode 100644 index 83dc605ff43917230672b6fd3e3f4e20720d5481..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmZw8Aritc5Czc8aDs~BxC1lm+Fl|iC4-1xV=UN6*UN$8t%dm2oT+! zmrZ7WoSQ3=wOlRt{MI?EWMLKCYB7-{eL{ah7!Qc!{v&WgYO^F_NR33?nt=0|MFQna z){_3)@Vy1=o8ufve@?tVRF5HQ3~|~4Q^`Lo51qFCpTXPN(62>t+d1&e0UNXG9*!8X@0#+WpNa9{}Z=;;YfPi!@M Ow*Im(Q{l=2JftsfTr5NY diff --git a/graphics/tileset_anims/anim_5_1.bin b/graphics/tileset_anims/anim_5_1.bin deleted file mode 100644 index f1a93897e2f28192cfa7b1da874f5580803a0ce9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmZXO(G3GJ2tz#p*?%1mz)1{1cIhLR_NPb)u#G{IB_$c;^fw}8w+#`GvaDJoc>@-D z`h4UnREyytgWm84-LTDWbjfREf5$-1CH^oOQ^%9~hB=s7%3f*=7d{>;(Hmoss{}s# PXP&P%$d{eJvH8s({s=R* diff --git a/graphics/tileset_anims/anim_5_2.bin b/graphics/tileset_anims/anim_5_2.bin deleted file mode 100644 index d63cdc5fcca2da5b8ab7500e3968e1074531c8aa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmY+9iw(mt2t;oH*ngcHfJzy_-lgvxMQM=*#`pMG`m>VCl1Ew>O8=^bI=Cp^rG1O= zLb(zjp4=xd_<_IRImZfW0zdTq9Pjs<%%{S%qEFdOT-(*%X5100hIJRfhEK=zh?IC{ RQlUN8XS&C1!r*)^_665-EJOeR diff --git a/graphics/tileset_anims/anim_5_3.bin b/graphics/tileset_anims/anim_5_3.bin deleted file mode 100644 index 0c396ccbe61223d363bb3ca879feab98661d351b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 256 zcmYL@i4DLo2m?I;*?%1mK&1?j?9zkuvDBjA59x(1MM~!DInO-2Ba}InYiRAMF@`Wm ziQWq>i^iAJ@8G}vv&4v)PmKjubPDD~G670^by{3_tT{?@P&vh6z2sT9R$p&w`@p;U NVHe)uOh0G7Wj9VHGqnH! diff --git a/graphics/tileset_anims/anim_6_0.bin b/graphics/tileset_anims/anim_6_0.bin deleted file mode 100644 index 8bdac939e67c63ff39cc6b051e2fdc0b1cdfaa45..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmZQzzzJ9x7y`m@$`UIPkebGjnwG+l>gE#Q=HddP!F-T7(EL!KIccGxp=m(i0t6r$ V#0QDP0Ei0`hRLHz1Ko)m008>27lQx* diff --git a/graphics/tileset_anims/anim_6_1.bin b/graphics/tileset_anims/anim_6_1.bin deleted file mode 100644 index cd2e32723fba781eda31c6aafc4e2d161ab49f69..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmaKm!3}^=2t#{uGX~&-6MVY=2)0r4JrJ7^ppTFOqYfZXWOJmCS%2_l&6SLBb==)E c;M1& diff --git a/graphics/tileset_anims/anim_7_0.bin b/graphics/tileset_anims/anim_7_0.bin deleted file mode 100644 index f94617c73505a157fdbe6cea964865aa73058997..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 128 zcmXwwK?;K~6a@#0yBwwvvhx<=F1un*;{_6PfF|?;-35f8@(*RKbQs=dc<`qP#6Vdx zF$F%^7xDXDTat>niggM*D&`H|tv=nVc{!m>6=My09Wi>K&Gk)RMG8AUA4IQ^{z0!h GnmpzkQR7Gru!(~#}{{ubfCoVZ}c`5?(gYEzK)Z~>kA BAY%Xk diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame0.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame0.png new file mode 100644 index 0000000000000000000000000000000000000000..8afacc21017f1fbc8a83009b51c95a79c06d01ba GIT binary patch literal 191 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsWwj+#}J9By{9*F9ySnYeYkxx zm-++2OL5P2W9Gyxzfj5adrRZ9f;+M)3mudS*~-=GzkYo1u)5`c!q%?-w=T_lHwH8F zDpbwb+u@L=l*V%VS?8YKws}H38t-R;T;}QO=d#Wzp$PybrcJB> literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame1.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame1.png new file mode 100644 index 0000000000000000000000000000000000000000..dbc8030952e6feeeed8e6c8ef6057d255d6dc3b9 GIT binary patch literal 177 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsR~aQ#}J9BYfo(CJ>($Za#6GW z57X&M-U@Ti#9BmHCCEV-AX+U+pw2H*$^QuikZuO(rJ_cZ9?+FG|xAU9_>u b@7pr|k2~k+q_{Apg52Wi>gTe~DWM4f*Dgb@ literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame2.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame2.png new file mode 100644 index 0000000000000000000000000000000000000000..57049923c681e2cb5ea3dfe1b04e188c26ef599e GIT binary patch literal 209 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsTrOwjv*3L*PhwPd&q%@HQ@Xt zKFzzLnG%iHVz+rDnkl$DI+p(D%6iwu!?zopr06?5i0{{R3 literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame3.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame3.png new file mode 100644 index 0000000000000000000000000000000000000000..ca84cf9bfb3d97e92c4eef80fd233b6419867148 GIT binary patch literal 235 zcmV{n~4j z!|N0L2hk{=(h)7?fsPEc1kpm|P6QJ1UW6d6XZEF_opY#pS0XRC4t&m$S6__n>8O~n z=8|Koz0NXBxsEY#hN9*eIh?TVZKt_nm24-C;F>=n+w>I}|nb(py!>o+z_p^L9hHxd8<002ovPDHLkV1nS{VDkU~ literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame4.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame4.png new file mode 100644 index 0000000000000000000000000000000000000000..a096093679eb22b39f21f4fc0926d7b208a37cc0 GIT binary patch literal 219 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsYRYHjv*3Ldrv9y9dZz8eONB$ z!^{*M=uy>jtI*a}`x(Ow*3P6bg@83LRcGz;+`-%@YRkxZCP>JKb^otP-#`3n`@dk? z!5UG3sn@@kHjW3~DtFW3Eo@+sj;_q{$8otpT*enV!HX?Kzn_q+qe z7Ai5kt6RDgUpDi*J9~WSc{XubaoaNQ4#^5x*Im17XXVKxrx_e&HRk$vWglZ&&pe(V SpS72OTB>AsjQ4fAF*N2%M5Q@+0TZ z{R*RwM6om*;UhoZh-H~xmOEkK&AT~@HEBlMvYFz{rL|^$-g>@lM*q&()To)Vs+1Nj zE6j>8^0pIbYH^zFi7wOh29q=2{{Lsx{t$Uh S^1xG&?F^o-elF{r5}E)L06rN2 literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_celadongym_flowers_frame1.png b/graphics/tileset_anims/anim_celadongym_flowers_frame1.png new file mode 100644 index 0000000000000000000000000000000000000000..5d1c493e38297f8542b9e0fa3d4ec93a2a4af676 GIT binary patch literal 171 zcmeAS@N?(olHy`uVBq!ia0vp^0wBx+BpCi@`0fExMV>B>AsjQ4fAF*N2%NexkI|=Y z9%oXGpYOIgJd=z(dE<6UocJ+EY}TGraz{9Lz4h1)d(K`ubJ(G0a&b;yt0l8!eVU&c zw=Z+%_F1XZq_|SnSnhdM5M>nb>Wt*-!)DJLdrZ^)ZqAA1H>x}GZ*#nQ6}w6ONradHm2E$6agEX0|S4 zEM054=ai1A$O(($W2Y>1B{jA_JEJ+<__br!wK{>D~UZJ!(hve(nq&t;uc GLK6Tdt3G-F literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_flower_frame0.png b/graphics/tileset_anims/anim_general_flower_frame0.png new file mode 100644 index 0000000000000000000000000000000000000000..49c7ceaaf502d442a50023340d98b82ad862cad5 GIT binary patch literal 166 zcmeAS@N?(olHy`uVBq!ia0vp^0wBx+BpCi@`0fExxt=bLAsjPJ&u-*BY{0{Epgl?~ z((&+~)goC(L`~!ccO*YtdS>P4&c&77aB5AEjM<>I_%DJ$UiI#FL!HlNZ0f==71j zWp?6V+XK(D)h)Z@fFV-vWZESYV+VQ!+^fBAK@;Mx literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_flower_frame2.png b/graphics/tileset_anims/anim_general_flower_frame2.png new file mode 100644 index 0000000000000000000000000000000000000000..5eb7401cf47f53b7f3b1fe0f52b3c1a0cbcfe165 GIT binary patch literal 162 zcmeAS@N?(olHy`uVBq!ia0vp^0wBx+BpCi@`0fExnVv3=AsjP(&u-*Bpuod&KwQ@~ zEJ4EA*^$|2!kcv05|PNRz9xxD9)+cs{-2h3|FB(5ZbC1&ZtV$c-3itj9EpolG<{rV z_iM=dKUvb2w`Hz#$U_HsE1)IJCO0 z?qL7IH~n6=^LXUZTfIvA@@o|Dtlq)gSS~1XT7PxgSC2V-AAc~o|M6bhQ+n+k$Z}6t KKbLh*2~7a#A3h!c literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_flower_frame4.png b/graphics/tileset_anims/anim_general_flower_frame4.png new file mode 100644 index 0000000000000000000000000000000000000000..d4d826f6dbdde1eb4aff059eb97a201925976df5 GIT binary patch literal 163 zcmeAS@N?(olHy`uVBq!ia0vp^0wBx+BpCi@`0fExS)MMAAsjP(&l>VIDDbdekbiVc z)xsySFu~Ek;kz>1a=y5(-i2XTj_}#*+uLhCvHf%L5%Z_a1-kOrd?t#Bn9ZNYaq-LR zX?ZGKGZjjgIe&j~?vqJ^j&Z20arW_s1aq-vFS;Lj6)s<7taF;RvC5~ahxg20knNtX KelF{r5}E)XaylUZ literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame0.png b/graphics/tileset_anims/anim_general_sandwatersedge_frame0.png new file mode 100644 index 0000000000000000000000000000000000000000..35cee12c46df40da7fd76b4c9c6795439fcb1180 GIT binary patch literal 407 zcmV;I0cie-P)Jmg)Aa$(&ApoafIz<7K=peu-^zFWAVVs zTf65K>+s=mI@s0ApS$ePFHBnvmiwSunJ^;^5VYnLS#xT6Ko1q0F2k%7f)8GVq zqR1zzVHpIiDp3`oy|`Q;jQk1(^&GihX;4UKc;%zfWO!*3`4m+dqK;3kXDp6`deHFK z*e^R7J=A!_K3ki7ZR{FSC>Qk~cwSiqFV8&@@+`|m$maK%2ot3yBJMhR68(VE>QN*x z75#$3`rBo}u5keAa{CnE<#T}&?=!pL^N9Dky<%9&KAJnT?;kW~t94)CLvrskxZD|B zwgx+w`v9Ng1GwA=*ty&X*tpzB*tpzBFfMm~$K}qjmE8MoXl#cT^#$^lN#>KHM}q(W N002ovPDHLkV1gtxxU2vG literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame2.png b/graphics/tileset_anims/anim_general_sandwatersedge_frame2.png new file mode 100644 index 0000000000000000000000000000000000000000..d6109731cf6abb969fe1c7c1cf33db778f450436 GIT binary patch literal 434 zcmV;j0ZsmiP)jyx8KXgpTx0TD1Bso6r3bQsKm)D33S z3d1EyKL$))G#cc9bPMOSls?KRpZQrsn&-$cozyJHAW)*UF3S@5>?BD5MXK`l9*6JZWcg!BAE+iMSO9$@Sih&2u-0Gvk%aTi5q>&~M9 zar~wGO!gi2uI_yx)Ex+QFX=nfy-#1E?m(#fV};?0zCzs{eBD=6hPsyyX~2(*CT>$` ca`d170N3blx_g|482|tP07*qoM6N<$f^t2=^Z)<= literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame3.png b/graphics/tileset_anims/anim_general_sandwatersedge_frame3.png new file mode 100644 index 0000000000000000000000000000000000000000..5e3aa58f8635be75690638663625de2e512481a5 GIT binary patch literal 460 zcmV;-0WT%me5t)}#rpve_0}5YD}SQG)AZzb)lYO8v-ke z#wDmO8V4<{%KZW8f=jV$Xj`W5p*=XWg^sN2@(bE#aupbP=5NQ5@cU$OHi5_le{Muh zUfY-WCbFK19OK5?cP~WFksR+mK6JAqv9BWH>}W1$@&*I1`9fhKGLyByFV?44PVezI z^fCTAzsKlfXnh!`>3aTyIUHm$8k5DJh%AaUpbee|w0%#89ah12s}_UptX@BYfx@h9kHF!S}Fs_mQ4E-KR2HXrF)SgWGHs9#!`(A?dC#=|18y>AuBN(w&fW zPe74B5hmRaP+fe*m~>~Kq&wk3MgFWqnYDfPpZ@_MD|&QPc;s3D0000C{ek{_`)IyK)~ym20g40000 z!A`eKJRj=xPIZwpWrb4cGG#Xt1tnW)F@jQ3OYbmIU2e}(qzt*% z8dp*i$ds*VXyvw`uaxZq4;aZ^435C%jAvTVy^#RddJ~nSEQ qxy|=D-x=28dtZjGb?^4ifBpuNOhOj@&*&lm0000tuU{!A_?tnFtNUCXi4A!NWj<_D^D9E9dwF+ z$U3u&e<~+8*v|Zus0qsswB2`&pnUt#3rei$wQmrvO)rb=6lo>jw z3DqC*u&*krnyj!{oECI@z#}%r$}U&d$&f(24a8x%7lmPr5ZDPI%Xbv~N#eRF?j@nN z0e-BpB;w${CCN~wV{Y nyzdMj;`>mBeri3mzwi77Xxlc}UwP5Z00000NkvXXu0mjft`W&* literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame7.png b/graphics/tileset_anims/anim_general_sandwatersedge_frame7.png new file mode 100644 index 0000000000000000000000000000000000000000..47916c696c5ddfe8a5e746d104e167d1d6c32d87 GIT binary patch literal 408 zcmV;J0cZY+P)7xV5C`ykfDGgj$g`McYZuaN?E>iwka+Csl1i+x7?_iV6^RZVBjLxO>IPfWQmO9! zZ3;|1>ExfzA2~SE&nwk5wI*F{)U;_BT>3+cJ*su-_Nb{VqZH6oFD;iCb!qqopyE@C zru%A>>dz z;^m#)y<67?f}&$wAPgfUg+w8eP7xSGWXvn44_Yg=MpD$L4U!QY(FJhwcl#G1imo$CBx4haC5hG@N-|%!OtCV zb9cbpX8`67xVg{B`nmHve(sDn?M9GH!+d00001r;P)ljA7=~ZL+M%w*)&ct$AYF%M?v-pHq?l~5wB`>qxsjoZlQm1vOV-#6D^eFmr1&p* zD`IoEM$N!+-}(I6A{9a+uk^@I?(Vzq97_l7QsmIyTFH=m>!fHU%Xg$;$#fvHq#h)t4Q3`r(#;OY$~Q+ckE(LH|1 z^H@#P2mG>+cx>frtdvyKA@0W0Pf}eBQNK<`GM4w)+)1fM@-yvRoBF45$Dkncc}jvH zvK%4s!9iI9W%xSR9fQR#b`p9Cf|4YlvwV%B z@X$WjGdplV=h3#Z>|W5AN3EA6kMwPpR+=x_lWikQZ1Wu{Sn@x_G+*106pd`js0G;< z)BB%q=BpWjG|y53bFEhd^2Hz{poP!`7D5aNh|_C9K%}W4_O?$a?G!KOa^8?za8o|U zzV^A9YeCqlg&^!=aZ11sq@C~-FXr-n?IZMRMnDX*l)$z9Ng(w@o$wSd?#lPHPZuFt zn)F0UK|uQalO#TnNg|0S)^H0>?1L9^{Ep~u36`+EK=?{|7DX=!yaJvRXkP|rLYxq& zd^$O)sxtydLWD%uA`XI>KvmZjf!YVPz3T`lpS=n1%)PifpSgGc{Ez$wqfq7P@{7gB P00000NkvXXu0mjfVFVNv literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png new file mode 100644 index 0000000000000000000000000000000000000000..a765897d9c3b5efd05ea9baf885203f8ba49488d GIT binary patch literal 586 zcmV-Q0=4~#P)9qr7r;oY74auPx(?0UE14pMRFe&s*6jx%xs9cZleJ6FOV`*-K0tTG09ywn zdSyXm>SZfxrO3RmeLe>nruwHm_7mT~*FNcx<`k_pw62VVl4nkIUQ1ew&RUWqbDbK= zy<{!Py;KHQg+@V%-WLVQ?cr!#ic*#QR_gF={2FVeCQ_*(mT`PAP-=j2`QXDf#uK@x z;(ZG%_aZe`@9>Lm(TL>dNGYi%1Cq&+R0ltB{VLv%Be}wQd1Tb(kd|1RRbf{}Sq2B8 z%fBQDLI#1g0RwA{Wniwp8U`0ha>3B3t?$f+^lrW}ET5Ub#5J`?l~R^b3y-SmaT3@o zmLApf<(TeURL`d=$qm<|X{2dhuqf{He8FnvEMtqa+?1y(X&s69+gGBUG2J;j8OCWWR8u3lO zvmf5oJnabjF?6lch!jFHkS-4uBc)+rTpHOnW|zTJAs#WPPK_`?6a*22$OX@%=naFw z1-vak{LFr>_Gj5Re;y)# Y098E&Ge@toz5oCK07*qoM6N<$f{4HjBme*a literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png new file mode 100644 index 0000000000000000000000000000000000000000..5673e4cdff9ad20d9a162a792735be92e83023a1 GIT binary patch literal 767 zcmVc+@FNBDSUMtQW1oNxel7dAklKS4{*)c4TT%8o3!>dJV0K7iiSwh znu-t!-O?c?1!iVg%- zUc_;K&HX5XeD_K3lsad)<7uB0xVbafxesvb=6>#=v0%qdpaR&rGuXL*fWgguVBonE z-16MtbJ1I0bZny*LMal%ydr_XwGhc#5TIZ|UA6@aux$`Ker;;iQj;xobFVHvwhi{cGWZZw?hvS-=~(JgkqEG(XX|JeC6ZEsPgK;;2#LQ{C4R9=&}~=3 zLlt}yEJhzXAKp$sSOy?4+bBkq4+kY5Mq>z9Y|Bbg3~;I%!1U%zd~>hwH^W7XTjJF z913y30_|gh1Fa8PuqVVm3nCwoMN!6r%m+NkvS+MmO@RFs#=bc)idU)hNzqEe^zXAWnCZfBBDRKY+002ovPDHLkV1hF#YEJ+F literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png new file mode 100644 index 0000000000000000000000000000000000000000..89276ad9f5f1552b121c26198de2f5b907c925a4 GIT binary patch literal 783 zcmV+q1MvKbP)f9Ek^rAK;p$uxlLAAS5Krb=qK4B(mtC9>Lr5_x4oN#UTZ1!SX*0V94h3<%#3m!}3eH}LbC^TSuk zGx)^$S;YBsxK5I{PdPsaJ8{y&yKQv9lb0HFbP)4X{u(;`iI)UR&Le)tp~BUb$5f% zuZPd>@VVD2NUD=d6PUgu*uE2(z7v?fU%+7dJ`hmfT?zUAVbRe>5TuM@LLdZVm>}~_ zMhPM-g{Vpad9F6-Z3C4I%c=-VPythlF$G1Ch6Q6Guu+HY>Qti+YKWY4P@|Fpb(ql+ zfQPM)d;qpYmAayN=4^=E2}KV||UcMu4-#Kz5RJU)XEqmE3iPE`o2Lx*zGp%UirSRM2;9+#Vp zDNG1T!NQXEWSbPHQUp5%EFVF-rBJ%fYCJwcIO(WS2R~DDJaqSCmZV6>&G>GN$9Dtg z7$uH2W{4PzC?Rq&L*n8OOS>=$?uO@LhJDZTeb3vQpOn8?og6kU;BnJDp@cog_9OB?G>)D~FgFZXPN*7I3!sx@e>M@mf$=vYM#rpkhz zCOw!|Fg0roCZ}l6bYdVPA{aBo24?g-*#Zr7w+Y6SiYMHCK8p+#6sa*?^f{sOK>Q~%N+9Huq99BYxqu=R-52!TgpJ5 zNm#Ydj)gqFf%|oq=ikn6pjhSWbhR!_ca9Bs*_G$jGY_(SeN|uO87#A9mR)9-kh*|w znhKGo3+OKBBDxC@f^rKXV6N1h1@)yk@s{1sP*2m7I>Tz2cIxTk6Tzax+5o3{8F(Y# z0DLQ#fIY550qYX7h3I%586y)NZ;$*4h9A_OKso3{2FQ!{mIPb>^me2M47WV@0fC*n z1sZn&cNPY4XXnmf=01R1J9h>%(hG*zKw-ySY=PNyVVdgrT{SZkZpi)RuR40i@%GR00eOpKC4=^)z8uT2R zI!Mo9$aSy*&6%l#fO8_MMFoir_@S>9Et#e&Y&aYAURYy(&$Sp;O}A`R#zJeg3868M z&C*v<0DE>buQ6FS~nO0-aB2mJ*s*S%=PtOTZ=&OWD|hAV3xbF8&IH3kZY=Sbx}4 zwWy-y0v@$mFIZ4>v4P!M>xt9q?Sh1J8TRf+qkESy28NI6&NILFQru`&o9tf*r(N z)}}?PR%@~7^Oa{T$X)PPG-uJr)5d>;s&dt<>Rx&N{Y(2#@CyWGGNVKlBKH6Q002ov JPDHLkV1iowfR+FN literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png new file mode 100644 index 0000000000000000000000000000000000000000..473f41e6dec717b757061407338e71173f970e7d GIT binary patch literal 856 zcmV-e1E>6nP)LHn@0_Hl8*s|SpS&O6_w}7)&|0UNo*0NMoQ+|ubUM;{0+X>y zM>qui>BPjD)_{u>Gh)z5JYpD{(FjH)WPvC_(70FkBU*z)XBJWfV|Qg6=#L`;Ix~VL zM(|>}MEHK(Xjzbw;ggid&%(#>OUkw{Sk$Ar`Uk&INKG+alrxDDg#|s zQOa|GJpTas^nIRRPICx3UacU+VyZDERN(TY0<#mSlx8Pof^zAiSuV|*1zh|AvjT7- zZ2;QJ+wsfAuv0F&LmwAS*V@Vv%5)go5tm>iYnJ z`;NeUU&4a>J|LjJGhpA}!cXoy0{8tbEV%CjSaRP{hx?AOpuWGehh}N{mthdhswyFhOOhQYKZbWAqR*(n-7&P($ll zM+0hj-Fn9Zff}N2td0<;hIM+$xX{TaY6S)qO~vQr2Nx@4{Rot(+y4bBd2~c#@ECh& z(!oQ?h9VnlV|)Z!wTC8Xo^9amurcGY)w*GwtUr!dWuf~Ly`nxs74@m&VAcA`aPYkF zqcYT~qMvFEG@js)-L8!2u?_)EWeHB<;#k*I3@nV>8BE4gb;CO7XKh14B=j&6R3G7` zN)-JXc8Y${5WhEY9&k88XWA~d^`Y&yK32yTigc)7xL6Mp>{m)dr`RtBnk34Rg(3c2s+l=wQ}*uYMn?@~fph%HKR=x>V&f#U>}5EKCq zg5U`yI7L9kE_JrSEduVj?n6p=1aO~nbEmsP>`=l--#?(-*q9e_3$7)`n>olL{u`{7 i*Js@=%iTBaU%_uj92vV5VjeO800000W6?cB%Gtv zbev}bn2c-4uPtDHnL9}HTp-Cuc@A<`fRDtyhnHpyNew795h{xCb5#-iJ~z- z)+ZmM_wc0kFwpt{?xW~{4X58y=$_^XbRJ}mfF zmbWa3TtHz=!2-W^+h-A!{Wg?+Xv5YS>)%lJ`M~CJ0`8|>LyI>0)EzZK(3XB~&it12 z6B)m?6;VHDvERCpeo&zKfmQX0c)_sZabFPFxf9sASFo~kzkrpUy8zFfLFR6O<}Sc< z|4KeGck;1wCwSy>bBSu@iq>tQQi$pbVWL!bqKYo4&bd;Z@fBPdqZHp^ah=A~Q5u6u zjWJnbV1#H$DP)sw5|hMdN)jIe=VQ(lDC?tuJ**FTm`m%Ej%Lm$n=KLx69P$Lk=o7K zYz}jKocftNL)9UmGF;SfVQC}gHrOZS#@NSjtKt(=(WZ^2F=@4DeY%sL^T8fn3##b| z)qF%LlhOTTw3!w<;|1MM#*5sKz=ZojPV;8NOL9CW2}~JydCDpAp<4uH>f;S?s%L$& zNzeIUkJ?CMg=tKUB}R1S*fiqpK=a8`~RlJim4XUZw@;d$}V z?#OI_q%N&bHyJx0s)_4ABPdnN#s&m|V!?3~?Xe(m@my$}n_6!HUa_F=26mKs$D+5w z#v0z0c#H5Jl$zDog`8fOLgTA+Ze|bqNBPQI|Bfasf-*C54(L8y9M{Y+R^WvdID5q%>e& z!JPwla%aa)m_M^iQh)_Wnccsi9Ewy}gtL}x3D~qyWPr-|$QDvEWCUzM*5wS` zsF4=JLSdO` zJ*CI_{A9|okiyvqS}cP%*F<&w3+aO{jk)Bc(U7h=0fPVs zgDcJ#L3RzU_qPMYMhCo@AtHt$`>6qPt<7k7z}Kq`8wTvh0_y$-o94;d3x+2i?K!~D z9pLBQ&>uhd3wrW%2l%-QxE8ns@N>VQ#?Ku(e(wH=s`?oYJ#Y4&vl_3Iaw|p37{y7O z++~~GWMs<1n9>=-**Kry!}X*nk$4YR)+%Lbt>SX6)P!|n))Jj!kNvu(c z4m9jabkt78z*{|tzb|GkYrxD+Gq(i(GI>G*k7P`|r ekUu@g>);>Aw!odVANmLY0000tXP>FL{dzycwnYaHg!n|R`@H10)zh*>Cm+QlDdq8Q{(n8ciKfIX{~!64 Yb@9Pt&az*)L_jX_boFyt=akR{06yHgdvK#fDED1+R~|t0!)o{LLZZ`$vhp7p|R3d>5}%Tz;+mIitPZ V$sH*Rp2>k+;pyt{b!yKvWSMtSwc z4xc<3{#>7MWrBKfX~N^2;QXgCrwdPB3bkzfvd=_&c0}jQ?alq)r`TBg$$!y)^j&!0 XnRCaSKfjn%0dj|@tDnm{r-UW|(U(H2 literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_mtember_steam_frame3.png b/graphics/tileset_anims/anim_mtember_steam_frame3.png new file mode 100644 index 0000000000000000000000000000000000000000..b4f607b5a5b7c4e36f5534d37485b15d2cd39117 GIT binary patch literal 171 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsUlAo#}J9Bsr?suk0|gsTXV}Q z1lcrvk5`v_u^>;w7@O1TaS?83{1OR1(K>Ppz literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame0.png b/graphics/tileset_anims/anim_silphco_fountain_frame0.png new file mode 100644 index 0000000000000000000000000000000000000000..c23f5886c7f0ff45127c4aee357c836620bdc162 GIT binary patch literal 222 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsimGSjv*3LL;E)J9Wvl?=@%&b z#Xj+>&fFg?+C}1OBBtK<>lbmypWLat%0l(i)0^q6cNI&fuf11zg->bkF(oF?^((eJ zOipamQrKbFG2tQG)ML>m!e+e{tFQk!vg%%!@vO+t-3xm^TWw`E+LD>WZT?-pcfQhz z&S;$!q5jEN?6R%|dG=`ilkd*@H~)!o{j=$lY*o{>-mYv=u~Tkr-*{lT%%Vai^`A_y Wid9yARJA(=a=53fpUXO@geCy+iC3=x literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame1.png b/graphics/tileset_anims/anim_silphco_fountain_frame1.png new file mode 100644 index 0000000000000000000000000000000000000000..d5e6d74663a8ef56f765fdae8196aebf2d22c57c GIT binary patch literal 208 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsp+0Bjv*3LOZyG^nhkhd_Xia> z+*8d+PCh^diAiY@vbGb~d7GH#9iHO;2>w>#%M@gJh)UZLW}x)&O(oi5I1P&2N& z@m6z2pugsf1AgiHU=sf%8AYn}gXJEb{wUP_#$_MZo?Z8kTo%D?bFX;l`9KN~Lta;m4RpUXO@ GgeCy@VNE6g literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame2.png b/graphics/tileset_anims/anim_silphco_fountain_frame2.png new file mode 100644 index 0000000000000000000000000000000000000000..e578cfae7451656872de31e08d80350f4108a6df GIT binary patch literal 213 zcmeAS@N?(olHy`uVBq!ia0vp^0zj<50wfrI3wa3wsX3l5jv*3LQ~M0L4jb^e)(55b zFJ$L96le97BP(#4-@zN+ec~r31&4WY<(_0d==?)bxyB)5om0Qvf|u%(*1bH)>6XSL ztXE#5E40(2%+N=PMWIK-X_b@y8m7<-J)v8}q|cPjxgI3`VePbydOUrzUwtcSob+Z< zo2OLH!dxc)x<#o^oIjN(Pu&=<^50V4^1qE;c#eE%S*P4inK@5+kLIiXeH*^L1ms>% LS3j3^P6&;{<&ma;M9Q8Dp+Y;2c{QnJNla=hgE!vgwZ3z|Ky>qjHEKsq7WPT5D{)jv*3LlYj8D@ciib>hS2g z&K|E5N_A`JocvJ#^vqm`q;Gj`@te!vw{1{JN{F1WceO)T`nssCU5RP}25;DyIJkAT mab3L-8gZrZs6ma(iCTuEHYes?-BIoYvc%KX&t;ucLK6T+fHQ^w literal 0 HcmV?d00001 diff --git a/graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png b/graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png new file mode 100644 index 0000000000000000000000000000000000000000..52a687e69fca906dcbf35b84720980c24950c056 GIT binary patch literal 146 zcmeAS@N?(olHy`uVBq!ia0vp^96)Tr0wfp|-f{m1Qjwl6jv*3LTl)?94j6DS|NSq& z!@gl@@sabJmK^lF%Hw;wz-gN*bCi5eLD?1NwNm91MgPf1Cg`l_k=U@q+;Lsi%Xb Date: Thu, 3 Jun 2021 12:45:59 -0400 Subject: [PATCH 18/21] Sync LinkPlayer Struct with pokeemerald In pokefirered, the `LinkPlayer` struct used an 11-byte name field and puts extra link-related info in the last three bytes. pokeemerald separates these last three bytes into their own fields. This commit replicates how pokeemerald handles those fields. Also renamed `IntlConvertLinkPlayerName` to pokeemerald's `ConvertLinkPlayerName` because I was there and noticed it. --- include/link.h | 7 +++++-- src/cable_club.c | 2 +- src/link.c | 18 +++++++++--------- src/link_rfu_2.c | 4 ++-- src/trade.c | 6 +++--- 5 files changed, 20 insertions(+), 17 deletions(-) diff --git a/include/link.h b/include/link.h index 564180b2b..7747bd7a9 100644 --- a/include/link.h +++ b/include/link.h @@ -127,7 +127,10 @@ struct LinkPlayer /* 0x00 */ u16 version; /* 0x02 */ u16 lp_field_2; /* 0x04 */ u32 trainerId; - /* 0x08 */ u8 name[11]; + /* 0x08 */ u8 name[PLAYER_NAME_LENGTH + 1]; + /* 0x10 */ u8 progressFlags; // (& 0x0F) is hasNationalDex, (& 0xF0) is hasClearedGame + /* 0x11 */ u8 neverRead; + /* 0x12 */ u8 progressFlagsCopy; /* 0x13 */ u8 gender; /* 0x14 */ u32 linkType; /* 0x18 */ u16 id; // battle bank in battles @@ -277,7 +280,7 @@ void CreateWirelessStatusIndicatorSprite(u8, u8); void sub_8009FE8(void); void ClearLinkCallback_2(void); void Rfu_SetLinkStandbyCallback(void); -void IntlConvertLinkPlayerName(struct LinkPlayer * linkPlayer); +void ConvertLinkPlayerName(struct LinkPlayer * linkPlayer); bool8 IsWirelessAdapterConnected(void); bool8 Link_PrepareCmd0xCCCC_Rfu0xA100(u8 blockRequestType); void LinkVSync(void); diff --git a/src/cable_club.c b/src/cable_club.c index c3de9dd26..791f04a07 100644 --- a/src/cable_club.c +++ b/src/cable_club.c @@ -659,7 +659,7 @@ static void Task_StartWirelessCableClubBattle(u8 taskId) for (i = 0; i < GetLinkPlayerCount(); i++) { gLinkPlayers[i] = *(struct LinkPlayer *)gBlockRecvBuffer[i]; - IntlConvertLinkPlayerName(&gLinkPlayers[i]); + ConvertLinkPlayerName(&gLinkPlayers[i]); ResetBlockReceivedFlag(i); } data[0] = 4; diff --git a/src/link.c b/src/link.c index 8122aafc0..d2d9e630f 100644 --- a/src/link.c +++ b/src/link.c @@ -321,10 +321,10 @@ static void InitLocalLinkPlayer(void) gLocalLinkPlayer.language = gGameLanguage; gLocalLinkPlayer.version = gGameVersion + 0x4000; gLocalLinkPlayer.lp_field_2 = 0x8000; - gLocalLinkPlayer.name[8] = IsNationalPokedexEnabled(); + gLocalLinkPlayer.progressFlags = IsNationalPokedexEnabled(); if (FlagGet(FLAG_SYS_CAN_LINK_WITH_RS)) { - gLocalLinkPlayer.name[8] |= 0x10; + gLocalLinkPlayer.progressFlags |= 0x10; } } @@ -602,11 +602,11 @@ void ProcessRecvCmds(u8 unused) *linkPlayer = block->linkPlayer; if ((linkPlayer->version & 0xFF) == VERSION_RUBY || (linkPlayer->version & 0xFF) == VERSION_SAPPHIRE) { - linkPlayer->name[10] = 0; - linkPlayer->name[9] = 0; - linkPlayer->name[8] = 0; + linkPlayer->progressFlagsCopy = 0; + linkPlayer->neverRead = 0; + linkPlayer->progressFlags = 0; } - IntlConvertLinkPlayerName(linkPlayer); + ConvertLinkPlayerName(linkPlayer); if (strcmp(block->magic1, sASCIIGameFreakInc) != 0 || strcmp(block->magic2, sASCIIGameFreakInc) != 0) { @@ -1640,7 +1640,7 @@ void LinkPlayerFromBlock(u32 who) block = (struct LinkPlayerBlock *)gBlockRecvBuffer[who_]; player = &gLinkPlayers[who_]; *player = block->linkPlayer; - IntlConvertLinkPlayerName(player); + ConvertLinkPlayerName(player); if (strcmp(block->magic1, sASCIIGameFreakInc) != 0 || strcmp(block->magic2, sASCIIGameFreakInc) != 0) { SetMainCallback2(CB2_LinkError); @@ -1718,9 +1718,9 @@ bool32 LinkRecvQueueLengthMoreThan2(void) return FALSE; } -void IntlConvertLinkPlayerName(struct LinkPlayer * player) +void ConvertLinkPlayerName(struct LinkPlayer * player) { - player->name[10] = player->name[8]; + player->progressFlagsCopy = player->progressFlags; // ? Perhaps relocating for a longer name field ConvertInternationalString(player->name, player->language); } diff --git a/src/link_rfu_2.c b/src/link_rfu_2.c index 76db5d1b0..d2c605d7b 100644 --- a/src/link_rfu_2.c +++ b/src/link_rfu_2.c @@ -1769,7 +1769,7 @@ static void ReceiveRfuLinkPlayers(const struct SioInfo *chunk) for (i = 0; i < MAX_RFU_PLAYERS; i++) { gLinkPlayers[i] = chunk->linkPlayers[i]; - IntlConvertLinkPlayerName(gLinkPlayers + i); + ConvertLinkPlayerName(gLinkPlayers + i); } } @@ -1814,7 +1814,7 @@ static void Task_ExchangeLinkPlayers(u8 taskId) ResetBlockReceivedFlag(r4); r2 = (struct LinkPlayerBlock *)gBlockRecvBuffer[r4]; gLinkPlayers[r4] = r2->linkPlayer; - IntlConvertLinkPlayerName(gLinkPlayers + r4); + ConvertLinkPlayerName(gLinkPlayers + r4); gTasks[taskId].data[0]++; } break; diff --git a/src/trade.c b/src/trade.c index 656cba37b..4893f5724 100644 --- a/src/trade.c +++ b/src/trade.c @@ -2623,7 +2623,7 @@ static u32 TestWhetherSelectedMonCanBeTraded(struct Pokemon * party, int partyCo if ((player->version & 0xFF) != VERSION_RUBY && (player->version & 0xFF) != VERSION_SAPPHIRE) { - if ((player->name[10] & 0xF) == 0) + if ((player->progressFlagsCopy & 0xF) == 0) { if (species2[cursorPos] == SPECIES_EGG) { @@ -2697,11 +2697,11 @@ s32 Trade_CalcLinkPlayerCompatibilityParam(void) if (val > 0) { - if (gLinkPlayers[GetMultiplayerId()].name[10] & 0xF0) + if (gLinkPlayers[GetMultiplayerId()].progressFlagsCopy & 0xF0) { if (val == 2) { - if (gLinkPlayers[GetMultiplayerId() ^ 1].name[10] & 0xF0) + if (gLinkPlayers[GetMultiplayerId() ^ 1].progressFlagsCopy & 0xF0) { return 0; } From 88e3ff0e39b337ffe401922726fa2b3afa2287c4 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 3 Jun 2021 12:49:25 -0400 Subject: [PATCH 19/21] Revert BG_CHAR_ADDR replacements in tileset_anims.c --- src/tileset_anims.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/tileset_anims.c b/src/tileset_anims.c index bedd19445..abd0d80e1 100644 --- a/src/tileset_anims.c +++ b/src/tileset_anims.c @@ -207,17 +207,17 @@ static void _InitSecondaryTilesetAnimation(void) static void QueueAnimTiles_General_Flower(u16 timer) { - AppendTilesetAnimToBuffer(sTilesetAnims_General_Flower[timer % NELEMS(sTilesetAnims_General_Flower)], (u16 *)(BG_CHAR_ADDR(0) + TILE_OFFSET_4BPP(508)), 4 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_General_Flower[timer % NELEMS(sTilesetAnims_General_Flower)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(508)), 4 * TILE_SIZE_4BPP); } static void QueueAnimTiles_General_Water_Current_LandWatersEdge(u16 timer) { - AppendTilesetAnimToBuffer(sTilesetAnims_General_Water_Current_LandWatersEdge[timer % NELEMS(sTilesetAnims_General_Water_Current_LandWatersEdge)], (u16 *)(BG_CHAR_ADDR(0) + TILE_OFFSET_4BPP(416)), 48 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_General_Water_Current_LandWatersEdge[timer % NELEMS(sTilesetAnims_General_Water_Current_LandWatersEdge)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(416)), 48 * TILE_SIZE_4BPP); } static void QueueAnimTiles_General_SandWatersEdge(u16 timer) { - AppendTilesetAnimToBuffer(sTilesetAnims_General_SandWatersEdge[timer % NELEMS(sTilesetAnims_General_SandWatersEdge)], (u16 *)(BG_CHAR_ADDR(0) + TILE_OFFSET_4BPP(464)), 18 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_General_SandWatersEdge[timer % NELEMS(sTilesetAnims_General_SandWatersEdge)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(464)), 18 * TILE_SIZE_4BPP); } static void TilesetAnim_General(u16 timer) @@ -239,7 +239,7 @@ void InitTilesetAnim_General(void) static void QueueAnimTiles_CeladonCity_Fountain(u16 timer) { - AppendTilesetAnimToBuffer(sTilesetAnims_CeladonCity_Fountain[timer % NELEMS(sTilesetAnims_CeladonCity_Fountain)], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(232)), 8 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_CeladonCity_Fountain[timer % NELEMS(sTilesetAnims_CeladonCity_Fountain)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(744)), 8 * TILE_SIZE_4BPP); } static void TilesetAnim_CeladonCity(u16 timer) @@ -257,7 +257,7 @@ void InitTilesetAnim_CeladonCity(void) static void QueueAnimTiles_SilphCo_Fountain(u16 timer) { - AppendTilesetAnimToBuffer(sTilesetAnims_SilphCo_Fountain[timer % NELEMS(sTilesetAnims_SilphCo_Fountain)], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(464)), 8 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_SilphCo_Fountain[timer % NELEMS(sTilesetAnims_SilphCo_Fountain)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(976)), 8 * TILE_SIZE_4BPP); } static void TilesetAnim_SilphCo(u16 timer) @@ -275,7 +275,7 @@ void InitTilesetAnim_SilphCo(void) static void QueueAnimTiles_MtEmber_Steam(u16 timer) { - AppendTilesetAnimToBuffer(sTilesetAnims_MtEmber_Steam[timer % NELEMS(sTilesetAnims_MtEmber_Steam)], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(384)), 8 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_MtEmber_Steam[timer % NELEMS(sTilesetAnims_MtEmber_Steam)], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(896)), 8 * TILE_SIZE_4BPP); } static void TilesetAnim_MtEmber(u16 timer) @@ -295,7 +295,7 @@ static void QueueAnimTiles_VermilionGym_MotorizedDoor(u16 timer) { u16 i = timer % NELEMS(sTilesetAnims_VermilionGym_MotorizedDoor); - AppendTilesetAnimToBuffer(sTilesetAnims_VermilionGym_MotorizedDoor[i], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(368)), 7 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_VermilionGym_MotorizedDoor[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(880)), 7 * TILE_SIZE_4BPP); } static void TilesetAnim_VermilionGym(u16 timer) @@ -315,7 +315,7 @@ static void QueueAnimTiles_CeladonGym_Flowers(u16 timer) { u16 i = timer % NELEMS(sTilesetAnims_CeladonGym_Flowers); - AppendTilesetAnimToBuffer(sTilesetAnims_CeladonGym_Flowers[i], (u16 *)(BG_CHAR_ADDR(1) + TILE_OFFSET_4BPP(227)), 4 * TILE_SIZE_4BPP); + AppendTilesetAnimToBuffer(sTilesetAnims_CeladonGym_Flowers[i], (u16 *)(BG_VRAM + TILE_OFFSET_4BPP(739)), 4 * TILE_SIZE_4BPP); } static void TilesetAnim_CeladonGym(u16 timer) From 6e26b4958985241acb4b67aa1b120f0f72ad4ac4 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Thu, 3 Jun 2021 13:53:16 -0400 Subject: [PATCH 20/21] Correct palettes on tileset anims --- .../anim_celadoncity_fountain_frame0.png | Bin 191 -> 249 bytes .../anim_celadoncity_fountain_frame1.png | Bin 177 -> 235 bytes .../anim_celadoncity_fountain_frame2.png | Bin 209 -> 266 bytes .../anim_celadoncity_fountain_frame3.png | Bin 235 -> 293 bytes .../anim_celadoncity_fountain_frame4.png | Bin 219 -> 276 bytes .../anim_celadongym_flowers_frame0.png | Bin 171 -> 222 bytes .../anim_celadongym_flowers_frame1.png | Bin 171 -> 222 bytes .../anim_celadongym_flowers_frame2.png | Bin 157 -> 212 bytes .../anim_general_flower_frame0.png | Bin 166 -> 219 bytes .../anim_general_flower_frame1.png | Bin 165 -> 221 bytes .../anim_general_flower_frame2.png | Bin 162 -> 219 bytes .../anim_general_flower_frame3.png | Bin 162 -> 218 bytes .../anim_general_flower_frame4.png | Bin 163 -> 219 bytes .../anim_general_sandwatersedge_frame0.png | Bin 407 -> 461 bytes .../anim_general_sandwatersedge_frame1.png | Bin 419 -> 470 bytes .../anim_general_sandwatersedge_frame2.png | Bin 434 -> 485 bytes .../anim_general_sandwatersedge_frame3.png | Bin 460 -> 512 bytes .../anim_general_sandwatersedge_frame4.png | Bin 444 -> 495 bytes .../anim_general_sandwatersedge_frame5.png | Bin 448 -> 501 bytes .../anim_general_sandwatersedge_frame6.png | Bin 445 -> 499 bytes .../anim_general_sandwatersedge_frame7.png | Bin 408 -> 465 bytes ...eral_water_current_landwatersedge_frame0.png | Bin 577 -> 629 bytes ...eral_water_current_landwatersedge_frame1.png | Bin 586 -> 634 bytes ...eral_water_current_landwatersedge_frame2.png | Bin 767 -> 821 bytes ...eral_water_current_landwatersedge_frame3.png | Bin 783 -> 834 bytes ...eral_water_current_landwatersedge_frame4.png | Bin 831 -> 883 bytes ...eral_water_current_landwatersedge_frame5.png | Bin 856 -> 910 bytes ...eral_water_current_landwatersedge_frame6.png | Bin 811 -> 864 bytes ...eral_water_current_landwatersedge_frame7.png | Bin 748 -> 806 bytes .../tileset_anims/anim_mtember_steam_frame0.png | Bin 175 -> 218 bytes .../tileset_anims/anim_mtember_steam_frame1.png | Bin 171 -> 224 bytes .../tileset_anims/anim_mtember_steam_frame2.png | Bin 173 -> 219 bytes .../tileset_anims/anim_mtember_steam_frame3.png | Bin 171 -> 225 bytes .../anim_silphco_fountain_frame0.png | Bin 222 -> 284 bytes .../anim_silphco_fountain_frame1.png | Bin 208 -> 273 bytes .../anim_silphco_fountain_frame2.png | Bin 213 -> 276 bytes .../anim_silphco_fountain_frame3.png | Bin 204 -> 268 bytes .../anim_vermiliongym_motorizeddoor_frame0.png | Bin 138 -> 175 bytes .../anim_vermiliongym_motorizeddoor_frame1.png | Bin 146 -> 186 bytes 39 files changed, 0 insertions(+), 0 deletions(-) diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame0.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame0.png index 8afacc21017f1fbc8a83009b51c95a79c06d01ba..c5783f481655088a1559ce88588a201eab320586 100644 GIT binary patch delta 232 zcmV%t8Gi!+008Ny<^KQx05DKYR7G>mr2qf_-rnYWdxKI^YQ^sVtkwT} zq~2nSz4qpd#k6y*oLYONy_CJ~|ILf$gL4L)P{sfN0E9_IK~xx(mCLaS!!Qtq;RjhL zaGm2hw1Li^z^5X$^$Ks{?%IrCNL*;B$SB~>kiWT)2M7F@)M4tmN$0-G9i1QW749#Q zhdW%vOvEAm6vMCy`j3XF&kf~$U??b)#_&V!8hgV6Ht-6$A)QNV$QT>u6Dc1^8JVVP itY0(DI1)RlN-kfWj9~D2vzBlG00000lxu|8Gir(008?EN)Z460ES6KK~xx(jmxnK!!Qtq;kT0tC*Tp%Ugs@b zoLr~Sc>?>if#z`B9b}kL^T*y|GgR4Ip}$y@)_&B4z~J z=3Lg^u-&v|ef9|VhBY9}n#+OOH9E%#cJLLVBb`ffL@bW!L??<3DI&6{3fI@fBD^p< cW>x0#2i*pq61aiiY5)KL07*qoM6N<$f+GD*qyPW_ diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame1.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame1.png index dbc8030952e6feeeed8e6c8ef6057d255d6dc3b9..7d1f6fb2e8bd978f913a613e72144c0205a90639 100644 GIT binary patch delta 218 zcmV<0044vi0qX&f8Gi!+008Ny<^KQx05DKYR7G>mr2qf_-rnYWdxKI^YQ^sVtkwT} zq~2nSz4qpd#k6y*oLYONy_CJ~|ILf$gL4L)P{sfN0Cq`4K~xx(t;n$rgFp~O(UIJc zrOkjgxDIYf9JB7g8_)&Wq%Hvo5nN6??D=v_mi&`>8sN7iic`5sN3L>5#|o|>-)21t z%B*?{Awy0%ZGvIXs_C(z?Dd%n%B0kHv)8Gir(008?EN)Z460C-76K~xx(t;n$r!axv2(J6=g0?U$1Af3!z zI9NJh9h0!v!MP3NY$X~(f;}HGBJfYmr2qf_-rnYWdxKI^YQ^sVtkwT} zq~2nSz4qpd#k6y*oLYONy_CJ~|ILf$gL4L)P{sfN0F_BZK~xx(t<13v0x=8)P)kgZ z=2!#C-2p>fkx*0Qr=p-BVFO&;7T39D1ez<-okVxL;IIJ_UvifIlVzFcx3I-(!@cUn zJLt2y< zmnzM<9jB2bw?9e#heyNRAO$GWAjMi}mT$%nxOHI0Kz#w@00000NkvXXu0mjfvMzUj delta 192 zcmV;x06+hV0?`4G8Gir(008?EN)Z460GLTcK~xx(t<13v!axiKP|uPMDcu!m7=hMZ zwn$+%AV)z#b^i)#?urZnq_e~tq`3)@z=s%sf-g&c`m#)~Z|FCu#qiXbxz{_*T){mt zZ<^-DOsp%QRVKXvIJQbxD@<#0DFP`vav9mia7sX242KL%4>`lWmr2qf_-rnYWdxKI^YQ^sVtkwT} zq~2nSz4qpd#k6y*oLYONy_CJ~|ILf$gL4L)P{sfN0I*3!K~xx(mCm6K!axiL;6LFB zPV7BM>c(DT;syqJodL-XfhC-Pr@+AC`KXy6_Gi%gyPPj;zNtR<0^37qi?==S!=6!vS!_5(6|1L7`XC2 z@QAKr?>TI6%xtDy;o@w@y^+ey`!Y*NJEvJHn$kI68-i|4u&v)X8TN`~rzS&+S`!{= b%J~CCR$X@mO%D4V00000NkvXXu0mjf6266C delta 218 zcmV<0044vW0_y>g8Gir(008?EN)Z460J2F$K~xx(jn1JC!axiL;Qw7F2uLPi$sPe) z$5Vhff<w46Z{9!D4x<0E#-lZ473E% zLgY>a67gPyAgyQirJ$X2sCic+FSrhT&XHGNjP2>Dn6T!OV^gZV&N587jxlhCqUIPm zoUrX}r@3O4Y$uK2nm)#+cW{TKxhbk9rFb?3y&7Owzp*jw70$lu49;tHn7JYAH#SS5 Ui?2>M5&!@I07*qoM6N<$g2r-S@Bjb+ diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame4.png b/graphics/tileset_anims/anim_celadoncity_fountain_frame4.png index a096093679eb22b39f21f4fc0926d7b208a37cc0..dd9a94d479ee52a226822ffa6d36022d1a58494e 100644 GIT binary patch delta 259 zcmV+e0sQ{k0h9ue8Gi!+008Ny<^KQx05DKYR7G>mr2qf_-rnYWdxKI^YQ^sVtkwT} zq~2nSz4qpd#k6y*oLYONy_CJ~|ILf$gL4L)P{sfN0G~-jK~xx(mC7Lw!axv(;g@iN zip6mUl5tHhQL`unVh4qUH5_0>dy2ZTJwg+xSc8Dna2IB&zs>mD%LUrfh`8puo*ato)q{|OB&9D|R&S)SrWC`bto#C0W zH@t!m{$%hOLC~)AbePcA8E%3+9CN*~pSCUvHyKRsErL4OhP zLrCz9=8>jzhNer18F(Ewkv-K|xvF-BY~gL^*bM7oUxq^3H4T|D-w1 zK}UXMMzI^x?BTs@@OB)lzW?R)YJh3Z6fVMJty85}Sb4q9e E0P$W~y#N3J delta 154 zcmcb|xSDZ-WIY2A{Lk>+1Eh*PT^vI=W+wmOXXOz%C2{0O&Y$}gMjeS_X*R+~e!LOO zGQBK!!oZt%a};aRjJ9Pn#hFWM&HTLeeA$ftow2D=Gi6mNEm~HX6=CFY{nW|Kg$Esu zNv$?b%T!ot+#W7@dk%Z&9Lv<=G}{whrs)kPXTJUa&!{c@A@Z8!fu|tr89ZJ6T-G@y GGywqh3_ace diff --git a/graphics/tileset_anims/anim_celadongym_flowers_frame1.png b/graphics/tileset_anims/anim_celadongym_flowers_frame1.png index 5d1c493e38297f8542b9e0fa3d4ec93a2a4af676..fd9eb53f7327b58045822c2131b75b866b75d07f 100644 GIT binary patch delta 205 zcmZ3@c#m;{WIZzj1H;?9kAi@dL4Z$)>wkv-K|xvF-BY~gL^*bM7oUxq^3H4T|D-w1 zK}U+1Eh*PT^vI=W+wmOXXOz%bz>f*Pu)Duq#8fpZF6`g8F})? z?UXq2V~*IYJ*VW3aPWHTu^aZBy>#ZVL(k;moW52|X36?AKQnG$=FIK0Qm09ArL3{s z^Qs`qDB#r@$<>F=o;UWGru*HT6UlE>c~(+^ck|!>^$ahBzeNf!D%vOja)zg?pUXO@ GgeCy26+C7D diff --git a/graphics/tileset_anims/anim_celadongym_flowers_frame2.png b/graphics/tileset_anims/anim_celadongym_flowers_frame2.png index b28a96814acf20aa221b11a63171091affd4ba52..a3edd7ccd77e7292001da1b4b01e47f32edcc751 100644 GIT binary patch delta 195 zcmbQsc!hC-WIZzj1H;?9kAi@dL4Z$)>wkv-K|xvF-BY~gL^*bM7oUxq^3H4T|D-w1 zK}UzM?87Q^p%qg2Q>p^PPoB`4ZO94pzU3+@BlT-iz002ovP6b4+LSTXgem)rh diff --git a/graphics/tileset_anims/anim_general_flower_frame0.png b/graphics/tileset_anims/anim_general_flower_frame0.png index 49c7ceaaf502d442a50023340d98b82ad862cad5..d445b4045df3d8de2bb7716272ae949c94446a0f 100644 GIT binary patch delta 202 zcmV;*05$)n0owtP8Gi!+008aX;!*$r05DKYR7C&)0KNZ7 z2R74iKCXa^Lnk>5SLncMESi`yd|vY41N@WqY-t;MJ;18DEknaqdJTva4jZ7#8cvJK zzDM-^n9Qj>(V2!LA-zkPBTj&M51)ggnvBSk8fP4_~8$?WgF{$mr(f=6aY=Ozq_2`LA9oja?!G_>T&3lBq z>>^ebJKqefB5rQ4y{h641U^MjET396t5;$<#N!622T3(KXAX0v00000NkvXXu0mjf D3ZOnK diff --git a/graphics/tileset_anims/anim_general_flower_frame1.png b/graphics/tileset_anims/anim_general_flower_frame1.png index c8b469f6b6fea26d9e238766af3ebca8b7abf02b..1aed594f656003ec005ba84d1c1a9bf9279484b7 100644 GIT binary patch delta 204 zcmV;-05kuk0o?(R8Gi!+008aX;!*$r05DKYR7C&)0KNZK~xBtMT80ao*tre?{;#*>UPfvAK{sMDng> z%gLNahDhVl6nQ38LEf&rt0IUBpnDaqw$-*+Th;~!RS;f&4m9$Z?gO&`0000+1Eg|1T^vI=W}2Q=^anKl%c|ATW@}@P&$4CJklk8gqMdcLDf0Teecq+ouoWMMFDjfy%<3HA`hd?lEZ1 zR-(3QW^jLpX0lhf0h}A;s{qJ3StjZO9EjskFizOP1LFiS?~XNQ_W%F@07*qoM6N<$ Ef~j#;^Z)<= delta 145 zcmV;C0B--=0ipqr8Gir(0094JO}qdA0BK1?K~xBtP0g_lz#t3+z!xn=R$v%ILqP*f zknCqgbQD>Nj)EAHNO5)2|H~Nf;fEF;kc|s1eaJg4kUJ;{VWVUzOhlWHC>>Aaq=s&^ zokMh`i(td3)ll)kz^OD8%P%&}<`VP@UB?al8cmbfj7L5I015yANkvXXu0mjfV5KA%BrQ-5#0><9_y+&rgGKE(+W29Ts|Ob6&^8j;I<;RQCp&`srn$#i z#oCP`zHfXX+^e_)fp-xU%P*^D^+=o!@%R8o{7a>bb=K|x015yANkvXXu0mjf$vr*I diff --git a/graphics/tileset_anims/anim_general_flower_frame4.png b/graphics/tileset_anims/anim_general_flower_frame4.png index d4d826f6dbdde1eb4aff059eb97a201925976df5..8e589150a000b42f4ce61f96dfb551b1cf48ddd0 100644 GIT binary patch delta 202 zcmV;*05$)k0owtP8Gi!+008aX;!*$r05DKYR7C&)0KNZr|77XbchD{E5AYfm4JRwsJ zn%Rqv>6^}Yzc3h)tjdUbLjjO;unebG{9$m9D2;}^FLI3~&07*qoM6N<$ Ef-&M$6aWAK delta 146 zcmV;D0B!%<0iyws8Gir(0094JO}qdA0BT7@K~xBtP0cY5fFKM7&>!N)B{)oBabQ7D zfcGN?rw(3_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0a!^yK~yM_eUY(F!!Qtre}hvK)E|dr32!mlRw@0 zexLQj%;Pv7CkDnaXoFc~7&MX@HwpAKY9R@vN1(Vj##le_^%${!47damQ(OXzF@Z-- zXyyWXDnR;4WFWGdfHmlr0Y~{N$JMgP1g!PYvv&EOe{dmn)>i1{`Kn^bq_Frzmb#72 z*L~c$O=&axhJOn>%7S1~SnF(BVOXRu&aNs9zVfvzT_3%nb9U{XS$TlLHGZRR<1c8M zn(`Y>8#pL+JSueu)doUiLQb062b`$4yA#}U{tGg-3(m#`WQ`NhWr1xAO`{kZ&@NG3 zZ}+rM@I-|J@1to_o&6A+KF@Z2>UD>M+~_uOs|j^VkEP8hj%eb zWG-*_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0bxl*K~yM_ZIQoD!cY{(zaWZk zTqcZ*R1*g`F(J;9bY&?sgSlNvDBf2%tq&lDMK>&qVM6*Wkbm$3eFo3Dw?vGdB}`pu~ zu@5gTByql`bbq0s@^wZDz2lryHfOk)6Xg`I7~)AzvrDwT(nXr(byS)Yk8YQ|qTiCIG8UI01Y(yxODnwA8r$q3s?mQ8?#&kv8wYwG_z_xKC66lD2L0S6SWx<}Y2kCP6 zlu)QEfi2(De&xL5dmf${8gh^3PVe9kaiaB5^0D|Xjj|4{*No9Ot{N65oezX*4{z;TvQ1^XpYpVPOCO002ovPDHLkV1o3H-?sn& delta 404 zcmV;F0c-x&1ET|w8Gir(001Ag$0h&(0cuG^K~yM_ZIQ7~0znXl|5vydFo9<|q#`yT zoi=dz0N%|jtQ-mLZ7is{hL!|tLn3w-CUV#qsW>_Xk*qVjN7U#ffA-7%H#>9rkq)&^ zlw!{W`f?>f<|xZJjB);YJVg%WgC&)Oyw%YFrLW^ z3<-aw1auOM33($v0MATexEkliFub*!p#>rb??mm>-~@Z3$S0~{83e5=Q5B)RxLhEN z{0as29Jya>5%i z7xf=_UReY$&wo7;@+`|m$maK%2ot3yBJMhR68(VE>QN*x75#$3`rBo}u5keAa{CnE z<#T}&?=!pL^N9Dky<%9&KAJnT?;kW~t94)CLvrskxZD|Bwgx+w`v9Ng1GwA=*ty&X y*tpzB*tpzBFfMm~$K}qjmE8MoXl#cT^#$^lN#>KHM-77j0000_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0dPq~K~yM_ZIQ7`13?gmM^J;E zdk8UB-V%t75V$~EAqQ#GTwcJiX#+9tE6km(pqn(>ov|@iA%FK4*YCUd?{3f(F5Jzx z|IF;p@{>{zeZ9yODW&FG2bd1^V(g(0iLy+odq{w6tkS+F?O-|pEL?Iv+{2_t+UEd6 zCyl2GK)c2P^|Y7fl%&3DLW2Yv%1NaOk^r~XZ$6wY%fbV5fE(uJhxwu-=DcG5rb}a1 zTjmWFUU-VB$bYLHn@>Ta+O4_ZcWNQ5OTbmhTyef7QRc6PSJyZPmFvwpQ7ob)j_99d z_v;U8DXo?A7EMA*AtDm^VS`I0LL>!A2#_SxyJED4u39{Yd455P7Z12RKrC8-T4FE*z&ys7M^9_xmYYWb%;6JH=X&O&^W9PK z9T0pcItjkds1bYz1mExWFzHew`0l{_-X#jYlY>QoV<(L$(CA=>AAY0H7o?eXSO5S3 M07*qoM6N<$f*QHu#sB~S delta 419 zcmV;U0bKs&1F{2<8Gir(001Ag$0h&(0eMM8K~yM_P0_(l!Y~*I@b6i6-&;U9i5GD< zy+AebDtxa{=Mt_o_yTa@N&<;j5|)s7k%Y9KL=v-lGop#}-*yq2Z2j%ucJ20&Quhm) zjuk1TGARQFQ<;uD7Kms(R_Xx}FdnJdLXvbC%z@MmX44A8C4Wgj225Qv8sva<3+J?y zKFTPc`B_7n=g2Uf)GWs!P@=Ui%M$qPBwY{YfM@2;xj3a?=3b5Ygx-W`H<+8$^}(&7 zZm(8nac0TZ>Mic_1#Qu_65usqu5qtHHtAgnZol9?nAvK6P-$$Do1*l)yLLcSwF6?U zqe$x~GS+HsZGS-)H#}fdjjqs^Gy+7L@S!tzQ54%v6q|R7jDy_(#SRba3dQaib{*hW z88;bA!>ZWcg!BAE+iMSO9$@Sih&2u-0Gvk%aTi5q>&~M9ar~wGO!gi2uI_yx)Ex+Q zFX=nfy-#1E?m(#fV};?0zCzs{eBD=6hPsyyX~2(*CLC^4Xma$Q{{YwMZn}G%h8X|= N002ovPDHLkV1n3M!_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0gFjQK~yM_ZIZoC+&~nC4~hax z#|#uW62&-0EOoE_5qP%a8`TWq(seX%PDqet>zGoa@?FY(@Uy zB!pkDA~#5mdw+-9V*4iHw}IKdZRAd#k@4EB71knKSqR*E@et(U5PLQ^=JU-V;EXMu z#eYuR9Sp|AIG9ry78x4QT1NxgJSQV$OY4edi7XT$EJKE=_fvfk%~2n1-m}k_<7gbg z<*UKi6(J*JU!g`{m~2;ra|*5>OwmJ2qsfj5wjcLlPHF;fv5Jw4SvKT`2F?~0!vkI7u n3HC|4>nIiZN{2CP_HKuNHgCgS-;R_X00000NkvXXu0mjfKKSv5 delta 445 zcmV;u0Yd(O1k3}F8Gir(001Ag$0h&(0h38YK~yM_O_9B7+&~nC&$G+}=qc8u39ho) zE@|TNg4izJTgCNcWk@UGBDK|QE7(9lps2X*lo?;sUD~iS?sDCaR2Q972{Q>BLOR;Nc zTc+=!Jvg(4j;!nQ3)*IK6&QKuZ^x1F`($x8fye}ZZbVLA+n4wzvYv??@BYfx@h9kHF!S}Fs z_mQ4E-KR2HXrF)SgWGHs9#!`(A?dC#=|18y>AuBN(l(utbWcE$KM^L~4^Ulv#h7$w npQJnCK}G(oLz%UG_MiU&AS-%wRCwfC00000NkvXXu0mjf^{CPB diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame4.png b/graphics/tileset_anims/anim_general_sandwatersedge_frame4.png index 1d3ec938e0516190b2a0b0cfcd3bb4389a941484..5b74a16fa4282a3765e738a98ec04290a914eb23 100644 GIT binary patch delta 480 zcmV<60U!Rn1MdTn8Gi!+000dDXvhEn05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0eVS9K~yM_ZIQoD0znYQKMFK< z-r1m5w^v!17?;FcEy=YuM@>QY9zbwwtp+S1ITjo35F71`Jb#7P@4Gm&2hqYwHuK9j zJAaZ7c3c#Nx$Ppi4E<6=3-yhK?McxXnBfk}rUqm3ATd}gjo?-*5~Nim0W;$Nkk)c! z#{tYR7vNgiwHOPPns>=^bDcwC{T$N4ay1P=6rj~1TE4n>L`0Jf(FZ!tJ$(}0qY)kx zJe+O5$h}2~Hh*7hn$io7IjvU=rz@fjO$fjqZPZ|D1 zyC`lX?~AtshQ@b>;THB9-v`)hd>05N-=N+2E)b*u;yaIQd`AHGT~>+j7iehk=Y}7< W(95zAzJ3A#0000lFgN4!! z7H}ick@hA!o5BOc>d?7ax>hQ4gj82Z3`}t*pbH5bq6~yPr-)jL{OQh@b8;}FG)?W@ z5_7|tCJs(CwFYJ(No!%pe@L1fteuAt!x$+9ml_E{N+l$)w|{&dQkvYFQGgxK1)NKk z1|w18xR*4y_jA;|+Glmm_`K-!1Be2C)_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0f0$FK~yM_ZIQ7~0znXle-nk+ zc~lx3SsJM{9toi{k%T8WY6`N~l5n`MFkmSO9yHn^HezMqS%2={z$3W_aGl*f6HNS* zyZN#+v->AMf}ks-h8iJY3Vo$8VhZn?3d$Tseg{gKUerKSjd(na5HSQ&O7u<7K&Wg_ zLMnFz*;jT7{6NRt#o!3s4*5+Ba@aAzyHbDZ;3u| z8pn%IqBSP=;D4ct$#}b=_|1d2-K=OrFF50}S~8q3iMBNUgtr_&#k9EKdw6oSJ^`v; z#jjTIkCH6=O0z6MruFwu>kPUOav`)9;tImQ5u)Y`#7>XD5TmVB+k8lMZJO%(6lq?c z?hNem)@+y8X9cwWK)nDSGz&1RZk>M#%eE4B2hD>CyI+GA3~Z78#IscA){jcH@EKAH+ZVyE6vwJOBUy07*qoM6N<$f`l37UH||9 delta 433 zcmV;i0Z#t)1Hc228Gir(001Ag$0h&(0f$LMK~yM_Rgu9?!axv)e;~mv?#%A|?Thw-^kuzn5Qs^>eHxmUVTWK+ZQc_FrFi~A@&r+lexz-w2QhyW3l&xuK<+h-&lj=<%NXIjv`kpS0v6P2UnXq=QK!^dgVwm{_Ik?8a&KEM}Ir%JSsw>WO@5!KPQ z8y9o5JJlM+hf6H0wFb567_Xcf5yMMFRHe=ymQm*{rsgx>!<~)#JIeWTQOp;moi6bU zq3`boz8}H|c7Hrb`iY7$fH4m+#l104g+c7%{0CxOD|Iak0iId`W-SDjS<4gfD&xef z%#tmP|G{hv+$aYiN8NFLgdDaMvO3l=PC_foFnE%SI0;yu$WQ^lG9;I*!0OQ!{(R|X zm`w#X;`@}r`Oe^cFR^mI_wng`A228fE9d(FYv((I^D2FS(z(s|INur8;(K3)u66JB b&wu^~l1xGt{mrr8Gi!+000dDXvhEn05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0e(qDK~yM_eUiUU0znYQzu^B4 zI*pAi6|pfw!UI4;YjandNS2laabID;mIPND?GPGch2FE=y?=ps2@l{pvx||+NhbTt z%+1c1{SI39nr0M5hy@Ho6!#llE+LBIc9%;6L+*_PdX0`TFj1`AjV8k=*1FRWh_u$X zE${$?9-`}ex{p>U^>HKDGD3G+yeW#I`)%3DpohK*iN&)&jvnU|4@3bDi5_3=8%jju zgyR)3iI!hIE!aq>xaSwSWFT+oDGaKgu8&Tu*>N@%=d7(XQRbcX7OUD`!b zM(OxL(fK>CD5)|kW&B0D38Z=cmF0Pg+_~?^99n&VBJ+DERI{d&D+#SIudpHs?QJlzzH4Yn-~mX$*cdBM8zUWbihsyDvx|Q!CpXz&W_NbJ+YiPJ zX1bf_$OJS)o~82nDBZd%W)qAL9E^hJI>2w7>8C Y1!&tg*k5_k%>V!Z07*qoM6N<$f_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0bEH$K~yM_eUUv*!$1&)2Z=!F zk`9q$Y$TTyL`s{+u2V$oHWCioQm&l~;G}`hI1O|rdlu&iPJiJ8Ec12^xMHNyewsf& z>ydn%t1yft$#|+ZVaULx9|+K+NG7gFVH69c0Ac(PaET#G1YZEeJf&#E$KoUagi^{x zk#ewNKu^YVQoaOmQ!7fK0x}Tgt9x#CMdm_RK;{bDPs&nr z)cIjVcjj2?On<-81wUoMur0JUI<06@q%TJAD;j_02UD664JXFvgL%f~F^zBOFX}FO z&@?rY8fzOQ*)FIR!dfBjNpwLorDjN~Pj-rAXgfH!0rFpPTkW*J&fsMH0)_#N1)QKq zFf^7}i>gm&%X)$*UTC35GKk(E(xuug@Ls`pkoO(nd^;x^c;6Q^@V*0_?+)Pm8UWt` s&i6Hu_nq%}-x;n^TH<3owd`s525F!VZ7X9)B>(^b07*qoM6N<$g72!%Jpcdz delta 393 zcmV;40e1e;1DFGl8Gir(001Ag$0h&(0bfZ(K~yM_ebK#c!Y~jA@Oyv^LtH3?lreQ#Hj07V6(-k|7h)i@;hx^a zAd$JeqaR+9lrc%A6takEn-&j3j$+zfWkZpOJ#||lc%zrDV4_Yg=MpD$L4U!QY(FJhwcl#G1imo$CBx4haC5hG@N-|%!OtCVb9cbpX8`67xVg{B`nmHv ne(sDn?M9GH!+d0000_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0su)wK~y-6t&}})(@+$KUxuKt z)f=Ll|AHeivQ%Pav9osZ?UFU|(t+_N{R6mNU<;0fU<5(7buX8L*7s@40puBA*MdGcKcq?hLC$UJfC+!?m+?tcvN!l70bp}rH z(LG+AFBeXxiX>?d5G*Ru8tH(aa7!azD!M zjCQ^d&y_m%&({2(>}1f&F$T$=#3IRG0{^#J;#LN1u78-dce_oTOvf_@S(0W9rb>+& zB$G|bKoKbh6QT_Rx;`Zalx4*9c1|bTDOoJrG|evt?Z-5PE20|)p-(3_VR*&ho~UBF z5=C7X48kA?83aBE>|Mv$JFiV|A}32NsV+VDls{O+6lA6w;0XW#002ovPDHLkV1mYR BE9?LO delta 563 zcmV-30?hsO1i=K58Gir(008Y)QIh}w0tiV&K~y-6t&}lu(?A%8U%}d;uEf>>`xhWx zhi2}TY#^kVY_PQE4>Y-vp^K9>OV3Nz*b6IC7e=J`FL*0rbGJs#z;WOC{MjNELL#s9 z$WQL>yYC!J2klbi(B4|fkbCQ-XeG;cq+rQ+q?v;*8go)O$$uK7rp{n&;*Z8ydAJ-; zoG8`EMybp9$y?ZgsZ?r+O_E#;NhWUK>J27Sd9IStJ$}gZSWVOi{IZXDY~^aKlvL9p z?#9zkQe6yDzfMLnmiO4)NvTHiGwocP`loTnpdj*jN`fG=93k+*L0JN2`OVSxSR9fQR#b`p9Cf|4YlvwV%B@X$WjGdplV=h3#Z>|W5A zN3EA6kMwPpR+=x_lWikQZ1Wu{Sn@x_G+*106pd`js0G;<)BB%q=BpWjG|y53bFEhd z^2Hz{poP!`7D5aNh|_C9K%}W4_O?$a?G!KOa^8?zaDP)i#=iEsnQKAVsf8fyVsT2q z52T&&6ffrTeeEOkYDPc|vXsEJ{YfD8L!IyxFYe0sv`-fyTAK7kNSu3Gd9kxI3S@cmMp4{05^?<>~T^#l`>t002ovPDHLkV1mil B6!QQ8 diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png index a765897d9c3b5efd05ea9baf885203f8ba49488d..7e41494c53680323ad26350b919ed21a00a67570 100644 GIT binary patch delta 620 zcmV-y0+ap91o{M!8Gi!+0095v{(S%d05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0tHD#K~y-6t&}lu(?A%8UquRn zE!QcCguy1{_h`vbbzS-beUbWOZ;VY`GMK;15|1y@2SQ-A1nPKSOHzraCVkuZM% zF!$M)JEOpaU+K|3@!fa#Ikt=>vQbJwsm83>M6nYUZ6w)=p%yyu@1)d1(x; z3k6R8wjLgw&u6u0-N=2d&);Vs(bIZrv|eDCWfx1WmzdQTUhiTyHCH;j6cFYr*E9VN z5ABf8tvs4*ZGZH1X=Qq5^u=TBe#$Ph+zikgo=LsGut)Ud0AhfU!sTyLmIZ@Sh?0Sj zQZSHv&m@C`G(BK!)!h@OCF`B149g4V4{=l5RkhS@Y=otIk7aH9dH%+ZcebCG z6DvF1kFu4rb%*Fj(IJob_(8I{N9rVLW^4}sEk{B68-H=H0$S2{GqoMHn;0uKVi2FK z5(bJ$F*qSwF`%1MVnAt1435X634=6FQl_(gy!a`<*q8ea{Sp39-$qyaj1?U-c8XHQ zF1{Hva2Mhre#$TQ>IOSLL0)RB|~lVNl0K1j+=E8Gir(008Y)QIh}w0uf0>K~y-6t&~4+(?A%9f4~>ONURm{CqTLm z&D<-QB7{_v4VKpJ2OznPrHhlbOV3N!*h@Y@cfD{7_4ysv#e2N|aN zr#$u(-@n&B>5%3Wtu?f+jD(VBPIO*NT8qwFk|T4S8p*w6Eq}?qR0datMnQ?*7X``f z;b>fnQkDEx>hNv+8f&E{QmG-9aeOdPYJhS1;KMb>6S=42eG4o1A~ja;@QZHIh~(!; zDXAs{lF5-&2S0HAD&CJHxx#vRWYp!5mROrrVOK?21_zQwH-B`b!{nj~ek!zOx_R)jaJ8`Z08^(ufp7 zGLSA06(gl#U|bs6HfEQ>Qz0HPs7{SAKokTKgUAKXqv#ETzy-bPka^Y|JCDQg1%sEs z6Q+67T{R)L8C*&^WSTOp%Z4l!<)eji=}i30ey#Rr**Je5B7Xo?Jq0sIud==X0000< KMNUMnLSTaasSOzb diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png index 5673e4cdff9ad20d9a162a792735be92e83023a1..5765ac4773d5c2a3fc354460c28ab7d2ba861e7a 100644 GIT binary patch delta 809 zcmV+^1J?Zi1+@l{8Gi!+0095v{(S%d05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0>DW`K~y-6t(38D)Ibo1hk{6S z>%ka?(x5&|;<`bh+Q zFG~mvRssggEQW+BM*))|lmTMkYCibOqqD`_gS7!(SbO%V{t6GQoh_~X22bny{LvKoz^dDkCG(bZdjuDSp(5=;Bw~n4b7crDzBBl~1MG#qp9IJ}_;wSR5q#eneBWOKguVkn=sUq4_x%(Co$Q9loim2S zuqsI4aOzw;bp+^Gke6x20!%Z+gkPK7q!coRB(JihSkX)CropFhC_XJ2i4RT(AM`%t zfhqdekAHm-D)R6?=>TYC3#??*F@`H87~A_TidMp#R$?TD1S<`SPm+&5=wq-4mZJ|r z5e|X!Y>y=`4T%5~dbWgC(Lh@okb#2o4A9E0qLs;}#jxBsfnxM&u^N2ne0VwiU^)7r z876ZciIG;$upmdb%8(zKj@hJi2&*y-ZGngVt$%EooZ>VrPb&dBT=DVu*oTHH?~}>- z1RorIkeVVfHd3&0Zo>j6wFAqgW5Ib{e`mo`>VIK$9{2jO+5BcfNV9Qp?c5CuwA2=E zw7zD+opZM==%t|P`-TOL6#QzMFRbmH5pMgw>-zp~`?31dbw63)KUF0DSos30lx5N9 nH6qmgL2%yLYutT&(*1K~y-6t(38D)Ibo1NALuWL{HqGgtRGq zbsSO=goL>cn#3T{a<>m~&Dafv8?T$R_BA{}UV(~+NYR>#5DDGVAteQ7W_P_li4GX) zKYusg{b#&m8QP8F*g(74IM|ey8c+mG1eEU>YF;ryW1%4G2!B)nw2KJ%UeggMEIcSI zn+wjlVrkTR94V=#-=>s+3GAscCghsCWw7Z zFw;7Ywf+RXF@IVcvjsyx^oNRSx@@%pO$kbAxInyMK|C{8@vQ$2anE3`2(~x$=hDOW zW*5w*1K!p1V%q9<&CFZZPXKM+SfJt#dUH)M)6`f_K>g%-Uc_;K&HX5XeD_K3lsad) z<7uB0xVbafxesvb=6>#=v0%qdpaR&rGuXL*fWgguV1MAb6WsFL-*eGhUvzAv7D6c! z!@MGaz_k#`S`eUML0z^53$SevJAQ3y)l!o!bal~m)tp{hv35R{K<|@~k@vy%=!4dW zJg`Ok`mql}K_1qp9RZaufrT#`+7P90jO}fSD)G&$#JAB^zOhoF_vz~3gSHL!z%uv{ zRPGR{pMU9C>Qa#iu%l<|Xcr}tQh`rY)XxZszf~oEu}aWwSHeRTd=e~1A37i2PCr-% zA5`OF?#H*$7DBP0Mlo-YADNC>wR8yc(xoQgw7u1gi(6c~?QP+K4%hqGd+bB0!umA+ ze4GykAEcr9Hl`3_l#3lmQ^A7MJb%oB)W^R;M1& diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png index 89276ad9f5f1552b121c26198de2f5b907c925a4..dbc111a7f824b52cea4cafd863cede53469dc2ef 100644 GIT binary patch delta 822 zcmV-61Ihf42EqoA8Gi!+0095v{(S%d05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0?kQ8K~y-6t(3iP)Ibo&2O%QS zWt|i;5`|5Hu0(l-NVGKewQ0QDxS+AOaTBUd=%SM@4h?jNk$;d74T`Dlf^F^roCiRP zUm?uwhaD*q4U9DFpZDWGfA2^J!7;KV1qTTvB@sa}L1NY*StdjrxZp`@q2!4HUh>R> zP<=fLm~!vSy%A{+q6I7Ws#JP)G9`5}b$qOQ;D5RRlgqJ)9%t%e|8 zq0Wo_fkg;Wyxy{4jSwP)FM$Sn!Og*X8$|@sYReWYpnszS3-=L%mGOgnETD_^Frcvj z1<@gcC|JD4Wd>*gA&Q}{k4l``BR_oD28VY)afkC`_vHKyg6%tj={vv^+xKJGv3(~n zeMhi;Cop{{Fnvc!+jju4eRn0q+q*@5^nIl@CiGHjjR~SymXsjNOv*HqP!xQL-joB+PZt5a*;*x+GhX#?9Idg_~VBY0qwGk@5-=<%t5jK*A{!Z#twPgqhi0+mQ}Y zz(}+A^ZxnfyB%pkDvYwOz(EalMnsTLP@6TVH#Lz0B~@Kn$bVFAKxL}5Ae5>M;F<*` zvf6?Yd1XOK;h?MqWTTA%BYras2;UEvrv^AT@bjAU!&k{O_{8~H#QAf$PLj7zIX?$G zani!OZFInsml||*5c5<18an)mmjp}BBYwuAU7j5!{OAsT^^Mlw&hKDob$`|NgQ-q2 zgYN~BUb$5f%uZPd>@VVD2NU< zwEgxYE^9yw2yFvNa+%@GE%{OYqQ83hPw$nwAh@R&1^hAgAk*ROs!5;2&+Sfa?+s^=I>Y?^fMlpn~W(;2ui`ilJ;bq6sJ-I zI|VEsLAs?-y3J}lK0!F?s8I($Q*%6Y_hXi%NPEZ4_->5HcLV1bC5|>`h!~3~A#yQ8 z;^GfWyD$mvhUa32eb4iK&)b`yl)qS=95ycCann4ZggwUgDQD%_^I}SfUBII_enC0! znRK)Z(D60; AF8}}l diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.png index 6ea08c88a980fe00d610bb0649acce4792159c06..a8ee69c1e87afc12e695b18e21378b071d5e11e5 100644 GIT binary patch delta 871 zcmV-t1DO232J;4x8Gi!+0095v{(S%d05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0{%%vK~y-6t(38E(?Ar)Uxy;G z)nO?x#hDno)JQ0Mq^u0YUK!%clA%NFTfCI%TE-P~9<#hdv24yUUK$ z`~{%!-rdE?(1D>(`s$zF-M#nqUThGe(@lCpfDmFJWoSUeGIh|C7DO*fpjSiBtTC9J zq&>aRKuSc=XNV1S>2J6N0y=IJ^eGjG+`ZFH4RGWi&ExUK^wfY-26pz9y7;WWfv40- zq11QS*ZRW`rGJjWCf+yU-HYN<=`S95#bvHe)hBpLk9fN>CL9RzI{x9OqBZP1!> zZLOgrWrqcemOiUm= zPpXQHk%>ulLw+>F6Y5SN9ZXUK9VGGQrx3*dQdfUVx>2zfhr69vtN*PN?goqNEMi36?aX6GQ2t*;U zOks#PAAd4nnIS0yloCmj>O?6?+B#u8vUP-b16@;RPQOD_2kCd1aUGn)tZV8ZV26lm zQ9&XDWmZZ_OQxyJ=FSGa7uHyrxE6!D>6VS!SZ1xxAT#E1wzkn<8;kk9V5<>~y6Zah zUT`gUKLV-6ko*jhnqryAtRx#qNorxCly*s!?0?6kGCD4hBsbueW^Ob4F$o;4L6RS{ zRFWT?Vm}#|0HilI6J!kMZeAIRDC2oaP9e?90^N^ULb@N5AkpzCC2c`wmquGY%}9F_UA&x=Aw!m&Gjw&rz#1uggoL|vV2U#VU5L9OwL{H&cV{OO z3<&Y0FaGJ>`ModqY=hSGS#PQ}Xst&|O$_K*MGmIQf}SQln15CR`C8ya45yg9P;3>B~RsR_)eEro8W6(%0Qk;ShdfNg*?82`*oJ*-_CEK zSmo<Tz2cIxTk6Tzax+5o3{8F(Y#0DLQ#fIY550qYX7h3I%5 z86y)NZ;$*4h9A_OKso3{2FQ!{mIPb>^me2M47WV@0e^v=y9F9|0e2P#aA)VvVCFu6 zTRV3KGtvu&*g#>&U2K8bbYYt6_~Z6Dk9zZ&>Ln4VNvxEL74)=DdMZj_GHk??p^8Bx zYK?vbL&V0A0sRn3A)r!7QdB32NXpik#C=;w>klw9bsF>>nmS0&VaRo`0nM4IgMf1) zszn8f41f5cuM{nrrYdYW8}wdSV}8%I7*$QTY*fZVYqbfXF^|pC#<(;V^LxQo6X?&% zI`m#}Eq6W|sl|}|43V0m-&3JaHjt9k!h)~tlJ?n;NriN~Mv~fqTWY$^?8hXqUxFe( zX2~Z%HpPBIE&)hyY^cc?Hr%{I)Je$mQk+7XmwyF1AG3sXJ|;n;+mnd21)*K)yUjc= zyL(&$olj_%5}H?8ht7vfz$Oq&+1P?0Ko$fp{tAQ(2!se&f7nyCsG{Wp9<^F8SWt7Z zf!$io^J=vn@La$H&wI>*CjbvwQ2rS>K-_0R=3)c;S$4pJ9mHMMrbVk(Yq99_m1iu- xT`cfdG-uJr)5d>;s&dt<>Rx&N{Y(2#@CyWGGNVKlBKH6Q002ovPDHLkV1nCQf^q-= diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png index 473f41e6dec717b757061407338e71173f970e7d..318c7b79650da6e7876b2d6264f50450a23cec25 100644 GIT binary patch delta 898 zcmV-|1AYA1295`i8Gi!+0095v{(S%d05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0~tv~K~y-6tyD2@(?Aq{3>2}E zPDL!#U5FTvNS1C4k#4P2#aSygzAV{l`<5(hmoQQ(xLsfiMt`bkr>gFj$QgPPzrbNf zsv~8F9`D^J1Szu>|c}okc$9 zfXyLmTEN4oX+euMo6sa80|P!2ni&H{`q4ZdAB_eE zNNK?fDUUuUUw`3&l>JP~GuTLy<8vubVPFdHHet}uE@bkh0+s9{l>_++p5h}NA$T^D zGL!vtsEqm_5_$X_d9X7*eFCsqS+8xb!#|=Z%j;QL7Eo$^GuOHV?E)5_r?uz30_^oW`EY6ylgDlmGu0e508@b~EXhr6g_M`GZDCbwJ=lr6Q z{l9_dfaMUCano$}L)XoI43Ak9@sMBG%v&M)6;SB_{jz}N_UM3F9x=iFI2mH~RW5{oK=VAq}Jnxbc=1SdALP?)3CZuJVQbOtiex&IMC6q2; zW?IW@C|tm=qWDe;-?aWox%#D-N?lRH%Pc#iT*;`oxC1sM#@h-=7xxC1%*$DSujQWN YH?;WRl7~M=^8f$<07*qoM6N<$g5Dvn{Qv*} delta 844 zcmV-S1GD^&2iOLX8Gir(008Y)QIh}w10P95K~y-6t(3oS(@+q{uP{f7E3p&*1xT+$ ztYoXJPAx*hWP_zOk;+K&HkK^UcDF2fPNl4IREhOT8Q8icNDL?}by*Od8a6~22zT$C zq^KKk%Eh0&AK&-&onz2ir^>C5&$%p2{O zp*;GGI=C`8{C@_^tNG3J>Sk$Ar`Uk&INKG+alrxDDg#|sQOa|GJpTas^nIRRPICx3 zUacU+VyZDERN(TY0<#mSlx8Pof^zAiSuV|*1zh|AvjT7-Z2;QJ+wsfAuv0F&LmwAS z*V@Vv%5)go5tm>VNwHf%}fYeP6c#ds?0RX|tLGSW%B6i`F!T1NwFc-?x(1A!W%Zmf&} zjOeir0ZnBIPT}HM*HjEFjN2JZ##42}I_PI@Lw`Xe^e_@sAK|4+6#W`@ihj`$zc+9m za5zC{+Ag;Bq3yOlR>u~Kbf{mrSPv8IS4u;t*e?d-@zkkd9aY2n6gCvx4S^p@{N~tz zFN9ACei8o)x$ozc_&VU&z)qg;QbJjXElP0cZ;J_m;{=ot6af!{;0Yx-ML@+ab+*AR z0!8k*?n6p=1aO~nbEmsP>`=l--#?(-*q9e_3$7)`n>olL{u`{7*Js@=%iTBaU%_uj W92vV5VjeO80000_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0_#acK~y-6t(38D+dvG4i2x1S zE!t9aX_P7G)@M-cB}0cuS~FPm;?dSEet@&P8c38Z?UpJ)QGaAgqKt+;gg~D_?p`1= zkh!f&-koJnT^a&E^x=5-lRm-+h!G;T5D-I#Kp^3zP77KFFo2+yNRCt8ei#|Rq`!jj z&;o|Xp@TRK4J6?p48fc=AV*T!BTF5DWCdtyB1q()%;(kl<=BAM7G7$7{w4bcTUw6_ zt*>D>%PwxTzJGzSS@^gI<56*^vnvn0;x5-?{TW{KC%hvE}c8w*%`aT|ik?kBh1*p{naY%etdlgr zWqi6UBSReLK$JQqvbevDrX(bkV3?_v^Y&S=pHni<=?x*bxY0ki9 zq^Od@rj1nE5T95Y6CWk58lRMlHf=PGnO3LPXV#lKADr^FAaw^w?E$A$#P<{NW?q>0 zTYNu}EJ{BHdeRR{S~e?LGRISvfv$iocO_+f_sRY{S^f}#=lh-rJQtunPmB0@wefsloi}PV e)tjIEOz{`ZvI4(+@$8iV0000Qx delta 799 zcmV+)1K|AN2CD{;8Gir(008Y)QIh}w0`f^jK~y-6t(37&8$l3;CrORuLrNdt6GYk+ zwp?;Rg`!AY=#mBwB)75m0ciH@(v9a_(B2(I3L2YxhIA1XN17;frb}cbbeWmmJG)9l zM*ihbJG=jkcjN`c3=tOyh&e&QkkHa>0Sf^vpjafFqttYqXMX~ijBCiREnt3`J4o|f zAjwC04suq2kHox(mu3t}4Jb7cDvI!PRT2C?IT{FPZQ+mBCm*Bt@TB!H(E0%Gqv&{F z>wOr=!k0T341--A9WG%R?1p-vKfy2h3XceW9%&uu;Xc9eG|{4X58y=$_^XbRJ}mfFmbWa3TtHz=!2-W^+h-A! z{Wg?+Xv5YS>)%lJ`M~CJ0`8|>LyI>0)EzZK(3XB~&it126B)m?6;VHDvERCpeo&zK zfmQX0c)_sZabFPFxf9sASFo~kzkrpUy8zFfLFR6O=6^20bN@;{GI#Q^b0>J@adU}k z<%-sApi+qH3SpvDccO|esLr`ko$(c18KV^6VR4gM7`$10gX2VNzJSGWD8F+chDe<9O1ZC>u4RESweX>c<`CyOQNMnU*OpPT* zbrVDL!t|V$XkH7qMDr3*lroCbyxDM8jvJEmQGeEF$|>>TdGXQi$ZUY5F0D^D89N`U ziR(WjC{@eG1_Xg(!EqGru^@2qTxgt|T5kbfv7qh-c9eR@qPN1v8s3%V4hy!GYO}y| z0ioxGEC^k|>oEMlTJLFq-zR>j*00t}-+#k`Wmzs+uyg@>xzsGsF8&`_=Z#uT_2wsU dycj>vfxj+d_m0fef7<{6002ovPDHLkV1jaogI53m diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.png b/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.png index fd450cf5d5a1ac1ed90f9bf25c380ecf52443084..e01c91449033f32f05a5ece78e047b674a9aa7aa 100644 GIT binary patch delta 794 zcmV+#1Lgee1*Qg&8Gi!+0095v{(S%d05DKYR7L*)0Ot1pz25(er2lH9=1P>_N_*Z? zoaW8m?ySAddwYXgT5~aT#qQ>d=GBYU#cDgyyO00?0SSp*R{@H4bAO|*vWMO)*bh)3%HRi3 z?~W8@AVrq;fU`c_k^lV?Wq~#n$`~*i!MFom5Tw2bMoYI;u{xcm2)c?EEcybhPf23 zzr%c1-MhuzF@L2tNPlZXEnb}ILI)d4^@3KcsvJ-S^SH@JVuN&QF~&L>b~-#X+K4)ARkPLj5ah8~ zzMXMykj7GrZj=%>RM_MNf-k5J#1FSjO@0c$n6_su!Js`*dDQ8UaJPMO0Nkp%6^Duq zlBXwMASbM~#r2r2(qW*sQ$Q)vd3j(z+@gmDRDYEse?UgEoqp=5lj)#CJ+HIj?LAPr z=9UQOqC++;ZIA!K2-vpB2^gY>3bEpZDnt*95PxYsg(&!RdK03Do&Rn;^k0%^tVV~Y zA>h~P=}%60K-_Wm%4O4(oKS{<-(~rgvtJW+h9T%P=O{i5!G-u&h=Toy4&w9(|0(_e Y_Y+eY&==gQV*mgE07*qoM6N<$g2PUJPXGV_ delta 735 zcmV<50wDdS2J8ip8Gir(008Y)QIh}w0<%d(K~y-6rIayl+dvRS=Kv~9137?ng-s!` z4IOm}0+>;kG`4a9OWP%dnk5?-YP4)zs9Cbf0oh6R9J+wmTU>wv`}P#%J;|?QZi%&Y(duL4BV=+7Jpm|QX*@ss%pVi0$79^ z@j^5!61mJ)RC%z}Akwc*19&){Ed;do@Tm3a=lMrMVVP(>rN{aFWXiCR!r2E}ER!QW zKfb5m$x*5o`V0NVC7l7zW?CnDIi=g#@>`-$rnGxMKTgu*o*r+LL?0(VSb5j%?i#Vd zL8B0R5Je+SihqbAPU>P%*F<&w3+aO{jk)Bc(U7h=0fPVsgDcJ#L3RzU_qPMYMhCo@ zAtHt$`>6qPt<7k7z}Kq`8wTvh0_y$-o94;d3x+2i?K!~D9pLBQ&>uhd3wrW%2l%-Q zxE8ns@N>VQ#?Ku(e(wH=s`?oYJ#Y4&vl_3Iaw|p37=Oh{o7`oa++<|R!kE$-!r3^V z-^2B!D3N#%SJojjNibvY>)%&T#}6&uir#Te_9s@35`I~$!2TP@gX_YmZ<7`~lNZWWG2 z3pa|SF@FlpkFB%&qQFu>pBJ`Al)r zq%dl-VXGL1D$I(MlrS$3?1x);XoRX1`2(_*?f8j1ow5iz=y{znZ|?!+m|G&8iwTGAN<+|_H2uWcujzDlA!v7}5#M*DL%bF`!TyLAy3;$5KRw6m;2+4gz@4-o R`Un63002ovPDHLkV1kRPTH62s diff --git a/graphics/tileset_anims/anim_mtember_steam_frame0.png b/graphics/tileset_anims/anim_mtember_steam_frame0.png index c63dbf1c427505f86fea40e03761e7b4551323ff..ab0ca2c698a84734162ef7ff710cb36ee13bd8fd 100644 GIT binary patch delta 201 zcmV;)05<=x0onnO8Gi!+008Ny<^KQx05DKYR7Fa2ti{E&tgM`rlzV%7YNV{J|K>q^ zduspx|4Knh?(XKjy|m`$&CSiUw6vt8q?FAv^2GoE0A)!;K~xx(jgP?%z%U2{8Nlqn z4g*lh1C(8gViM(9K8eg3gV|jG^ogz!YI;wp7bFEc79p}NNkVzD(O61Vis74bA>kB$ z#@PRg9fph@CjaA9ym4=gL#G(;>|y4;C(k;_QP!Ow*3me>^mYm(00000NkvXXu0mjf DlwV(9 delta 158 zcmcb`xSnx>WIY2A{1);O1X5+5E{-7*Q(OBF@;V!GI2&`zGQ2cy_#V&B@4)z6zDle8 zM3G!s(W`Sao0qUu_3=y&?hg!qr)R;g))>ov$gt_6#x+B3!+)H)hBLG;Sk69EbNlsv zhHZ-u90>7=T=#j&Z>y(eiB3L>M^eh;-TeQ0eiKcJS^i%<@+<4&gU6g@zi^3woZ{)~ K=d#Wzp$PyNYCfz0 diff --git a/graphics/tileset_anims/anim_mtember_steam_frame1.png b/graphics/tileset_anims/anim_mtember_steam_frame1.png index 8236d28b2bf6bf850a4c16dbdb0e972d9c38f952..1324c7ad5cabbb758b12dade47d76fa38d39f389 100644 GIT binary patch delta 207 zcmV;=05Jcn0pJ0U8Gi!+008Ny<^KQx05DKYR7Fa2ti{E&tgM`rlzV%7YNV{J|K>q^ zduspx|4Knh?(XKjy|m`$&CSiUw6vt8q?FAv^2GoE0BcD^K~xx(ZH~bWz%UE~JpkT+ z9S?vd21s^k8aqT2nJOo1Y>}#+#sQ;v(q~!Hd;ApN&3^cvnF~8(HA(>hWM%*W002ov JPDHLkV1oCdVUhp< delta 154 zcmV;L0A>H+0jmL!8Gir(008?EN)Z460CGu0K~xx(ZI8hXz%U2{J4-qM5+1<&uY(7m z3FOg6<#n>);#`?2Df5~D@-84k1qx$9%^Nspf#mxf_pnMLM)Z#PJ{LXuTxN%m8q^ zduspx|4Knh?(XKjy|m`$&CSiUw6vt8q?FAv^2GoE0A@)0^(R_%^0e2j~FEd?1|G*VHSs}TnY8VeqGedzGrt5pNJOp+k>3bf) zur%ptIekw|Kk3%Qdjn$by5fwyD(%$m2s1+Bz5zcCtZq5uE@07*qoM6N<$ Ef^i03Gynhq delta 156 zcmV;N0Av5#0j&X$8Gir(008?EN)Z460CY)2K~xx(ZIICo#2^eqnI$)XB{G2bUnd@b zOOsSOUCY;#c>%*Zv(_t+ETB9oLB6As9Y7@qHnP~xp|=x?+W{XZqd@XW0Q}dG)Q~50 zbztLcQ*Y&5%W=ulRXKt5zBDVFSc#dpgOB%=JUdPw^ef``6BWM9&c;LY=#qE<0000< KMNUMnLSTZdJwjms diff --git a/graphics/tileset_anims/anim_mtember_steam_frame3.png b/graphics/tileset_anims/anim_mtember_steam_frame3.png index b4f607b5a5b7c4e36f5534d37485b15d2cd39117..a6ec412cf459d2ddc857cb6b011047d234844a79 100644 GIT binary patch delta 208 zcmV;>05AWm0pS6V8Gi!+008Ny<^KQx05DKYR7Fa2ti{E&tgM`rlzV%7YNV{J|K>q^ zduspx|4Knh?(XKjy|m`$&CSiUw6vt8q?FAv^2GoE0BlJ_K~xx(ZI0Ou!!Qg(Jpi@; zIvjukG(fydY*Q_YCjKyl2VP^mJOJcAC@Bt+vP^QCL{$?UlSv>RfQ)HWE%{A$@JH-0jmL!8Gir(008?EN)Z460CGu0K~xx(WslJf#2^eqI}05kQaph7Und^m zuHdwycYGkr*e~Ju^f@*miJXD}YB@lLog8*5q8+Uk1jZD~8d{u~kstB}ZgScA%gpf> zAkQU;lAkL04&Q<_S<0^C9NwpDcorkOE@rtd|6&93S>w9CI}=jLxXo^V+yDRo07*qo IM6N<$f-eQZrd!)UTz3v+2AvXX30H;YrK~xx(RgN(V!!Qg*|0T1e z0Z@!r6i^FgV5(mUkKYNZ1254aDVmK%h>+n1 zmBw2%6E=-_tJnC%s@{q-npyLUp^fu8wFNS?X>1EO_aBX)B1XuGTP$P}kCW6sYSdCm zj4J*gi)#L#T@Ki@g+XW00000NkvXX Hu0mjfzf4z& diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame1.png b/graphics/tileset_anims/anim_silphco_fountain_frame1.png index d5e6d74663a8ef56f765fdae8196aebf2d22c57c..5063c1476e1f0479da71622255bf59ac5a181586 100644 GIT binary patch delta 256 zcmV+b0ssEc0g(cb8Gi!+008Ny<^KQx05DKYR7L*)|58$FdwYA7l%%w@r2qf_)z#IM z&9rl@lxmcV#qR&C)&F~>-eQZrd!)UTz3v+2AvXX30GvrgK~xx(b&o*~gHQ-W=aR0B z7sMD>ZX^vy=*rD+$iG1kApN1BrtPM);RR+0;CTtZz?@K(O?g-wl$_Z~QN-NECKQ*~ z-F!klp<(tM`Hs=k>??ZlkS*9GJ2qfrCSo3-T~D-hifP=5=Cwc{zVv?6027lnVB}DC zYM#*&a^V+_ROpjB;BTs(P|-9&YdlzU5)WPqbCyh<9(@Cr4cqR=*tB*40000rs<36sia6bdi=%F#+b ttwa8{$|;qeWL`Nd{NP1~JlHyS^bO>NBNSiFUmO4c002ovPDHLkV1lkoOxXYc diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame2.png b/graphics/tileset_anims/anim_silphco_fountain_frame2.png index e578cfae7451656872de31e08d80350f4108a6df..eb46683ea93b108a7bce58f0dc044e16c1a087e2 100644 GIT binary patch delta 259 zcmV+e0sQ{e0h9ue8Gi!+008Ny<^KQx05DKYR7L*)|58$FdwYA7l%%w@r2qf_)z#IM z&9rl@lxmcV#qR&C)&F~>-eQZrd!)UTz3v+2AvXX30G~-jK~xx(WsX4#gFp;L|0UfB z9?#9l;Hn!#nKu!nsEwk@j>7b=8?ht0rUQ3y?iY*_N7-|_XU#7iGr!O z*WK0)NwaXw;<${)W@-aERwC95YBnO%7Bx`_K4`8S zk|tl!mLO9;u?b?4_}zHr9F_8aE+v!PrZV7s!%RR!RzO$pgVd_#q>FKxnQ)k3OL3Cz7t|!3joY3==MQbS)CONOmzy zA_O3eC_<`2FRTJp(2P~JRvXN9oYztp@U51yE)0&F>h^Sjl0EFAhDjQ1p=|;WexhaM yL-KcHm9bYO|2ZEy|2#fdY#&v2i5|HeoaGJ0ZzcWhSGRNk0000-eQZrd!)UTz3v+2AvXX30GCNbK~xx(WsgA$!!Qg4_meq= zd{80eluJa=6MD+ULHGxKfK{VfO$%u|r@^}m7Vd9w73PqvY;?j}q2$a?iX`SPHX*q@ zZsrs6DHXFvqmnM0~Z z)QIRXG1;QbjaNB-SU;;T`B~{@b>0<{qZ@MaFHZ*5+M3>X@bCZt002ovPDHLkV1kQ! BdQ|`b delta 187 zcmV;s07UQ|C@{VZpk`(wEEt?DNB|lJquOy1nRZ&ba4#fn3<`x*PxA?B_$Y+ X&J$}f-nq{QXbOX;tDnm{r-UW|f$Kz0 literal 138 zcmeAS@N?(olHy`uVBq!ia0vp^96)Tr0wfp|-f{m1Qh}Z>jv*3LlYj8D@ciib>hS2g z&K|E5N_A`JocvJ#^vqm`q;Gj`@te!vw{1{JN{F1WceO)T`nssCU5RP}25;DyIJkAT mab3L-8gZrZs6ma(iCTuEHYes?-BIoYvc%KX&t;ucLK6T+fHQ^w diff --git a/graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png b/graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png index 52a687e69fca906dcbf35b84720980c24950c056..bfddebccd99450ca3164c11f4f8ba1a6fc763169 100644 GIT binary patch literal 186 zcmeAS@N?(olHy`uVBq!ia0vp^7C_9w!VDziE-5wuDT4r?5ZC_<|AT_Es;jHFY+3UE z|9^!o&({2Zws&vwyL&+Hma{>Q|C@{VZpk`(wEEt?DNB|lJquOy1nPD5ba4#fn3 Date: Thu, 3 Jun 2021 15:00:52 -0400 Subject: [PATCH 21/21] Reorganize tileset graphics files --- .../primary/general/anim/flower/0.png | Bin .../primary/general/anim/flower/1.png | Bin .../primary/general/anim/flower/2.png | Bin .../primary/general/anim/flower/3.png | Bin .../primary/general/anim/flower/4.png | Bin .../primary/general/anim/sandwatersedge/0.png | Bin .../primary/general/anim/sandwatersedge/1.png | Bin .../primary/general/anim/sandwatersedge/2.png | Bin .../primary/general/anim/sandwatersedge/3.png | Bin .../primary/general/anim/sandwatersedge/4.png | Bin .../primary/general/anim/sandwatersedge/5.png | Bin .../primary/general/anim/sandwatersedge/6.png | Bin .../primary/general/anim/sandwatersedge/7.png | Bin .../anim/water_current_landwatersedge/0.png | Bin .../anim/water_current_landwatersedge/1.png | Bin .../anim/water_current_landwatersedge/2.png | Bin .../anim/water_current_landwatersedge/3.png | Bin .../anim/water_current_landwatersedge/4.png | Bin .../anim/water_current_landwatersedge/5.png | Bin .../anim/water_current_landwatersedge/6.png | Bin .../anim/water_current_landwatersedge/7.png | Bin .../celadon_city/anim/fountain/0.png | Bin .../celadon_city/anim/fountain/1.png | Bin .../celadon_city/anim/fountain/2.png | Bin .../celadon_city/anim/fountain/3.png | Bin .../celadon_city/anim/fountain/4.png | Bin .../secondary/celadon_gym/anim/flowers/0.png | Bin .../secondary/celadon_gym/anim/flowers/1.png | Bin .../secondary/celadon_gym/anim/flowers/2.png | Bin .../secondary/mt_ember/anim/steam/0.png | Bin .../secondary/mt_ember/anim/steam/1.png | Bin .../secondary/mt_ember/anim/steam/2.png | Bin .../secondary/mt_ember/anim/steam/3.png | Bin .../secondary/silph_co/anim/fountain/0.png | Bin .../secondary/silph_co/anim/fountain/1.png | Bin .../secondary/silph_co/anim/fountain/2.png | Bin .../secondary/silph_co/anim/fountain/3.png | Bin .../vermilion_gym/anim/motorizeddoor/0.png | Bin .../vermilion_gym/anim/motorizeddoor/1.png | Bin graphics_file_rules.mk | 3 +- src/tileset_anims.c | 78 +++++++++--------- 41 files changed, 40 insertions(+), 41 deletions(-) rename graphics/tileset_anims/anim_general_flower_frame0.png => data/tilesets/primary/general/anim/flower/0.png (100%) rename graphics/tileset_anims/anim_general_flower_frame1.png => data/tilesets/primary/general/anim/flower/1.png (100%) rename graphics/tileset_anims/anim_general_flower_frame2.png => data/tilesets/primary/general/anim/flower/2.png (100%) rename graphics/tileset_anims/anim_general_flower_frame3.png => data/tilesets/primary/general/anim/flower/3.png (100%) rename graphics/tileset_anims/anim_general_flower_frame4.png => data/tilesets/primary/general/anim/flower/4.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame0.png => data/tilesets/primary/general/anim/sandwatersedge/0.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame1.png => data/tilesets/primary/general/anim/sandwatersedge/1.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame2.png => data/tilesets/primary/general/anim/sandwatersedge/2.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame3.png => data/tilesets/primary/general/anim/sandwatersedge/3.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame4.png => data/tilesets/primary/general/anim/sandwatersedge/4.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame5.png => data/tilesets/primary/general/anim/sandwatersedge/5.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame6.png => data/tilesets/primary/general/anim/sandwatersedge/6.png (100%) rename graphics/tileset_anims/anim_general_sandwatersedge_frame7.png => data/tilesets/primary/general/anim/sandwatersedge/7.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame0.png => data/tilesets/primary/general/anim/water_current_landwatersedge/0.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png => data/tilesets/primary/general/anim/water_current_landwatersedge/1.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png => data/tilesets/primary/general/anim/water_current_landwatersedge/2.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png => data/tilesets/primary/general/anim/water_current_landwatersedge/3.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.png => data/tilesets/primary/general/anim/water_current_landwatersedge/4.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png => data/tilesets/primary/general/anim/water_current_landwatersedge/5.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame6.png => data/tilesets/primary/general/anim/water_current_landwatersedge/6.png (100%) rename graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.png => data/tilesets/primary/general/anim/water_current_landwatersedge/7.png (100%) rename graphics/tileset_anims/anim_celadoncity_fountain_frame0.png => data/tilesets/secondary/celadon_city/anim/fountain/0.png (100%) rename graphics/tileset_anims/anim_celadoncity_fountain_frame1.png => data/tilesets/secondary/celadon_city/anim/fountain/1.png (100%) rename graphics/tileset_anims/anim_celadoncity_fountain_frame2.png => data/tilesets/secondary/celadon_city/anim/fountain/2.png (100%) rename graphics/tileset_anims/anim_celadoncity_fountain_frame3.png => data/tilesets/secondary/celadon_city/anim/fountain/3.png (100%) rename graphics/tileset_anims/anim_celadoncity_fountain_frame4.png => data/tilesets/secondary/celadon_city/anim/fountain/4.png (100%) rename graphics/tileset_anims/anim_celadongym_flowers_frame0.png => data/tilesets/secondary/celadon_gym/anim/flowers/0.png (100%) rename graphics/tileset_anims/anim_celadongym_flowers_frame1.png => data/tilesets/secondary/celadon_gym/anim/flowers/1.png (100%) rename graphics/tileset_anims/anim_celadongym_flowers_frame2.png => data/tilesets/secondary/celadon_gym/anim/flowers/2.png (100%) rename graphics/tileset_anims/anim_mtember_steam_frame0.png => data/tilesets/secondary/mt_ember/anim/steam/0.png (100%) rename graphics/tileset_anims/anim_mtember_steam_frame1.png => data/tilesets/secondary/mt_ember/anim/steam/1.png (100%) rename graphics/tileset_anims/anim_mtember_steam_frame2.png => data/tilesets/secondary/mt_ember/anim/steam/2.png (100%) rename graphics/tileset_anims/anim_mtember_steam_frame3.png => data/tilesets/secondary/mt_ember/anim/steam/3.png (100%) rename graphics/tileset_anims/anim_silphco_fountain_frame0.png => data/tilesets/secondary/silph_co/anim/fountain/0.png (100%) rename graphics/tileset_anims/anim_silphco_fountain_frame1.png => data/tilesets/secondary/silph_co/anim/fountain/1.png (100%) rename graphics/tileset_anims/anim_silphco_fountain_frame2.png => data/tilesets/secondary/silph_co/anim/fountain/2.png (100%) rename graphics/tileset_anims/anim_silphco_fountain_frame3.png => data/tilesets/secondary/silph_co/anim/fountain/3.png (100%) rename graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame0.png => data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/0.png (100%) rename graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png => data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/1.png (100%) diff --git a/graphics/tileset_anims/anim_general_flower_frame0.png b/data/tilesets/primary/general/anim/flower/0.png similarity index 100% rename from graphics/tileset_anims/anim_general_flower_frame0.png rename to data/tilesets/primary/general/anim/flower/0.png diff --git a/graphics/tileset_anims/anim_general_flower_frame1.png b/data/tilesets/primary/general/anim/flower/1.png similarity index 100% rename from graphics/tileset_anims/anim_general_flower_frame1.png rename to data/tilesets/primary/general/anim/flower/1.png diff --git a/graphics/tileset_anims/anim_general_flower_frame2.png b/data/tilesets/primary/general/anim/flower/2.png similarity index 100% rename from graphics/tileset_anims/anim_general_flower_frame2.png rename to data/tilesets/primary/general/anim/flower/2.png diff --git a/graphics/tileset_anims/anim_general_flower_frame3.png b/data/tilesets/primary/general/anim/flower/3.png similarity index 100% rename from graphics/tileset_anims/anim_general_flower_frame3.png rename to data/tilesets/primary/general/anim/flower/3.png diff --git a/graphics/tileset_anims/anim_general_flower_frame4.png b/data/tilesets/primary/general/anim/flower/4.png similarity index 100% rename from graphics/tileset_anims/anim_general_flower_frame4.png rename to data/tilesets/primary/general/anim/flower/4.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame0.png b/data/tilesets/primary/general/anim/sandwatersedge/0.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame0.png rename to data/tilesets/primary/general/anim/sandwatersedge/0.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame1.png b/data/tilesets/primary/general/anim/sandwatersedge/1.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame1.png rename to data/tilesets/primary/general/anim/sandwatersedge/1.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame2.png b/data/tilesets/primary/general/anim/sandwatersedge/2.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame2.png rename to data/tilesets/primary/general/anim/sandwatersedge/2.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame3.png b/data/tilesets/primary/general/anim/sandwatersedge/3.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame3.png rename to data/tilesets/primary/general/anim/sandwatersedge/3.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame4.png b/data/tilesets/primary/general/anim/sandwatersedge/4.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame4.png rename to data/tilesets/primary/general/anim/sandwatersedge/4.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame5.png b/data/tilesets/primary/general/anim/sandwatersedge/5.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame5.png rename to data/tilesets/primary/general/anim/sandwatersedge/5.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame6.png b/data/tilesets/primary/general/anim/sandwatersedge/6.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame6.png rename to data/tilesets/primary/general/anim/sandwatersedge/6.png diff --git a/graphics/tileset_anims/anim_general_sandwatersedge_frame7.png b/data/tilesets/primary/general/anim/sandwatersedge/7.png similarity index 100% rename from graphics/tileset_anims/anim_general_sandwatersedge_frame7.png rename to data/tilesets/primary/general/anim/sandwatersedge/7.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame0.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/0.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame0.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/0.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/1.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/1.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/2.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/2.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/3.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/3.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/4.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/4.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/5.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/5.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame6.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/6.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame6.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/6.png diff --git a/graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.png b/data/tilesets/primary/general/anim/water_current_landwatersedge/7.png similarity index 100% rename from graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.png rename to data/tilesets/primary/general/anim/water_current_landwatersedge/7.png diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame0.png b/data/tilesets/secondary/celadon_city/anim/fountain/0.png similarity index 100% rename from graphics/tileset_anims/anim_celadoncity_fountain_frame0.png rename to data/tilesets/secondary/celadon_city/anim/fountain/0.png diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame1.png b/data/tilesets/secondary/celadon_city/anim/fountain/1.png similarity index 100% rename from graphics/tileset_anims/anim_celadoncity_fountain_frame1.png rename to data/tilesets/secondary/celadon_city/anim/fountain/1.png diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame2.png b/data/tilesets/secondary/celadon_city/anim/fountain/2.png similarity index 100% rename from graphics/tileset_anims/anim_celadoncity_fountain_frame2.png rename to data/tilesets/secondary/celadon_city/anim/fountain/2.png diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame3.png b/data/tilesets/secondary/celadon_city/anim/fountain/3.png similarity index 100% rename from graphics/tileset_anims/anim_celadoncity_fountain_frame3.png rename to data/tilesets/secondary/celadon_city/anim/fountain/3.png diff --git a/graphics/tileset_anims/anim_celadoncity_fountain_frame4.png b/data/tilesets/secondary/celadon_city/anim/fountain/4.png similarity index 100% rename from graphics/tileset_anims/anim_celadoncity_fountain_frame4.png rename to data/tilesets/secondary/celadon_city/anim/fountain/4.png diff --git a/graphics/tileset_anims/anim_celadongym_flowers_frame0.png b/data/tilesets/secondary/celadon_gym/anim/flowers/0.png similarity index 100% rename from graphics/tileset_anims/anim_celadongym_flowers_frame0.png rename to data/tilesets/secondary/celadon_gym/anim/flowers/0.png diff --git a/graphics/tileset_anims/anim_celadongym_flowers_frame1.png b/data/tilesets/secondary/celadon_gym/anim/flowers/1.png similarity index 100% rename from graphics/tileset_anims/anim_celadongym_flowers_frame1.png rename to data/tilesets/secondary/celadon_gym/anim/flowers/1.png diff --git a/graphics/tileset_anims/anim_celadongym_flowers_frame2.png b/data/tilesets/secondary/celadon_gym/anim/flowers/2.png similarity index 100% rename from graphics/tileset_anims/anim_celadongym_flowers_frame2.png rename to data/tilesets/secondary/celadon_gym/anim/flowers/2.png diff --git a/graphics/tileset_anims/anim_mtember_steam_frame0.png b/data/tilesets/secondary/mt_ember/anim/steam/0.png similarity index 100% rename from graphics/tileset_anims/anim_mtember_steam_frame0.png rename to data/tilesets/secondary/mt_ember/anim/steam/0.png diff --git a/graphics/tileset_anims/anim_mtember_steam_frame1.png b/data/tilesets/secondary/mt_ember/anim/steam/1.png similarity index 100% rename from graphics/tileset_anims/anim_mtember_steam_frame1.png rename to data/tilesets/secondary/mt_ember/anim/steam/1.png diff --git a/graphics/tileset_anims/anim_mtember_steam_frame2.png b/data/tilesets/secondary/mt_ember/anim/steam/2.png similarity index 100% rename from graphics/tileset_anims/anim_mtember_steam_frame2.png rename to data/tilesets/secondary/mt_ember/anim/steam/2.png diff --git a/graphics/tileset_anims/anim_mtember_steam_frame3.png b/data/tilesets/secondary/mt_ember/anim/steam/3.png similarity index 100% rename from graphics/tileset_anims/anim_mtember_steam_frame3.png rename to data/tilesets/secondary/mt_ember/anim/steam/3.png diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame0.png b/data/tilesets/secondary/silph_co/anim/fountain/0.png similarity index 100% rename from graphics/tileset_anims/anim_silphco_fountain_frame0.png rename to data/tilesets/secondary/silph_co/anim/fountain/0.png diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame1.png b/data/tilesets/secondary/silph_co/anim/fountain/1.png similarity index 100% rename from graphics/tileset_anims/anim_silphco_fountain_frame1.png rename to data/tilesets/secondary/silph_co/anim/fountain/1.png diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame2.png b/data/tilesets/secondary/silph_co/anim/fountain/2.png similarity index 100% rename from graphics/tileset_anims/anim_silphco_fountain_frame2.png rename to data/tilesets/secondary/silph_co/anim/fountain/2.png diff --git a/graphics/tileset_anims/anim_silphco_fountain_frame3.png b/data/tilesets/secondary/silph_co/anim/fountain/3.png similarity index 100% rename from graphics/tileset_anims/anim_silphco_fountain_frame3.png rename to data/tilesets/secondary/silph_co/anim/fountain/3.png diff --git a/graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame0.png b/data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/0.png similarity index 100% rename from graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame0.png rename to data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/0.png diff --git a/graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png b/data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/1.png similarity index 100% rename from graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.png rename to data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/1.png diff --git a/graphics_file_rules.mk b/graphics_file_rules.mk index d96845bba..dbb583269 100644 --- a/graphics_file_rules.mk +++ b/graphics_file_rules.mk @@ -28,7 +28,6 @@ INTROGFXDIR := graphics/intro BATTLETERRAINGFXDIR := graphics/battle_terrain BERRYPOUCHGFXDIR := graphics/berry_pouch HALLOFFAMEGFXDIR := graphics/hall_of_fame -TILESETANIMSGFXDIR := graphics/tileset_anims types := normal fight flying poison ground rock bug ghost steel mystery fire water grass electric psychic ice dragon dark contest_types := cool beauty cute smart tough @@ -592,5 +591,5 @@ $(BERRYPOUCHGFXDIR)/background.4bpp: %.4bpp: %.png $(HALLOFFAMEGFXDIR)/hall_of_fame.4bpp: %.4bpp: %.png $(GFX) $< $@ -num_tiles 29 -$(TILESETANIMSGFXDIR)/anim_general_water_current_landwatersedge_frame7.4bpp: %.4bpp: %.png +$(TILESETGFXDIR)/primary/general/anim/water_current_landwatersedge/7.4bpp: %.4bpp: %.png $(GFX) $< $@ -num_tiles 47 diff --git a/src/tileset_anims.c b/src/tileset_anims.c index abd0d80e1..fcf6a6038 100644 --- a/src/tileset_anims.c +++ b/src/tileset_anims.c @@ -18,11 +18,11 @@ static void _InitPrimaryTilesetAnimation(void); static void _InitSecondaryTilesetAnimation(void); // palette: general 00 -static const u16 sTilesetAnims_General_Flower_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_general_flower_frame0.4bpp"); -static const u16 sTilesetAnims_General_Flower_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_general_flower_frame1.4bpp"); -static const u16 sTilesetAnims_General_Flower_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_general_flower_frame2.4bpp"); -static const u16 sTilesetAnims_General_Flower_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_general_flower_frame3.4bpp"); -static const u16 sTilesetAnims_General_Flower_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_general_flower_frame4.4bpp"); +static const u16 sTilesetAnims_General_Flower_Frame0[] = INCBIN_U16("data/tilesets/primary/general/anim/flower/0.4bpp"); +static const u16 sTilesetAnims_General_Flower_Frame1[] = INCBIN_U16("data/tilesets/primary/general/anim/flower/1.4bpp"); +static const u16 sTilesetAnims_General_Flower_Frame2[] = INCBIN_U16("data/tilesets/primary/general/anim/flower/2.4bpp"); +static const u16 sTilesetAnims_General_Flower_Frame3[] = INCBIN_U16("data/tilesets/primary/general/anim/flower/3.4bpp"); +static const u16 sTilesetAnims_General_Flower_Frame4[] = INCBIN_U16("data/tilesets/primary/general/anim/flower/4.4bpp"); static const u16 *const sTilesetAnims_General_Flower[] = { sTilesetAnims_General_Flower_Frame0, @@ -33,14 +33,14 @@ static const u16 *const sTilesetAnims_General_Flower[] = { }; // palette: general 04 -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame0.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame1.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame2.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame3.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame4.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame5[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame5.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame6[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame6.4bpp"); -static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame7[] = INCBIN_U16("graphics/tileset_anims/anim_general_water_current_landwatersedge_frame7.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame0[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/0.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame1[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/1.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame2[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/2.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame3[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/3.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame4[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/4.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame5[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/5.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame6[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/6.4bpp"); +static const u16 sTilesetAnims_General_Water_Current_LandWatersEdge_Frame7[] = INCBIN_U16("data/tilesets/primary/general/anim/water_current_landwatersedge/7.4bpp"); static const u16 *const sTilesetAnims_General_Water_Current_LandWatersEdge[] = { sTilesetAnims_General_Water_Current_LandWatersEdge_Frame0, @@ -54,14 +54,14 @@ static const u16 *const sTilesetAnims_General_Water_Current_LandWatersEdge[] = { }; // palette: general 04 -static const u16 sTilesetAnims_General_SandWatersEdge_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame0.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame1.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame2.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame3.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame4.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame5[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame5.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame6[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame6.4bpp"); -static const u16 sTilesetAnims_General_SandWatersEdge_Frame7[] = INCBIN_U16("graphics/tileset_anims/anim_general_sandwatersedge_frame7.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame0[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/0.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame1[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/1.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame2[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/2.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame3[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/3.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame4[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/4.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame5[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/5.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame6[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/6.4bpp"); +static const u16 sTilesetAnims_General_SandWatersEdge_Frame7[] = INCBIN_U16("data/tilesets/primary/general/anim/sandwatersedge/7.4bpp"); static const u16 *const sTilesetAnims_General_SandWatersEdge[] = { sTilesetAnims_General_SandWatersEdge_Frame0, @@ -75,11 +75,11 @@ static const u16 *const sTilesetAnims_General_SandWatersEdge[] = { }; // palette: general 00 -static const u16 sTilesetAnims_CeladonCity_Fountain_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_celadoncity_fountain_frame0.4bpp"); -static const u16 sTilesetAnims_CeladonCity_Fountain_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_celadoncity_fountain_frame1.4bpp"); -static const u16 sTilesetAnims_CeladonCity_Fountain_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_celadoncity_fountain_frame2.4bpp"); -static const u16 sTilesetAnims_CeladonCity_Fountain_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_celadoncity_fountain_frame3.4bpp"); -static const u16 sTilesetAnims_CeladonCity_Fountain_Frame4[] = INCBIN_U16("graphics/tileset_anims/anim_celadoncity_fountain_frame4.4bpp"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame0[] = INCBIN_U16("data/tilesets/secondary/celadon_city/anim/fountain/0.4bpp"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame1[] = INCBIN_U16("data/tilesets/secondary/celadon_city/anim/fountain/1.4bpp"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame2[] = INCBIN_U16("data/tilesets/secondary/celadon_city/anim/fountain/2.4bpp"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame3[] = INCBIN_U16("data/tilesets/secondary/celadon_city/anim/fountain/3.4bpp"); +static const u16 sTilesetAnims_CeladonCity_Fountain_Frame4[] = INCBIN_U16("data/tilesets/secondary/celadon_city/anim/fountain/4.4bpp"); static const u16 gUnknown_83ABD94[16] = {}; static const u16 *const sTilesetAnims_CeladonCity_Fountain[] = { @@ -90,10 +90,10 @@ static const u16 *const sTilesetAnims_CeladonCity_Fountain[] = { sTilesetAnims_CeladonCity_Fountain_Frame4 }; -static const u16 sTilesetAnims_SilphCo_Fountain_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_silphco_fountain_frame0.4bpp"); -static const u16 sTilesetAnims_SilphCo_Fountain_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_silphco_fountain_frame1.4bpp"); -static const u16 sTilesetAnims_SilphCo_Fountain_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_silphco_fountain_frame2.4bpp"); -static const u16 sTilesetAnims_SilphCo_Fountain_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_silphco_fountain_frame3.4bpp"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame0[] = INCBIN_U16("data/tilesets/secondary/silph_co/anim/fountain/0.4bpp"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame1[] = INCBIN_U16("data/tilesets/secondary/silph_co/anim/fountain/1.4bpp"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame2[] = INCBIN_U16("data/tilesets/secondary/silph_co/anim/fountain/2.4bpp"); +static const u16 sTilesetAnims_SilphCo_Fountain_Frame3[] = INCBIN_U16("data/tilesets/secondary/silph_co/anim/fountain/3.4bpp"); static const u16 gUnknown_83AC1C8[16] = {}; static const u16 *const sTilesetAnims_SilphCo_Fountain[] = { @@ -103,10 +103,10 @@ static const u16 *const sTilesetAnims_SilphCo_Fountain[] = { sTilesetAnims_SilphCo_Fountain_Frame3 }; -static const u16 sTilesetAnims_MtEmber_Steam_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_mtember_steam_frame0.4bpp"); -static const u16 sTilesetAnims_MtEmber_Steam_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_mtember_steam_frame1.4bpp"); -static const u16 sTilesetAnims_MtEmber_Steam_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_mtember_steam_frame2.4bpp"); -static const u16 sTilesetAnims_MtEmber_Steam_Frame3[] = INCBIN_U16("graphics/tileset_anims/anim_mtember_steam_frame3.4bpp"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame0[] = INCBIN_U16("data/tilesets/secondary/mt_ember/anim/steam/0.4bpp"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame1[] = INCBIN_U16("data/tilesets/secondary/mt_ember/anim/steam/1.4bpp"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame2[] = INCBIN_U16("data/tilesets/secondary/mt_ember/anim/steam/2.4bpp"); +static const u16 sTilesetAnims_MtEmber_Steam_Frame3[] = INCBIN_U16("data/tilesets/secondary/mt_ember/anim/steam/3.4bpp"); static const u16 *const sTilesetAnims_MtEmber_Steam[] = { sTilesetAnims_MtEmber_Steam_Frame0, @@ -115,17 +115,17 @@ static const u16 *const sTilesetAnims_MtEmber_Steam[] = { sTilesetAnims_MtEmber_Steam_Frame3 }; -static const u16 sTilesetAnims_VermilionGym_MotorizedDoor_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame0.4bpp"); -static const u16 sTilesetAnims_VermilionGym_MotorizedDoor_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_vermiliongym_motorizeddoor_frame1.4bpp"); +static const u16 sTilesetAnims_VermilionGym_MotorizedDoor_Frame0[] = INCBIN_U16("data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/0.4bpp"); +static const u16 sTilesetAnims_VermilionGym_MotorizedDoor_Frame1[] = INCBIN_U16("data/tilesets/secondary/vermilion_gym/anim/motorizeddoor/1.4bpp"); static const u16 *const sTilesetAnims_VermilionGym_MotorizedDoor[] = { sTilesetAnims_VermilionGym_MotorizedDoor_Frame0, sTilesetAnims_VermilionGym_MotorizedDoor_Frame1 }; -static const u16 sTilesetAnims_CeladonGym_Flowers_Frame0[] = INCBIN_U16("graphics/tileset_anims/anim_celadongym_flowers_frame0.4bpp"); -static const u16 sTilesetAnims_CeladonGym_Flowers_Frame1[] = INCBIN_U16("graphics/tileset_anims/anim_celadongym_flowers_frame1.4bpp"); -static const u16 sTilesetAnims_CeladonGym_Flowers_Frame2[] = INCBIN_U16("graphics/tileset_anims/anim_celadongym_flowers_frame2.4bpp"); +static const u16 sTilesetAnims_CeladonGym_Flowers_Frame0[] = INCBIN_U16("data/tilesets/secondary/celadon_gym/anim/flowers/0.4bpp"); +static const u16 sTilesetAnims_CeladonGym_Flowers_Frame1[] = INCBIN_U16("data/tilesets/secondary/celadon_gym/anim/flowers/1.4bpp"); +static const u16 sTilesetAnims_CeladonGym_Flowers_Frame2[] = INCBIN_U16("data/tilesets/secondary/celadon_gym/anim/flowers/2.4bpp"); static const u16 *const sTilesetAnims_CeladonGym_Flowers[] = { sTilesetAnims_CeladonGym_Flowers_Frame0,