Add FIRST_BALL, some FIRST_BERRY_INDEX usage

This commit is contained in:
GriffinR 2021-01-19 13:39:18 -05:00
parent 305ebdbc4a
commit 752982552e
5 changed files with 39 additions and 34 deletions

View File

@ -17,7 +17,11 @@
#define ITEM_LUXURY_BALL 11 #define ITEM_LUXURY_BALL 11
#define ITEM_PREMIER_BALL 12 #define ITEM_PREMIER_BALL 12
#define LAST_BALL ITEM_PREMIER_BALL // Note: If moving ball IDs around, updating FIRST_BALL/LAST_BALL is not sufficient
// Several places expect the ball IDs to be first and contiguous (e.g. gBattlescriptsForBallThrow and MON_DATA_POKEBALL)
// If adding new balls, it's easiest to insert them after the last ball and increment the below IDs (and removing ITEM_034 for example)
#define FIRST_BALL ITEM_MASTER_BALL
#define LAST_BALL ITEM_PREMIER_BALL
// Pokemon Items // Pokemon Items
#define ITEM_POTION 13 #define ITEM_POTION 13
@ -145,6 +149,8 @@
#define ITEM_FAB_MAIL 131 #define ITEM_FAB_MAIL 131
#define ITEM_RETRO_MAIL 132 #define ITEM_RETRO_MAIL 132
#define FIRST_MAIL_INDEX ITEM_ORANGE_MAIL
// Berries // Berries
#define ITEM_CHERI_BERRY 133 #define ITEM_CHERI_BERRY 133
#define ITEM_CHESTO_BERRY 134 #define ITEM_CHESTO_BERRY 134
@ -189,6 +195,10 @@
#define ITEM_LANSAT_BERRY 173 #define ITEM_LANSAT_BERRY 173
#define ITEM_STARF_BERRY 174 #define ITEM_STARF_BERRY 174
#define ITEM_ENIGMA_BERRY 175 #define ITEM_ENIGMA_BERRY 175
#define FIRST_BERRY_INDEX ITEM_CHERI_BERRY
#define LAST_BERRY_INDEX ITEM_ENIGMA_BERRY
#define ITEM_0B0 176 #define ITEM_0B0 176
#define ITEM_0B1 177 #define ITEM_0B1 177
#define ITEM_0B2 178 #define ITEM_0B2 178
@ -467,9 +477,6 @@
#define ITEMS_COUNT 377 #define ITEMS_COUNT 377
#define ITEM_FIELD_ARROW ITEMS_COUNT #define ITEM_FIELD_ARROW ITEMS_COUNT
#define FIRST_BERRY_INDEX ITEM_CHERI_BERRY
#define LAST_BERRY_INDEX ITEM_ENIGMA_BERRY
// Range of berries given out by various NPCS // Range of berries given out by various NPCS
#define FIRST_BERRY_MASTER_BERRY ITEM_POMEG_BERRY #define FIRST_BERRY_MASTER_BERRY ITEM_POMEG_BERRY
#define LAST_BERRY_MASTER_BERRY ITEM_NOMEL_BERRY #define LAST_BERRY_MASTER_BERRY ITEM_NOMEL_BERRY
@ -490,8 +497,6 @@
#define ITEM_TO_BERRY(itemId)(((itemId - FIRST_BERRY_INDEX) + 1)) #define ITEM_TO_BERRY(itemId)(((itemId - FIRST_BERRY_INDEX) + 1))
#define FIRST_MAIL_INDEX ITEM_ORANGE_MAIL
#define NUM_TECHNICAL_MACHINES 50 #define NUM_TECHNICAL_MACHINES 50
#define NUM_HIDDEN_MACHINES 8 #define NUM_HIDDEN_MACHINES 8

View File

@ -877,7 +877,7 @@ void StartBerryCrush(MainCallback callback)
static void GetBerryFromBag(void) static void GetBerryFromBag(void)
{ {
if (gSpecialVar_ItemId < FIRST_BERRY_INDEX || gSpecialVar_ItemId > LAST_BERRY_INDEX + 1) if (gSpecialVar_ItemId < FIRST_BERRY_INDEX || gSpecialVar_ItemId > LAST_BERRY_INDEX + 1)
gSpecialVar_ItemId = ITEM_CHERI_BERRY; gSpecialVar_ItemId = FIRST_BERRY_INDEX;
else else
RemoveBagItem(gSpecialVar_ItemId, 1); RemoveBagItem(gSpecialVar_ItemId, 1);

View File

@ -20,10 +20,10 @@ const struct Item gItems[] =
.price = 0, .price = 0,
.description = sMasterBallDesc, .description = sMasterBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_MASTER_BALL - 1, .type = ITEM_MASTER_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_MASTER_BALL - 1, .secondaryId = ITEM_MASTER_BALL - FIRST_BALL,
}, },
[ITEM_ULTRA_BALL] = [ITEM_ULTRA_BALL] =
@ -33,10 +33,10 @@ const struct Item gItems[] =
.price = 1200, .price = 1200,
.description = sUltraBallDesc, .description = sUltraBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_ULTRA_BALL - 1, .type = ITEM_ULTRA_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_ULTRA_BALL - 1, .secondaryId = ITEM_ULTRA_BALL - FIRST_BALL,
}, },
[ITEM_GREAT_BALL] = [ITEM_GREAT_BALL] =
@ -46,10 +46,10 @@ const struct Item gItems[] =
.price = 600, .price = 600,
.description = sGreatBallDesc, .description = sGreatBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_GREAT_BALL - 1, .type = ITEM_GREAT_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_GREAT_BALL - 1, .secondaryId = ITEM_GREAT_BALL - FIRST_BALL,
}, },
[ITEM_POKE_BALL] = [ITEM_POKE_BALL] =
@ -59,10 +59,10 @@ const struct Item gItems[] =
.price = 200, .price = 200,
.description = sPokeBallDesc, .description = sPokeBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_POKE_BALL - 1, .type = ITEM_POKE_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_POKE_BALL - 1, .secondaryId = ITEM_POKE_BALL - FIRST_BALL,
}, },
[ITEM_SAFARI_BALL] = [ITEM_SAFARI_BALL] =
@ -72,10 +72,10 @@ const struct Item gItems[] =
.price = 0, .price = 0,
.description = sSafariBallDesc, .description = sSafariBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_SAFARI_BALL - 1, .type = ITEM_SAFARI_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_SAFARI_BALL - 1, .secondaryId = ITEM_SAFARI_BALL - FIRST_BALL,
}, },
[ITEM_NET_BALL] = [ITEM_NET_BALL] =
@ -85,10 +85,10 @@ const struct Item gItems[] =
.price = 1000, .price = 1000,
.description = sNetBallDesc, .description = sNetBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_NET_BALL - 1, .type = ITEM_NET_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_NET_BALL - 1, .secondaryId = ITEM_NET_BALL - FIRST_BALL,
}, },
[ITEM_DIVE_BALL] = [ITEM_DIVE_BALL] =
@ -98,10 +98,10 @@ const struct Item gItems[] =
.price = 1000, .price = 1000,
.description = sDiveBallDesc, .description = sDiveBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_DIVE_BALL - 1, .type = ITEM_DIVE_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_DIVE_BALL - 1, .secondaryId = ITEM_DIVE_BALL - FIRST_BALL,
}, },
[ITEM_NEST_BALL] = [ITEM_NEST_BALL] =
@ -111,10 +111,10 @@ const struct Item gItems[] =
.price = 1000, .price = 1000,
.description = sNestBallDesc, .description = sNestBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_NEST_BALL - 1, .type = ITEM_NEST_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_NEST_BALL - 1, .secondaryId = ITEM_NEST_BALL - FIRST_BALL,
}, },
[ITEM_REPEAT_BALL] = [ITEM_REPEAT_BALL] =
@ -124,10 +124,10 @@ const struct Item gItems[] =
.price = 1000, .price = 1000,
.description = sRepeatBallDesc, .description = sRepeatBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_REPEAT_BALL - 1, .type = ITEM_REPEAT_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_REPEAT_BALL - 1, .secondaryId = ITEM_REPEAT_BALL - FIRST_BALL,
}, },
[ITEM_TIMER_BALL] = [ITEM_TIMER_BALL] =
@ -137,10 +137,10 @@ const struct Item gItems[] =
.price = 1000, .price = 1000,
.description = sTimerBallDesc, .description = sTimerBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_TIMER_BALL - 1, .type = ITEM_TIMER_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_TIMER_BALL - 1, .secondaryId = ITEM_TIMER_BALL - FIRST_BALL,
}, },
[ITEM_LUXURY_BALL] = [ITEM_LUXURY_BALL] =
@ -150,10 +150,10 @@ const struct Item gItems[] =
.price = 1000, .price = 1000,
.description = sLuxuryBallDesc, .description = sLuxuryBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_LUXURY_BALL - 1, .type = ITEM_LUXURY_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_LUXURY_BALL - 1, .secondaryId = ITEM_LUXURY_BALL - FIRST_BALL,
}, },
[ITEM_PREMIER_BALL] = [ITEM_PREMIER_BALL] =
@ -163,10 +163,10 @@ const struct Item gItems[] =
.price = 200, .price = 200,
.description = sPremierBallDesc, .description = sPremierBallDesc,
.pocket = POCKET_POKE_BALLS, .pocket = POCKET_POKE_BALLS,
.type = ITEM_PREMIER_BALL - 1, .type = ITEM_PREMIER_BALL - FIRST_BALL,
.battleUsage = ITEM_B_USE_OTHER, .battleUsage = ITEM_B_USE_OTHER,
.battleUseFunc = ItemUseInBattle_PokeBall, .battleUseFunc = ItemUseInBattle_PokeBall,
.secondaryId = ITEM_PREMIER_BALL - 1, .secondaryId = ITEM_PREMIER_BALL - FIRST_BALL,
}, },
// Medicine // Medicine

View File

@ -102,8 +102,8 @@ void CopyItemNameHandlePlural(u16 itemId, u8 *dst, u32 quantity)
} }
else else
{ {
if (itemId >= ITEM_CHERI_BERRY && itemId <= ITEM_ENIGMA_BERRY) if (itemId >= FIRST_BERRY_INDEX && itemId <= LAST_BERRY_INDEX)
GetBerryCountString(dst, gBerries[itemId - ITEM_CHERI_BERRY].name, quantity); GetBerryCountString(dst, gBerries[itemId - FIRST_BERRY_INDEX].name, quantity);
else else
StringCopy(dst, ItemId_GetName(itemId)); StringCopy(dst, ItemId_GetName(itemId));
} }

View File

@ -865,7 +865,7 @@ void GetItemName(s8 *dest, u16 itemId)
} }
break; break;
case BERRIES_POCKET: case BERRIES_POCKET:
ConvertIntToDecimalStringN(gStringVar1, itemId - ITEM_CHERI_BERRY + 1, STR_CONV_MODE_LEADING_ZEROS, 2); ConvertIntToDecimalStringN(gStringVar1, itemId - FIRST_BERRY_INDEX + 1, STR_CONV_MODE_LEADING_ZEROS, 2);
CopyItemName(itemId, gStringVar2); CopyItemName(itemId, gStringVar2);
StringExpandPlaceholders(dest, gText_NumberVar1Clear7Var2); StringExpandPlaceholders(dest, gText_NumberVar1Clear7Var2);
break; break;