From c149616482f740a38daf52eb81f044d737e21c6b Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 00:00:46 -0600 Subject: [PATCH 1/9] suggest possible bgm name if it is not found --- tools/splat_ext/pm_sbn.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/tools/splat_ext/pm_sbn.py b/tools/splat_ext/pm_sbn.py index 5c20c091e85..543613be91b 100644 --- a/tools/splat_ext/pm_sbn.py +++ b/tools/splat_ext/pm_sbn.py @@ -275,10 +275,16 @@ def write(self, path: Path): f.write("\n") def lookup_file_id(self, filename: str) -> int: + suggestion = "" for id, sbn_file in enumerate(self.files): if sbn_file.file_name() == filename: return id - raise Exception(f"File not found: {filename} - is it in the file_id_map?") + elif sbn_file.file_name().split('_')[0] == filename.split('_')[0]: + suggestion = sbn_file.file_name() + if (suggestion == ""): + raise Exception(f"File not found: {filename} - is it in the file_id_map?") + else: + raise Exception(f"File not found: {filename} - is it in the file_id_map? (Did you mean to name the file: {suggestion}?)") def __str__(self) -> str: s = "SBN(\n" From 6cc452031ad78ae6be9ac19f8153e53b06c31f24 Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 00:06:29 -0600 Subject: [PATCH 2/9] remove pointless () --- tools/splat_ext/pm_sbn.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/splat_ext/pm_sbn.py b/tools/splat_ext/pm_sbn.py index 543613be91b..5ecd8e0d1d4 100644 --- a/tools/splat_ext/pm_sbn.py +++ b/tools/splat_ext/pm_sbn.py @@ -281,7 +281,7 @@ def lookup_file_id(self, filename: str) -> int: return id elif sbn_file.file_name().split('_')[0] == filename.split('_')[0]: suggestion = sbn_file.file_name() - if (suggestion == ""): + if suggestion == "": raise Exception(f"File not found: {filename} - is it in the file_id_map?") else: raise Exception(f"File not found: {filename} - is it in the file_id_map? (Did you mean to name the file: {suggestion}?)") From c617eeb0932c743caeca7d41a80b8c59291fe5d0 Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 00:10:44 -0600 Subject: [PATCH 3/9] run black --- tools/splat_ext/pm_sbn.py | 6 ++++-- tools/splat_ext/pm_sprites.py | 6 +++--- tools/star_rod_idx_to_c.py | 6 +++++- 3 files changed, 12 insertions(+), 6 deletions(-) diff --git a/tools/splat_ext/pm_sbn.py b/tools/splat_ext/pm_sbn.py index 5ecd8e0d1d4..9cd7a8f6007 100644 --- a/tools/splat_ext/pm_sbn.py +++ b/tools/splat_ext/pm_sbn.py @@ -279,12 +279,14 @@ def lookup_file_id(self, filename: str) -> int: for id, sbn_file in enumerate(self.files): if sbn_file.file_name() == filename: return id - elif sbn_file.file_name().split('_')[0] == filename.split('_')[0]: + elif sbn_file.file_name().split("_")[0] == filename.split("_")[0]: suggestion = sbn_file.file_name() if suggestion == "": raise Exception(f"File not found: {filename} - is it in the file_id_map?") else: - raise Exception(f"File not found: {filename} - is it in the file_id_map? (Did you mean to name the file: {suggestion}?)") + raise Exception( + f"File not found: {filename} - is it in the file_id_map? (Did you mean to name the file: {suggestion}?)" + ) def __str__(self) -> str: s = "SBN(\n" diff --git a/tools/splat_ext/pm_sprites.py b/tools/splat_ext/pm_sprites.py index 5a2184b7c1d..58641d7deef 100644 --- a/tools/splat_ext/pm_sprites.py +++ b/tools/splat_ext/pm_sprites.py @@ -424,9 +424,9 @@ def get_sprite_name_from_offset(offset: int, offsets: List[int], names: List[str raster_attributes["special"] = f"{back_raster.width & 0xFF:X},{back_raster.height & 0xFF:X}" else: back_name_offset = raster_sets[sprite_idx + 1].raster_offsets[i] - raster_attributes["back"] = ( - f"{get_sprite_name_from_offset(back_name_offset, sprite_offsets, raster_names)}.png" - ) + raster_attributes[ + "back" + ] = f"{get_sprite_name_from_offset(back_name_offset, sprite_offsets, raster_names)}.png" if back_raster.palette_idx != raster.palette_idx: raster_attributes[BACK_PALETTE_XML] = f"{back_raster.palette_idx:X}" diff --git a/tools/star_rod_idx_to_c.py b/tools/star_rod_idx_to_c.py index 1e36abc329b..6098ce484f6 100755 --- a/tools/star_rod_idx_to_c.py +++ b/tools/star_rod_idx_to_c.py @@ -385,7 +385,11 @@ def transform_symbol_name(symbol): var_name = ( var_names[1] if i == 0x4 - else var_names[3] if i == 0x14 else var_names[4] if i == 0x18 else var_names[17] + else var_names[3] + if i == 0x14 + else var_names[4] + if i == 0x18 + else var_names[17] ) addr = unpack_from(f">I", staticNpc, curr_base + i)[0] if not addr == 0: From c6018a689fb807b86235802d33120e0c4286b027 Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 00:13:32 -0600 Subject: [PATCH 4/9] ...run updated black --- tools/splat_ext/pm_sprites.py | 6 +++--- tools/star_rod_idx_to_c.py | 6 +----- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/tools/splat_ext/pm_sprites.py b/tools/splat_ext/pm_sprites.py index 58641d7deef..5a2184b7c1d 100644 --- a/tools/splat_ext/pm_sprites.py +++ b/tools/splat_ext/pm_sprites.py @@ -424,9 +424,9 @@ def get_sprite_name_from_offset(offset: int, offsets: List[int], names: List[str raster_attributes["special"] = f"{back_raster.width & 0xFF:X},{back_raster.height & 0xFF:X}" else: back_name_offset = raster_sets[sprite_idx + 1].raster_offsets[i] - raster_attributes[ - "back" - ] = f"{get_sprite_name_from_offset(back_name_offset, sprite_offsets, raster_names)}.png" + raster_attributes["back"] = ( + f"{get_sprite_name_from_offset(back_name_offset, sprite_offsets, raster_names)}.png" + ) if back_raster.palette_idx != raster.palette_idx: raster_attributes[BACK_PALETTE_XML] = f"{back_raster.palette_idx:X}" diff --git a/tools/star_rod_idx_to_c.py b/tools/star_rod_idx_to_c.py index 6098ce484f6..1e36abc329b 100755 --- a/tools/star_rod_idx_to_c.py +++ b/tools/star_rod_idx_to_c.py @@ -385,11 +385,7 @@ def transform_symbol_name(symbol): var_name = ( var_names[1] if i == 0x4 - else var_names[3] - if i == 0x14 - else var_names[4] - if i == 0x18 - else var_names[17] + else var_names[3] if i == 0x14 else var_names[4] if i == 0x18 else var_names[17] ) addr = unpack_from(f">I", staticNpc, curr_base + i)[0] if not addr == 0: From 816d7f58f96849d5c545d59f1581f75eb0d4434a Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 05:41:16 -0600 Subject: [PATCH 5/9] unhardcode many for loop conditions --- include/effects.h | 22 ++++++---- include/entity.h | 22 +++++----- include/macros.h | 3 ++ src/23680.c | 8 ++-- src/8a160_len_700.c | 2 +- src/audio/28910_len_5090.c | 6 +-- src/audio/2e230_len_2190.c | 2 +- src/audio/e0b30_len_b80.c | 6 +-- src/audio/reverb.c | 4 +- src/background_gfx.c | 44 ++++++++++--------- src/battle/action_cmd/tidal_wave.c | 6 +-- src/battle/area/sam2/actor/monstar.c | 14 +++--- src/battle/btl_states_menus.c | 2 +- src/common/UpdateEnchantedBowserColors.inc.c | 14 +++--- src/draw_box.c | 4 +- src/effects/firework_rocket.c | 4 +- src/effects/motion_blur_flame.c | 2 +- src/effects/quizmo_audience.c | 2 +- src/effects/sun.c | 2 +- src/entity/default/BoardedFloor.c | 2 +- src/evt/evt.c | 4 +- src/npc.c | 12 ++--- src/pause/pause_partners.c | 2 +- .../area_mac/mac_01/npc/post_office.inc.c | 2 +- src/world/area_sam/sam_05/sam_05_4_npc.c | 25 ++++++----- 25 files changed, 119 insertions(+), 97 deletions(-) diff --git a/include/effects.h b/include/effects.h index 86597127848..f6ca9260db9 100644 --- a/include/effects.h +++ b/include/effects.h @@ -1370,15 +1370,17 @@ typedef struct RadiatingEnergyOrbFXData { /* 0x30 */ f32 unk_30; } RadiatingEnergyOrbFXData; // size = 0x34 +#define Unk_Array_Size1 4 + typedef struct MotionBlurFlameFXData { /* 0x00 */ s32 unk_00; /* 0x04 */ f32 unk_04; /* 0x08 */ f32 unk_08; /* 0x0C */ f32 unk_0C; /* 0x10 */ Vec3f pos; - /* 0x1C */ f32 unk_1C[4]; - /* 0x2C */ f32 unk_2C[4]; - /* 0x3C */ f32 unk_3C[4]; + /* 0x1C */ f32 unk_1C[Unk_Array_Size1]; + /* 0x2C */ f32 unk_2C[Unk_Array_Size1]; + /* 0x3C */ f32 unk_3C[Unk_Array_Size1]; /* 0x4C */ s32 unk_4C; /* 0x50 */ s32 unk_50; /* 0x54 */ s32 unk_54; @@ -2131,6 +2133,8 @@ typedef struct Effect75FXData { /* 0x7C */ f32 unk_7C; } Effect75FXData; // size = 0x80 +#define ROCKET_BUF_SIZE 4 + typedef struct FireworkRocketFXData { /* 0x00 */ s32 variation; /* 0x04 */ Vec3f pos; @@ -2148,12 +2152,12 @@ typedef struct FireworkRocketFXData { /* 0x44 */ f32 radius; /* 0x48 */ f32 maxRadius; /* 0x4C */ s32 isExploded; - /* 0x50 */ f32 rocketX[4]; - /* 0x60 */ f32 rocketY[4]; - /* 0x70 */ f32 rocketZ[4]; - /* 0x80 */ f32 rocketVelX[4]; - /* 0x90 */ f32 rocketVelY[4]; - /* 0xA0 */ f32 rocketVelZ[4]; + /* 0x50 */ f32 rocketX[ROCKET_BUF_SIZE]; + /* 0x60 */ f32 rocketY[ROCKET_BUF_SIZE]; + /* 0x70 */ f32 rocketZ[ROCKET_BUF_SIZE]; + /* 0x80 */ f32 rocketVelX[ROCKET_BUF_SIZE]; + /* 0x90 */ f32 rocketVelY[ROCKET_BUF_SIZE]; + /* 0xA0 */ f32 rocketVelZ[ROCKET_BUF_SIZE]; } FireworkRocketFXData; // size = 0xB0 typedef struct PeachStarBeamSpirit { diff --git a/include/entity.h b/include/entity.h index 26e0e69e173..89bd42dbe82 100644 --- a/include/entity.h +++ b/include/entity.h @@ -263,19 +263,21 @@ typedef struct PadlockData { /* 0x18 */ Gfx* shackleGfx; } PadlockData; // size = 0x1C +#define FRAGMENT_BUF_SIZE 13 + typedef struct BoardedFloorData { /* 0x000 */ Gfx** fragmentsGfx; /* 0x004 */ f32 inititalY; - /* 0x008 */ s8 fragmentRebounds[13]; - /* 0x015 */ u8 fragmentMoveAngle[13]; - /* 0x022 */ u8 fragmentRotX[13]; - /* 0x02F */ u8 fragmentRotY[13]; - /* 0x03C */ u8 fragmentLateralSpeed[13]; - /* 0x04C */ f32 fragmentRotSpeed[13]; - /* 0x080 */ f32 fragmentPosX[13]; - /* 0x0B4 */ f32 fragmentPosY[13]; - /* 0x0E8 */ f32 fragmentPosZ[13]; - /* 0x11C */ f32 fragmentFallSpeed[13]; + /* 0x008 */ s8 fragmentRebounds[FRAGMENT_BUF_SIZE]; + /* 0x015 */ u8 fragmentMoveAngle[FRAGMENT_BUF_SIZE]; + /* 0x022 */ u8 fragmentRotX[FRAGMENT_BUF_SIZE]; + /* 0x02F */ u8 fragmentRotY[FRAGMENT_BUF_SIZE]; + /* 0x03C */ u8 fragmentLateralSpeed[FRAGMENT_BUF_SIZE]; + /* 0x04C */ f32 fragmentRotSpeed[FRAGMENT_BUF_SIZE]; + /* 0x080 */ f32 fragmentPosX[FRAGMENT_BUF_SIZE]; + /* 0x0B4 */ f32 fragmentPosY[FRAGMENT_BUF_SIZE]; + /* 0x0E8 */ f32 fragmentPosZ[FRAGMENT_BUF_SIZE]; + /* 0x11C */ f32 fragmentFallSpeed[FRAGMENT_BUF_SIZE]; } BoardedFloorData; // size = 0x150 typedef struct BombableRockData { diff --git a/include/macros.h b/include/macros.h index f2d6c2a234c..0ef90445021 100644 --- a/include/macros.h +++ b/include/macros.h @@ -44,6 +44,9 @@ #define ARRAY_COUNT(arr) (s32)(sizeof(arr) / sizeof(arr[0])) +#define COUNT_ROWS(matrix) (s32)(sizeof(matrix) / sizeof(matrix[0])) +#define COUNT_COLS(matrix) (s32)(sizeof(matrix[0]) / sizeof(matrix[0][0])) + #if !defined(PERMUTER) && !defined(M2CTX) && defined(OLD_GCC) #define NOP_FIX __asm__(".set nogpopt"); #define NOP_UNFIX __asm__(".set gpopt"); diff --git a/src/23680.c b/src/23680.c index df99a530aa0..dd88ff65a69 100644 --- a/src/23680.c +++ b/src/23680.c @@ -51,7 +51,7 @@ void spawn_drops(Enemy* enemy) { if (drops->itemDropChance > rand_int(100)) { tempMax = 0; - for (i = 0; i < 8; i++) { + for (i = 0; i < ARRAY_COUNT(drops->itemDrops) / 3; i++) { if (drops->itemDrops[3 * i] != 0) { tempMax += drops->itemDrops[3 * i + 1]; } else { @@ -63,7 +63,7 @@ void spawn_drops(Enemy* enemy) { dropCount = rand_int(tempMax); itemToDrop = ITEM_NONE; - for (i = 0; i < 8; i++) { + for (i = 0; i < ARRAY_COUNT(drops->itemDrops) / 3; i++) { if (drops->itemDrops[3 * i] == 0) { break; } @@ -122,7 +122,7 @@ void spawn_drops(Enemy* enemy) { itemToDrop = ITEM_NONE; fraction = playerData->curHP / (f32) playerData->curMaxHP; - for (i = 0; i < 8; i++) { + for (i = 0; i < ARRAY_COUNT(drops->itemDrops) / 3; i++) { attempts = drops->heartDrops[4 * i]; threshold = drops->heartDrops[4 * i + 1]; attempts /= 32767.0f; @@ -176,7 +176,7 @@ void spawn_drops(Enemy* enemy) { itemToDrop = ITEM_NONE; fraction = playerData->curFP / (f32) playerData->curMaxFP; - for (i = 0; i < 8; i++) { + for (i = 0; i < ARRAY_COUNT(drops->itemDrops) / 3; i++) { attempts = drops->flowerDrops[4 * i + 0]; threshold = drops->flowerDrops[4 * i + 1]; attempts /= 32767.0f; diff --git a/src/8a160_len_700.c b/src/8a160_len_700.c index 42d2ef45bce..f5225de0463 100644 --- a/src/8a160_len_700.c +++ b/src/8a160_len_700.c @@ -72,7 +72,7 @@ void func_800F0D5C(void) { Unk8a160Outer* outer = &D_8010D000[0]; s32 i; - for (i = 0; i < 1; i++) { + for (i = 0; i < ARRAY_COUNT(D_8010D000); i++) { outer[i].subs[0].alive = FALSE; } } diff --git a/src/audio/28910_len_5090.c b/src/audio/28910_len_5090.c index b56c8ca37b3..b14bb5b28e2 100644 --- a/src/audio/28910_len_5090.c +++ b/src/audio/28910_len_5090.c @@ -89,7 +89,7 @@ void au_bgm_update_main(BGMPlayer* player) { BGMDrumInfo* drum = &player->drumsInfo[i]; player->drums[i] = drum; } - for (; i < 12; i++) { + for (; i < ARRAY_COUNT(player->drums); i++) { player->drums[i] = player->drums[0]; } } else { @@ -808,7 +808,7 @@ void func_8004E844(BGMPlayer* player, s32 arg1) { u16* temp = player->unk_174[arg1]; player->unk_212[arg1] = 0; - for (i = 0; i < 9; i++) { + for (i = 0; i < COUNT_COLS(player->unk_174); i++) { *temp++ = 0xFF00; } } @@ -1798,7 +1798,7 @@ void au_BGMCmd_FF(BGMPlayer* player, BGMPlayerTrack* track) { if (arg1 == 0) { if (track->unk_4E != 0) { track->unk_4E = 0; - for (i = 0; i < 16; i++) { + for (i = 0; i < ARRAY_COUNT(player->tracks); i++) { BGMPlayerTrack* otherTrack = &player->tracks[i]; if (player->proxMixVolume == 0x7F) { if (otherTrack->unk_4F != 0) { diff --git a/src/audio/2e230_len_2190.c b/src/audio/2e230_len_2190.c index 146c847bf9b..685351c0863 100644 --- a/src/audio/2e230_len_2190.c +++ b/src/audio/2e230_len_2190.c @@ -79,7 +79,7 @@ void au_engine_init(s32 outputRate) { globals->unk_globals_6C[i].unk_5 = 0; } - for (i = 0; i < 4; i++) { + for (i = 0; i < ARRAY_COUNT(globals->effectChanges); i++) { globals->effectChanges[i].type = AU_FX_NONE; globals->effectChanges[i].changed = FALSE; } diff --git a/src/audio/e0b30_len_b80.c b/src/audio/e0b30_len_b80.c index 58da9278be3..21d55add59d 100644 --- a/src/audio/e0b30_len_b80.c +++ b/src/audio/e0b30_len_b80.c @@ -79,13 +79,13 @@ void bgm_reset_volume(void) { //TODO refactor out constants void bgm_update_music_settings(void) { - MusicSettings* music = &gMusicSettings[0]; + MusicSettings* music = gMusicSettings; s32 i = 0; s16 state2 = 2; s16 flag4 = MUSIC_SETTINGS_FLAG_4; s32 flags; - for (i; i < 2; i++, music++) { + for (i; i < ARRAY_COUNT(gMusicSettings); i++, music++) { switch (music->state) { case 0: break; @@ -359,7 +359,7 @@ s32 func_8014AD40(void) { MusicSettings* settings = gMusicSettings; s32 i; - for (i = 0; i < 2; i++, settings++) { + for (i = 0; i < ARRAY_COUNT(gMusicSettings); i++, settings++) { if (!(settings->flags & MUSIC_SETTINGS_FLAG_1)) { continue; } diff --git a/src/audio/reverb.c b/src/audio/reverb.c index 65c8d6e4717..0876a176212 100644 --- a/src/audio/reverb.c +++ b/src/audio/reverb.c @@ -116,7 +116,7 @@ static void _init_lpfilter(AuLowPass* lp) { timeConstant = timeConstant >> 1; lp->fgain = SCALE - timeConstant; - for (i = 0; i < 8; i++) { + for (i = 0; i < ARRAY_COUNT(lp->fccoef) / 2; i++) { lp->fccoef[i] = 0; } @@ -125,7 +125,7 @@ static void _init_lpfilter(AuLowPass* lp) { // ith value is 16384 * (timeConstant / 16384)^(i-7) // ex: i = 9 --> timeConstant^2 / 16384 attenuation = ((f64)timeConstant / SCALE); - for (i = 9; i < 16; i++) { + for (i = 9; i < ARRAY_COUNT(lp->fccoef); i++) { attenuation *= ((f64)timeConstant /SCALE); lp->fccoef[i] = attenuation * SCALE; } diff --git a/src/background_gfx.c b/src/background_gfx.c index 7843472b36a..efa5b5c27da 100644 --- a/src/background_gfx.c +++ b/src/background_gfx.c @@ -48,18 +48,19 @@ s32 gfx_frame_filter_pass_0(const u16* frameBuffer0, const u16* frameBuffer1, s3 } void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u16* out) { + #define RGBA_BUF_SIZE 32 Color_RGBA8 sp0; Color_RGBA8 sp8; Color_RGBA8 final; - u8 rs[0x20]; - u8 gs[0x20]; - u8 bs[0x20]; + u8 rs[RGBA_BUF_SIZE]; + u8 gs[RGBA_BUF_SIZE]; + u8 bs[RGBA_BUF_SIZE]; s32 i; sp8 = filterBuf1; sp0 = filterBuf1; - for (i = 0; i < ARRAY_COUNT(rs); i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { rs[i] = 0; gs[i] = 0; bs[i] = 0; @@ -73,13 +74,13 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 } } - for (i = 0; i < ARRAY_COUNT(rs); i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { if (rs[i] != 0) { rs[i]--; break; } } - for (; i < ARRAY_COUNT(rs); i++) { + for (; i < RGBA_BUF_SIZE; i++) { if (rs[i] != 0) { break; } @@ -88,13 +89,13 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 sp0.r = i; } - for (i = 0; i < ARRAY_COUNT(gs); i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { if (gs[i] != 0) { gs[i]--; break; } } - for (; i < ARRAY_COUNT(gs); i++) { + for (; i < RGBA_BUF_SIZE; i++) { if (gs[i] != 0) { break; } @@ -103,13 +104,13 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 sp0.g = i; } - for (i = 0; i < ARRAY_COUNT(bs); i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { if (bs[i] != 0) { bs[i]--; break; } } - for (; i < ARRAY_COUNT(bs); i++) { + for (; i < RGBA_BUF_SIZE; i++) { if (bs[i] != 0) { break; } @@ -118,7 +119,7 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 sp0.b = i; } - for (i = ARRAY_COUNT(rs) - 1; i >= 0; i--) { + for (i = RGBA_BUF_SIZE - 1; i >= 0; i--) { if (rs[i] != 0) { break; } @@ -127,7 +128,7 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 sp8.r = i; } - for (i = ARRAY_COUNT(gs) - 1; i >= 0; i--) { + for (i = RGBA_BUF_SIZE - 1; i >= 0; i--) { if (gs[i] != 0) { break; } @@ -136,7 +137,7 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 sp8.g = i; } - for (i = ARRAY_COUNT(bs) - 1; i >= 0; i--) { + for (i = RGBA_BUF_SIZE - 1; i >= 0; i--) { if (bs[i] != 0) { break; } @@ -154,17 +155,19 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 final.b = ((filterBuf1.b * filterBuf1.a) + (final.b * (8 - filterBuf1.a))) >> 3; *out = (final.r << 11) + (final.g << 6) + (final.b << 1) + 1; + #undef RGBA_BUF_SIZE } void func_80027600(Color_RGBA8* arg0, s16* out) { + #define RGBA_SIZE_BUF 32 Color_RGBA8 final; - u8 rs[0x20]; - u8 gs[0x20]; - u8 bs[0x20]; + u8 rs[RGBA_SIZE_BUF]; + u8 gs[RGBA_SIZE_BUF]; + u8 bs[RGBA_SIZE_BUF]; s32 i; s32 sum; - for (i = 0; i < ARRAY_COUNT(rs); i++) { + for (i = 0; i < RGBA_SIZE_BUF; i++) { rs[i] = 0; gs[i] = 0; bs[i] = 0; @@ -177,7 +180,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { } sum = 0; - for (i = 0; i < ARRAY_COUNT(rs); i++) { + for (i = 0; i < RGBA_SIZE_BUF; i++) { sum += rs[i]; if (sum >= 5) { break; @@ -186,7 +189,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { final.r = i; sum = 0; - for (i = 0; i < ARRAY_COUNT(gs); i++) { + for (i = 0; i < RGBA_SIZE_BUF; i++) { sum += gs[i]; if (sum >= 5) { break; @@ -195,7 +198,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { final.g = i; sum = 0; - for (i = 0; i < ARRAY_COUNT(bs); i++) { + for (i = 0; i < RGBA_SIZE_BUF; i++) { sum += bs[i]; if (sum >= 5) { break; @@ -204,6 +207,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { final.b = i; *out = (final.r << 11) + (final.g << 6) + (final.b << 1) + 1; + #undef RGBA_SIZE_BUF } void func_80027774(u16* frameBuffer0, u16* frameBuffer1, u16* zBuffer) { diff --git a/src/battle/action_cmd/tidal_wave.c b/src/battle/action_cmd/tidal_wave.c index 00b131a133b..4455922d828 100644 --- a/src/battle/action_cmd/tidal_wave.c +++ b/src/battle/action_cmd/tidal_wave.c @@ -37,7 +37,7 @@ API_CALLABLE(N(init)) { hud_element_set_render_depth(id, 0); hud_element_set_flags(id, HUD_ELEMENT_FLAG_80 | HUD_ELEMENT_FLAG_DISABLED); - for (i = 1; i < 15; i++) { + for (i = 1; i < ARRAY_COUNT(actionCommandStatus->hudElements) - 1; i++) { id = hud_element_create(&HES_AButton); actionCommandStatus->hudElements[i] = id; hud_element_set_render_pos(id, actionCommandStatus->hudPosX, actionCommandStatus->hudPosY); @@ -298,7 +298,7 @@ void N(update)(void) { void N(draw)(void) { s32 i; - for (i = 1; i < 15; i++) { + for (i = 1; i < ARRAY_COUNT(gActionCommandStatus.hudElements) - 1; i++) { hud_element_draw_clipped(gActionCommandStatus.hudElements[i]); } } @@ -308,7 +308,7 @@ void N(free)(void) { hud_element_free(gActionCommandStatus.hudElements[0]); - for (i = 1; i < 15; i++) { + for (i = 1; i < ARRAY_COUNT(gActionCommandStatus.hudElements) - 1; i++) { hud_element_free(gActionCommandStatus.hudElements[i]); } } diff --git a/src/battle/area/sam2/actor/monstar.c b/src/battle/area/sam2/actor/monstar.c index 1cc95ed2f71..e82261e60b4 100644 --- a/src/battle/area/sam2/actor/monstar.c +++ b/src/battle/area/sam2/actor/monstar.c @@ -158,12 +158,13 @@ ImgFXOverlayTexture N(MonstarDetailTexture) = { }; API_CALLABLE(N(UpdateMonstarImgFX)) { + #define RGBA_BUF_SIZE 20 ActorPart* part = get_actor_part(get_actor(script->owner1.actorID), 1); s32 i; - u8 colR[20]; - u8 colG[20]; - u8 colB[20]; - u8 colA[20]; + u8 colR[RGBA_BUF_SIZE]; + u8 colG[RGBA_BUF_SIZE]; + u8 colB[RGBA_BUF_SIZE]; + u8 colA[RGBA_BUF_SIZE]; if (isInitialCall) { script->functionTemp[1] = 0; @@ -178,17 +179,18 @@ API_CALLABLE(N(UpdateMonstarImgFX)) { script->functionTemp[1] %= 360; } - for (i = 0; i < 20; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { colR[i] = (cosine(script->functionTemp[1] + i * 25) + 1.0) * 56.0; colG[i] = (cosine(script->functionTemp[1] + i * 25 + 45) + 1.0) * 56.0; colB[i] = (cosine(script->functionTemp[1] + i * 25 + 90) + 1.0) * 56.0; } - for (i = 0; i < 20; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { set_npc_imgfx_comp(part->spriteInstanceID, 0, IMGFX_COLOR_BUF_SET_MODULATE, i, colR[i] << 0x18 | colG[i] << 0x10 | colB[i] << 8 | 255, 0, 255, 0); } return ApiStatus_BLOCK; + #undef RGBA_BUF_SIZE } #include "common/Dist3D.inc.c" diff --git a/src/battle/btl_states_menus.c b/src/battle/btl_states_menus.c index ba635b0ad95..14e8c9732eb 100644 --- a/src/battle/btl_states_menus.c +++ b/src/battle/btl_states_menus.c @@ -4372,7 +4372,7 @@ void btl_state_update_partner_menu(void) { break; case BTL_SUBSTATE_PARTNER_MENU_CHANGE_PARTNER_1: popupIndex = 0; - for (i = 1; i < 12; i++) { + for (i = 1; i < ARRAY_COUNT(PartnerIDFromMenuIndex); i++) { s32 partnerId = PartnerIDFromMenuIndex[i]; if (playerData->partners[partnerId].enabled) { popupProps = &gPartnerPopupProperties[partnerId]; diff --git a/src/common/UpdateEnchantedBowserColors.inc.c b/src/common/UpdateEnchantedBowserColors.inc.c index f8e0778857c..b19673ff947 100644 --- a/src/common/UpdateEnchantedBowserColors.inc.c +++ b/src/common/UpdateEnchantedBowserColors.inc.c @@ -8,12 +8,13 @@ #endif API_CALLABLE(N(UpdateEnchantedBowserColors)) { + #define RGBA_BUF_SIZE 20 Actor* actor = get_actor(script->owner1.actorID); ActorPart* part; s32 i, j; - u8 colR[20]; - u8 colG[20]; - u8 colB[20]; + u8 colR[RGBA_BUF_SIZE]; + u8 colG[RGBA_BUF_SIZE]; + u8 colB[RGBA_BUF_SIZE]; s32 colorRGBA; s32 temp; s32 lol; @@ -39,7 +40,7 @@ API_CALLABLE(N(UpdateEnchantedBowserColors)) { script->functionTemp[1] %= 360; } - for (j = 0; j < 20; j++) { + for (j = 0; j < RGBA_BUF_SIZE; j++) { colR[j] = (cosine(script->functionTemp[1] + j * 25 + 120) + 1.0) * 56.0; colG[j] = (cosine(script->functionTemp[1] + j * 25 + 60) + 1.0) * 56.0; colB[j] = (cosine(script->functionTemp[1] + j * 25 + 180) + 1.0) * 56.0; @@ -47,7 +48,7 @@ API_CALLABLE(N(UpdateEnchantedBowserColors)) { if (part->eventFlags & BOWSER_FLAG_TOCHECK) { - for (j = 0; j < 20; j++) { + for (j = 0; j < RGBA_BUF_SIZE; j++) { colorRGBA = colR[j] << 0x18 | colG[j] << 0x10 | colB[j] << 8 | 0xFF; for (i = 0; i < 10; i++) { set_npc_imgfx_comp(part->spriteInstanceID, i, IMGFX_COLOR_BUF_SET_MODULATE, j, colorRGBA, 0, 255, 0); @@ -56,7 +57,7 @@ API_CALLABLE(N(UpdateEnchantedBowserColors)) { return ApiStatus_BLOCK; } else { s32 opacity = 255; - for (j = 0; j < 20; j++) { + for (j = 0; j < RGBA_BUF_SIZE; j++) { colorRGBA = 255; for (i = 0; i < 10; i++) { // TODO find better match for opacity @@ -68,4 +69,5 @@ API_CALLABLE(N(UpdateEnchantedBowserColors)) { script->functionTemp[0] = 0; return ApiStatus_BLOCK; } + #undef RGBA_BUF_SIZE } diff --git a/src/draw_box.c b/src/draw_box.c index 141972cdcf0..96214df527d 100644 --- a/src/draw_box.c +++ b/src/draw_box.c @@ -474,8 +474,8 @@ s32 draw_box(s32 flags, WindowStyle windowStyle, s32 posX, s32 posY, s32 posZ, s guMtxCatF(mtx2, rotScaleMtx, mtx1); } if (outMtx) { - for (i = 0; i < 4; i++) { - for (j = 0; j < 4; j++) { + for (i = 0; i < COUNT_ROWS(mtx1); i++) { + for (j = 0; j < COUNT_COLS(mtx1); j++) { outMtx[i][j] = mtx1[i][j]; } } diff --git a/src/effects/firework_rocket.c b/src/effects/firework_rocket.c index bd9627ab65d..735618c119a 100644 --- a/src/effects/firework_rocket.c +++ b/src/effects/firework_rocket.c @@ -124,7 +124,7 @@ EffectInstance* firework_rocket_main(s32 variation, f32 centerX, f32 centerY, f3 data->unk_3C = 150; data->unk_40 = 255; - for (i = 0; i < 4; i++) { + for (i = 0; i < ROCKET_BUF_SIZE; i++) { data->rocketX[i] = data->pos.x; data->rocketY[i] = data->pos.y - 1000.0f; data->rocketZ[i] = data->pos.z; @@ -189,7 +189,7 @@ void firework_rocket_update(EffectInstance* effect) { data->rocketVelY[i] = (rand_int(10) - 5) * 0.1f; data->rocketVelZ[i] = (rand_int(10) - 5) * 0.1f; - for (i = 0; i < 4; i++) { + for (i = 0; i < ROCKET_BUF_SIZE; i++) { data->rocketX[i] += data->rocketVelX[i]; data->rocketY[i] += data->rocketVelY[i]; data->rocketZ[i] += data->rocketVelZ[i]; diff --git a/src/effects/motion_blur_flame.c b/src/effects/motion_blur_flame.c index 506e9b72ca1..d3200a2c3e1 100644 --- a/src/effects/motion_blur_flame.c +++ b/src/effects/motion_blur_flame.c @@ -157,7 +157,7 @@ void motion_blur_flame_appendGfx(void* effect) { gSPSegment(gMainGfxPos++, 0x09, VIRTUAL_TO_PHYSICAL(((EffectInstance*)effect)->graphics->data)); gSPDisplayList(gMainGfxPos++, D_E00A29D0[temp_a2]); - for (i = 0; i < 4; i++) { + for (i = 0; i < Unk_Array_Size1; i++) { f32 temp_f12 = data->unk_1C[i]; f32 temp_f14 = data->unk_2C[i]; f32 temp_f0 = data->unk_3C[i]; diff --git a/src/effects/quizmo_audience.c b/src/effects/quizmo_audience.c index 4e2f0f0e286..0d9e22277b7 100644 --- a/src/effects/quizmo_audience.c +++ b/src/effects/quizmo_audience.c @@ -103,7 +103,7 @@ EffectInstance* quizmo_audience_main(s32 arg0, f32 posX, f32 posY, f32 posZ) { data->pos.z = posZ; data->lifeTime = 0; - for(i = 0; i < 10; i++) { + for (i = 0; i < ARRAY_COUNT(data->compState); i++) { data->compState[i] = 0; data->compX[i] = data->compY[i] = 0.0f; } diff --git a/src/effects/sun.c b/src/effects/sun.c index 4b171d9e736..4b74c5cd401 100644 --- a/src/effects/sun.c +++ b/src/effects/sun.c @@ -118,7 +118,7 @@ void sun_update(EffectInstance* effect) { } } - for (i = 0; i < 5; i++) { + for (i = 0; i < ARRAY_COUNT(data->texScrollAmt); i++) { data->texScrollAmt[i] -= 4.0 * ((sin_deg((time * 2 + (20 * i))) * 0.01) + 0.05) * sin_deg(((f32) time * 0.25) + (SQ(i) * 20)); diff --git a/src/entity/default/BoardedFloor.c b/src/entity/default/BoardedFloor.c index 199f8a1b5d0..8867e32d242 100644 --- a/src/entity/default/BoardedFloor.c +++ b/src/entity/default/BoardedFloor.c @@ -21,7 +21,7 @@ void Entity_BoardedFloor_init_fragments(Entity* entity, Gfx** dlists, Mtx* matri entity->pos.y = data->inititalY; guTranslateF(mtxTrans, entity->pos.x, entity->pos.y, entity->pos.z); - for (i = 0; i < 12; i++) { + for (i = 0; i < FRAGMENT_BUF_SIZE - 1; i++) { guMtxL2F(mtxFragment, ENTITY_ADDR(entity, Mtx*, matrices++)); guMtxCatF(mtxTrans, mtxFragment, mtxFragment); data->fragmentPosX[i] = mtxFragment[3][0]; diff --git a/src/evt/evt.c b/src/evt/evt.c index beea879858e..4245085d34d 100644 --- a/src/evt/evt.c +++ b/src/evt/evt.c @@ -2040,14 +2040,14 @@ Bytecode* evt_find_label(Evt* script, s32 arg1) { return (Bytecode*) arg1; } - for (i = 0; i < 16; i++) { + for (i = 0; i < ARRAY_COUNT(script->labelIndices); i++) { if (script->labelIndices[i] == arg1) { ret = script->labelPositions[i]; break; } } - ASSERT(i < 16); + ASSERT(i < ARRAY_COUNT(script->labelIndices)); return ret; } diff --git a/src/npc.c b/src/npc.c index f99c5d528e0..24fe3daa013 100644 --- a/src/npc.c +++ b/src/npc.c @@ -1963,9 +1963,10 @@ void npc_remove_decoration_glow_behind(Npc* npc, s32 idx) { } void npc_update_decoration_charged(Npc* npc, s32 idx) { - u8 rbuf[20]; - u8 gbuf[20]; - u8 bbuf[20]; + #define RGBA_BUF_SIZE 20 + u8 rbuf[RGBA_BUF_SIZE]; + u8 gbuf[RGBA_BUF_SIZE]; + u8 bbuf[RGBA_BUF_SIZE]; s32 color; s32 alpha; s32 i; @@ -1980,18 +1981,19 @@ void npc_update_decoration_charged(Npc* npc, s32 idx) { npc->decorationGlowPhase[idx] %= 360; } - for (i = 0; i < 20; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { rbuf[i] = (cosine(npc->decorationGlowPhase[idx] + (25 * i)) + 1.0) * 80.0f; gbuf[i] = (cosine(npc->decorationGlowPhase[idx] + (25 * i) + 45) + 1.0) * 80.0f; bbuf[i] = (cosine(npc->decorationGlowPhase[idx] + (25 * i) + 90) + 1.0) * 80.0f; } alpha = 255; - for (i = 0; i < 20; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { color = (rbuf[i] << 24) | (gbuf[i] << 16) | (bbuf[i] << 8) | alpha; set_npc_imgfx_all(npc->spriteInstanceID, IMGFX_COLOR_BUF_SET_MODULATE, i, color, 0, 255, 0); } } + #undef RGBA_BUF_SIZE } void npc_remove_decoration_charged(Npc* npc, s32 idx) { diff --git a/src/pause/pause_partners.c b/src/pause/pause_partners.c index c20d1e09f63..00020419a93 100644 --- a/src/pause/pause_partners.c +++ b/src/pause/pause_partners.c @@ -418,7 +418,7 @@ void pause_partners_draw_contents(MenuPanel* menu, s32 baseX, s32 baseY, s32 wid portraitOffsetX *= 0.01; portraitIndex = portraitScrollIndex; pause_partners_load_portrait(portraitIndex % gPausePartnersNumPartners); - for (i = 0; i < 2; portraitOffsetX += 150, i++) { + for (i = 0; i < ARRAY_COUNT(gPausePartnersPaletteBuffers); portraitOffsetX += 150, i++) { gSPDisplayList(gMainGfxPos++, &gPausePartnersDL); gDPLoadTLUT_pal256(gMainGfxPos++, gPausePartnersPaletteBuffers[i]); diff --git a/src/world/area_mac/mac_01/npc/post_office.inc.c b/src/world/area_mac/mac_01/npc/post_office.inc.c index b765b21e4d4..d30769e2a40 100644 --- a/src/world/area_mac/mac_01/npc/post_office.inc.c +++ b/src/world/area_mac/mac_01/npc/post_office.inc.c @@ -91,7 +91,7 @@ API_CALLABLE(N(func_80245028_8058A8)) { if (isInitialCall) { numEntries = 0; - for (i = 1; i < 12; i++) { + for (i = 1; i < ARRAY_COUNT(PartnerIDFromMenuIndex); i++) { partnerID = PartnerIDFromMenuIndex[i]; if (playerData->partners[partnerID].enabled && partnerID != PARTNER_GOOMPA) { temp_s2 = &gPartnerPopupProperties[partnerID]; diff --git a/src/world/area_sam/sam_05/sam_05_4_npc.c b/src/world/area_sam/sam_05/sam_05_4_npc.c index 0834ac5e65f..2044b0f7fbf 100644 --- a/src/world/area_sam/sam_05/sam_05_4_npc.c +++ b/src/world/area_sam/sam_05/sam_05_4_npc.c @@ -60,12 +60,13 @@ ImgFXOverlayTexture N(MonstarDetailTexture) = { }; API_CALLABLE(N(UpdateMonstarSpriteEffects)) { + #define RGBA_BUF_SIZE 20 Enemy* enemy = script->owner1.enemy; Npc* npc = get_npc_unsafe(enemy->npcID); - u8 sp20[20]; - u8 sp38[20]; - u8 sp50[20]; - u8 sp68[20]; + u8 rbuf[RGBA_BUF_SIZE]; + u8 gbuf[RGBA_BUF_SIZE]; + u8 bbuf[RGBA_BUF_SIZE]; + u8 abuf[RGBA_BUF_SIZE]; s32 i; if (isInitialCall) { @@ -84,13 +85,14 @@ API_CALLABLE(N(UpdateMonstarSpriteEffects)) { script->functionTemp[0] %= 360; } - for (i = 0; i < 20; i++) { - sp20[i] = (cosine(script->functionTemp[0] + (i * 25)) + 1.0) * 56.0; - sp38[i] = (cosine(script->functionTemp[0] + (i * 25) + 45) + 1.0) * 56.0; - sp50[i] = (cosine(script->functionTemp[0] + (i * 25) + 90) + 1.0) * 56.0; - sp68[i] = enemy->varTable[3]; + for (i = 0; i < RGBA_BUF_SIZE; i++) { + rbuf[i] = (cosine(script->functionTemp[0] + (i * 25)) + 1.0) * 56.0; + gbuf[i] = (cosine(script->functionTemp[0] + (i * 25) + 45) + 1.0) * 56.0; + bbuf[i] = (cosine(script->functionTemp[0] + (i * 25) + 90) + 1.0) * 56.0; + abuf[i] = enemy->varTable[3]; - set_npc_imgfx_comp(npc->spriteInstanceID, 0, IMGFX_COLOR_BUF_SET_MODULATE, i, (sp20[i] << 24) | (sp38[i] << 16) | (sp50[i] << 8) | sp68[i], 0, 255, 0); + set_npc_imgfx_comp(npc->spriteInstanceID, 0, IMGFX_COLOR_BUF_SET_MODULATE, i, + (rbuf[i] << 24) | (gbuf[i] << 16) | (bbuf[i] << 8) | abuf[i], 0, 255, 0); } if (enemy->varTable[3] == 255) { @@ -98,7 +100,8 @@ API_CALLABLE(N(UpdateMonstarSpriteEffects)) { set_npc_imgfx_comp(npc->spriteInstanceID, 1, IMGFX_OVERLAY, (s32) &N(MonstarDetailTexture), 255, 0, 255, 0); } else { npc->renderMode = RENDER_MODE_SURFACE_XLU_LAYER2; - set_npc_imgfx_comp(npc->spriteInstanceID, 1, IMGFX_OVERLAY, (s32) &N(MonstarDetailTexture), enemy->varTable[3], 0, enemy->varTable[3], 0); + set_npc_imgfx_comp(npc->spriteInstanceID, 1, IMGFX_OVERLAY, (s32) &N(MonstarDetailTexture), + enemy->varTable[3], 0, enemy->varTable[3], 0); } return ApiStatus_BLOCK; } From 3bf973a9888f2347eead6a8681d7026776791e38 Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 05:50:13 -0600 Subject: [PATCH 6/9] fix inconsistent RGBA_BUF_SIZE naming --- src/background_gfx.c | 18 +++++++++--------- src/battle/area/sam2/actor/monstar.c | 1 + src/common/UpdateEnchantedBowserColors.inc.c | 1 + src/world/area_sam/sam_05/sam_05_4_npc.c | 2 ++ 4 files changed, 13 insertions(+), 9 deletions(-) diff --git a/src/background_gfx.c b/src/background_gfx.c index 55253c1fb41..9bd45ea8eef 100644 --- a/src/background_gfx.c +++ b/src/background_gfx.c @@ -157,15 +157,15 @@ void gfx_frame_filter_pass_1(Color_RGBA8* filterBuf0, Color_RGBA8 filterBuf1, u1 } void func_80027600(Color_RGBA8* arg0, s16* out) { - #define RGBA_SIZE_BUF 32 + #define RGBA_BUF_SIZE 32 Color_RGBA8 final; - u8 rs[RGBA_SIZE_BUF]; - u8 gs[RGBA_SIZE_BUF]; - u8 bs[RGBA_SIZE_BUF]; + u8 rs[RGBA_BUF_SIZE]; + u8 gs[RGBA_BUF_SIZE]; + u8 bs[RGBA_BUF_SIZE]; s32 i; s32 sum; - for (i = 0; i < RGBA_SIZE_BUF; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { rs[i] = 0; gs[i] = 0; bs[i] = 0; @@ -178,7 +178,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { } sum = 0; - for (i = 0; i < RGBA_SIZE_BUF; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { sum += rs[i]; if (sum >= 5) { break; @@ -187,7 +187,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { final.r = i; sum = 0; - for (i = 0; i < RGBA_SIZE_BUF; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { sum += gs[i]; if (sum >= 5) { break; @@ -196,7 +196,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { final.g = i; sum = 0; - for (i = 0; i < RGBA_SIZE_BUF; i++) { + for (i = 0; i < RGBA_BUF_SIZE; i++) { sum += bs[i]; if (sum >= 5) { break; @@ -205,7 +205,7 @@ void func_80027600(Color_RGBA8* arg0, s16* out) { final.b = i; *out = (final.r << 11) + (final.g << 6) + (final.b << 1) + 1; - #undef RGBA_SIZE_BUF + #undef RGBA_BUF_SIZE } void func_80027774(u16* frameBuffer0, u16* frameBuffer1, u16* zBuffer) { diff --git a/src/battle/area/sam2/actor/monstar.c b/src/battle/area/sam2/actor/monstar.c index e82261e60b4..d4d71bfa38f 100644 --- a/src/battle/area/sam2/actor/monstar.c +++ b/src/battle/area/sam2/actor/monstar.c @@ -190,6 +190,7 @@ API_CALLABLE(N(UpdateMonstarImgFX)) { } return ApiStatus_BLOCK; + #undef RGBA_BUF_SIZE } diff --git a/src/common/UpdateEnchantedBowserColors.inc.c b/src/common/UpdateEnchantedBowserColors.inc.c index b19673ff947..132fe203bea 100644 --- a/src/common/UpdateEnchantedBowserColors.inc.c +++ b/src/common/UpdateEnchantedBowserColors.inc.c @@ -69,5 +69,6 @@ API_CALLABLE(N(UpdateEnchantedBowserColors)) { script->functionTemp[0] = 0; return ApiStatus_BLOCK; } + #undef RGBA_BUF_SIZE } diff --git a/src/world/area_sam/sam_05/sam_05_4_npc.c b/src/world/area_sam/sam_05/sam_05_4_npc.c index 2044b0f7fbf..83dfcc73272 100644 --- a/src/world/area_sam/sam_05/sam_05_4_npc.c +++ b/src/world/area_sam/sam_05/sam_05_4_npc.c @@ -104,6 +104,8 @@ API_CALLABLE(N(UpdateMonstarSpriteEffects)) { enemy->varTable[3], 0, enemy->varTable[3], 0); } return ApiStatus_BLOCK; + + #undef RGBA_BUF_SIZE } API_CALLABLE(N(CheckSkipInput)) { From 2ce1730a85429307d7e369bc2f3e9f8fb7266ac2 Mon Sep 17 00:00:00 2001 From: Rainchus Date: Tue, 5 Mar 2024 14:32:19 -0600 Subject: [PATCH 7/9] requested macro changes --- include/effects.h | 8 ++++---- include/macros.h | 3 --- src/audio/28910_len_5090.c | 2 +- src/battle/battle.h | 2 +- src/draw_box.c | 4 ++-- src/effects/motion_blur_flame.c | 2 +- 6 files changed, 9 insertions(+), 12 deletions(-) diff --git a/include/effects.h b/include/effects.h index f6ca9260db9..82242ab5417 100644 --- a/include/effects.h +++ b/include/effects.h @@ -1370,7 +1370,7 @@ typedef struct RadiatingEnergyOrbFXData { /* 0x30 */ f32 unk_30; } RadiatingEnergyOrbFXData; // size = 0x34 -#define Unk_Array_Size1 4 +#define UNK_ARRAY_SIZE_1 4 typedef struct MotionBlurFlameFXData { /* 0x00 */ s32 unk_00; @@ -1378,9 +1378,9 @@ typedef struct MotionBlurFlameFXData { /* 0x08 */ f32 unk_08; /* 0x0C */ f32 unk_0C; /* 0x10 */ Vec3f pos; - /* 0x1C */ f32 unk_1C[Unk_Array_Size1]; - /* 0x2C */ f32 unk_2C[Unk_Array_Size1]; - /* 0x3C */ f32 unk_3C[Unk_Array_Size1]; + /* 0x1C */ f32 unk_1C[UNK_ARRAY_SIZE_1]; + /* 0x2C */ f32 unk_2C[UNK_ARRAY_SIZE_1]; + /* 0x3C */ f32 unk_3C[UNK_ARRAY_SIZE_1]; /* 0x4C */ s32 unk_4C; /* 0x50 */ s32 unk_50; /* 0x54 */ s32 unk_54; diff --git a/include/macros.h b/include/macros.h index 00eb429e534..a46cf02bd5c 100644 --- a/include/macros.h +++ b/include/macros.h @@ -46,9 +46,6 @@ #define ARRAY_COUNT(arr) (s32)(sizeof(arr) / sizeof(arr[0])) -#define COUNT_ROWS(matrix) (s32)(sizeof(matrix) / sizeof(matrix[0])) -#define COUNT_COLS(matrix) (s32)(sizeof(matrix[0]) / sizeof(matrix[0][0])) - #if !defined(PERMUTER) && !defined(M2CTX) && defined(OLD_GCC) #define NOP_FIX __asm__(".set nogpopt"); #define NOP_UNFIX __asm__(".set gpopt"); diff --git a/src/audio/28910_len_5090.c b/src/audio/28910_len_5090.c index f8ac824f7e4..1d9926d5ad3 100644 --- a/src/audio/28910_len_5090.c +++ b/src/audio/28910_len_5090.c @@ -809,7 +809,7 @@ void func_8004E844(BGMPlayer* player, s32 arg1) { u16* temp = player->unk_174[arg1]; player->unk_212[arg1] = 0; - for (i = 0; i < COUNT_COLS(player->unk_174); i++) { + for (i = 0; i < 9; i++) { *temp++ = 0xFF00; } } diff --git a/src/battle/battle.h b/src/battle/battle.h index 0c3b7ff677f..52e11279e86 100644 --- a/src/battle/battle.h +++ b/src/battle/battle.h @@ -252,7 +252,7 @@ typedef struct PlayerCelebrationAnimOptions { /* 0x00 */ s16 randomChance; /* 0x02 */ s16 hpBasedChance; /* 0x04 */ s32 options[80]; -} PlayerCelebrationAnimOptions; // size = 0x8 +} PlayerCelebrationAnimOptions; // size = 0x144 #ifndef NO_EXTERN_VARIABLES diff --git a/src/draw_box.c b/src/draw_box.c index 989370d7903..3602ab8363b 100644 --- a/src/draw_box.c +++ b/src/draw_box.c @@ -474,8 +474,8 @@ s32 draw_box(s32 flags, WindowStyle windowStyle, s32 posX, s32 posY, s32 posZ, s guMtxCatF(mtx2, rotScaleMtx, mtx1); } if (outMtx) { - for (i = 0; i < COUNT_ROWS(mtx1); i++) { - for (j = 0; j < COUNT_COLS(mtx1); j++) { + for (i = 0; i < 4; i++) { + for (j = 0; j < 4; j++) { outMtx[i][j] = mtx1[i][j]; } } diff --git a/src/effects/motion_blur_flame.c b/src/effects/motion_blur_flame.c index d3200a2c3e1..d21c29086d9 100644 --- a/src/effects/motion_blur_flame.c +++ b/src/effects/motion_blur_flame.c @@ -157,7 +157,7 @@ void motion_blur_flame_appendGfx(void* effect) { gSPSegment(gMainGfxPos++, 0x09, VIRTUAL_TO_PHYSICAL(((EffectInstance*)effect)->graphics->data)); gSPDisplayList(gMainGfxPos++, D_E00A29D0[temp_a2]); - for (i = 0; i < Unk_Array_Size1; i++) { + for (i = 0; i < UNK_ARRAY_SIZE_1; i++) { f32 temp_f12 = data->unk_1C[i]; f32 temp_f14 = data->unk_2C[i]; f32 temp_f0 = data->unk_3C[i]; From c2580244828a2f36edf17a773ef3ec3a95e12e0f Mon Sep 17 00:00:00 2001 From: Rainchus Date: Sat, 9 Mar 2024 11:27:31 -0600 Subject: [PATCH 8/9] unhardcode 64 in pause_badges.c --- src/pause/pause_badges.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pause/pause_badges.c b/src/pause/pause_badges.c index 1d21ba2231f..6554df0a0e1 100644 --- a/src/pause/pause_badges.c +++ b/src/pause/pause_badges.c @@ -420,7 +420,7 @@ void pause_badges_draw_contents(MenuPanel* menu, s32 baseX, s32 baseY, s32 width posY = pause_badges_get_pos_y(pageIndex, itemIndex); isNone = badgeID == BADGE_NONE_STANDIN; - for (j = 0; j < 64; equippedBadges++, j++) { + for (j = 0; j < ARRAY_COUNT(gPlayerData.equippedBadges); equippedBadges++, j++) { if (badgeID == *equippedBadges) { isEquipped = TRUE; break; From 4f2220d44c8d4ae76f599e2eeae9a7ab38210f09 Mon Sep 17 00:00:00 2001 From: Rainchus Date: Fri, 19 Apr 2024 00:53:38 -0500 Subject: [PATCH 9/9] remove hardcoding of 3 move IDs in battle/sushie.c --- src/battle/partner/sushie.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/battle/partner/sushie.c b/src/battle/partner/sushie.c index 3c37c2f9aba..c9f0a3530be 100644 --- a/src/battle/partner/sushie.c +++ b/src/battle/partner/sushie.c @@ -818,7 +818,7 @@ EvtScript N(bellyFlop) = { Else Call(GetMenuSelection, LVar0, LVar1, LVar2) Switch(LVar2) - CaseEq(167) + CaseEq(MOVE_BELLY_FLOP1) Wait(13) Call(SetActorScale, ACTOR_PARTNER, Float(1.0), Float(1.0), Float(1.0)) Wait(1) @@ -829,7 +829,7 @@ EvtScript N(bellyFlop) = { Call(SetActorScale, ACTOR_PARTNER, Float(1.0), Float(1.0), Float(1.0)) Wait(1) Call(SetActorScale, ACTOR_PARTNER, Float(1.0), Float(1.0), Float(1.0)) - CaseEq(168) + CaseEq(MOVE_BELLY_FLOP2) Wait(13) Call(SetActorScale, ACTOR_PARTNER, Float(1.05), Float(1.05), Float(1.0)) Wait(1) @@ -840,7 +840,7 @@ EvtScript N(bellyFlop) = { Call(SetActorScale, ACTOR_PARTNER, Float(1.2), Float(1.2), Float(1.0)) Wait(1) Call(SetActorScale, ACTOR_PARTNER, Float(1.25), Float(1.25), Float(1.0)) - CaseEq(169) + CaseEq(MOVE_BELLY_FLOP3) Wait(13) Call(SetActorScale, ACTOR_PARTNER, Float(1.1), Float(1.1), Float(1.0)) Wait(1)