mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-12-26 03:34:15 +01:00
document record mixing
This commit is contained in:
parent
b051cbaaab
commit
9e7965fab0
@ -3746,7 +3746,7 @@ _08163FF4:
|
|||||||
ldr r0, [r6]
|
ldr r0, [r6]
|
||||||
ldr r1, =0x0000064c
|
ldr r1, =0x0000064c
|
||||||
adds r0, r1
|
adds r0, r1
|
||||||
bl sub_8164F70
|
bl CalcEmeraldBattleTowerChecksum
|
||||||
bl sub_8163E90
|
bl sub_8163E90
|
||||||
pop {r3,r4}
|
pop {r3,r4}
|
||||||
mov r8, r3
|
mov r8, r3
|
||||||
@ -5484,8 +5484,8 @@ _08164F52:
|
|||||||
.pool
|
.pool
|
||||||
thumb_func_end sub_8164ED8
|
thumb_func_end sub_8164ED8
|
||||||
|
|
||||||
thumb_func_start sub_8164F70
|
thumb_func_start CalcEmeraldBattleTowerChecksum
|
||||||
sub_8164F70: @ 8164F70
|
CalcEmeraldBattleTowerChecksum: @ 8164F70
|
||||||
push {r4,lr}
|
push {r4,lr}
|
||||||
adds r2, r0, 0
|
adds r2, r0, 0
|
||||||
adds r2, 0xE8
|
adds r2, 0xE8
|
||||||
@ -5504,7 +5504,7 @@ _08164F7E:
|
|||||||
pop {r4}
|
pop {r4}
|
||||||
pop {r0}
|
pop {r0}
|
||||||
bx r0
|
bx r0
|
||||||
thumb_func_end sub_8164F70
|
thumb_func_end CalcEmeraldBattleTowerChecksum
|
||||||
|
|
||||||
thumb_func_start sub_8164F94
|
thumb_func_start sub_8164F94
|
||||||
sub_8164F94: @ 8164F94
|
sub_8164F94: @ 8164F94
|
||||||
@ -6750,7 +6750,7 @@ _08165988:
|
|||||||
ldr r1, [sp, 0x10]
|
ldr r1, [sp, 0x10]
|
||||||
bl CpuSet
|
bl CpuSet
|
||||||
adds r0, r5, 0
|
adds r0, r5, 0
|
||||||
bl sub_8164F70
|
bl CalcEmeraldBattleTowerChecksum
|
||||||
movs r0, 0x1
|
movs r0, 0x1
|
||||||
_081659BE:
|
_081659BE:
|
||||||
add sp, 0x14
|
add sp, 0x14
|
||||||
|
@ -2431,8 +2431,8 @@ sub_80FAFF8: @ 80FAFF8
|
|||||||
.pool
|
.pool
|
||||||
thumb_func_end sub_80FAFF8
|
thumb_func_end sub_80FAFF8
|
||||||
|
|
||||||
thumb_func_start sub_80FB00C
|
thumb_func_start CreateRecordMixingSprite
|
||||||
sub_80FB00C: @ 80FB00C
|
CreateRecordMixingSprite: @ 80FB00C
|
||||||
push {r4,r5,lr}
|
push {r4,r5,lr}
|
||||||
ldr r0, =gUnknown_0858E864
|
ldr r0, =gUnknown_0858E864
|
||||||
bl LoadSpritePalette
|
bl LoadSpritePalette
|
||||||
@ -2478,10 +2478,10 @@ _080FB06E:
|
|||||||
pop {r4,r5}
|
pop {r4,r5}
|
||||||
pop {r1}
|
pop {r1}
|
||||||
bx r1
|
bx r1
|
||||||
thumb_func_end sub_80FB00C
|
thumb_func_end CreateRecordMixingSprite
|
||||||
|
|
||||||
thumb_func_start sub_80FB074
|
thumb_func_start DestroyRecordMixingSprite
|
||||||
sub_80FB074: @ 80FB074
|
DestroyRecordMixingSprite: @ 80FB074
|
||||||
push {r4-r7,lr}
|
push {r4-r7,lr}
|
||||||
ldr r4, =gSprites
|
ldr r4, =gSprites
|
||||||
adds r7, r4, 0
|
adds r7, r4, 0
|
||||||
@ -2509,6 +2509,6 @@ _080FB098:
|
|||||||
pop {r0}
|
pop {r0}
|
||||||
bx r0
|
bx r0
|
||||||
.pool
|
.pool
|
||||||
thumb_func_end sub_80FB074
|
thumb_func_end DestroyRecordMixingSprite
|
||||||
|
|
||||||
.align 2, 0 @ Don't pad with nop.
|
.align 2, 0 @ Don't pad with nop.
|
||||||
|
@ -1,5 +0,0 @@
|
|||||||
.set POCKET_ITEMS, 0x01
|
|
||||||
.set POCKET_POKE_BALLS, 0x02
|
|
||||||
.set POCKET_TM_HM, 0x03
|
|
||||||
.set POCKET_BERRIES, 0x04
|
|
||||||
.set BAG_KEYITEMS, 0x05
|
|
@ -1,7 +1,8 @@
|
|||||||
#ifndef GUARD_BATTLE_TOWER_H
|
#ifndef GUARD_BATTLE_TOWER_H
|
||||||
#define GUARD_BATTLE_TOWER_H
|
#define GUARD_BATTLE_TOWER_H
|
||||||
|
|
||||||
struct RSBattleTowerRecord {
|
struct RSBattleTowerRecord
|
||||||
|
{
|
||||||
/*0x00*/ u8 battleTowerLevelType; // 0 = level 50, 1 = level 100
|
/*0x00*/ u8 battleTowerLevelType; // 0 = level 50, 1 = level 100
|
||||||
/*0x01*/ u8 trainerClass;
|
/*0x01*/ u8 trainerClass;
|
||||||
/*0x02*/ u16 winStreak;
|
/*0x02*/ u16 winStreak;
|
||||||
@ -15,30 +16,16 @@ struct RSBattleTowerRecord {
|
|||||||
/*0xA4*/ u16 unk_11c8;
|
/*0xA4*/ u16 unk_11c8;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct EmeraldBattleTowerRecord {
|
union BattleTowerRecord
|
||||||
/*0x00*/ u8 battleTowerLevelType; // 0 = level 50, 1 = level 100
|
{
|
||||||
/*0x01*/ u8 trainerClass;
|
|
||||||
/*0x02*/ u16 winStreak;
|
|
||||||
/*0x04*/ u8 name[8];
|
|
||||||
/*0x0C*/ u8 trainerId[4];
|
|
||||||
/*0x10*/ struct {
|
|
||||||
u16 easyChat[6];
|
|
||||||
} greeting;
|
|
||||||
/*0x1C*/ u8 filler_1c[0x18];
|
|
||||||
/*0x34*/ struct UnknownPokemonStruct party[4];
|
|
||||||
/*0xe4*/ u8 language;
|
|
||||||
u8 filler_e5[7];
|
|
||||||
};
|
|
||||||
|
|
||||||
union BattleTowerRecord {
|
|
||||||
struct RSBattleTowerRecord ruby_sapphire;
|
struct RSBattleTowerRecord ruby_sapphire;
|
||||||
struct EmeraldBattleTowerRecord emerald;
|
struct EmeraldBattleTowerRecord emerald;
|
||||||
};
|
};
|
||||||
|
|
||||||
u16 sub_8164FCC(u8, u8);
|
u16 sub_8164FCC(u8, u8);
|
||||||
void sub_81659DC(union BattleTowerRecord *a0, union BattleTowerRecord *a1);
|
void sub_81659DC(struct RSBattleTowerRecord *a0, struct RSBattleTowerRecord *a1);
|
||||||
bool32 sub_816587C(union BattleTowerRecord *, union BattleTowerRecord *);
|
bool32 sub_816587C(union BattleTowerRecord *, union BattleTowerRecord *);
|
||||||
bool32 sub_8164F70(union BattleTowerRecord *);
|
void CalcEmeraldBattleTowerChecksum(struct EmeraldBattleTowerRecord *);
|
||||||
void sub_81628A0(union BattleTowerRecord *);
|
void sub_81628A0(union BattleTowerRecord *);
|
||||||
|
|
||||||
#endif //GUARD_BATTLE_TOWER_H
|
#endif //GUARD_BATTLE_TOWER_H
|
||||||
|
@ -9,8 +9,8 @@
|
|||||||
|
|
||||||
void sub_80FA5E4(s16 id, s16 x, s16 y);
|
void sub_80FA5E4(s16 id, s16 x, s16 y);
|
||||||
void sub_80FA794(s16 x, s16 y);
|
void sub_80FA794(s16 x, s16 y);
|
||||||
void sub_80FB00C(void);
|
void CreateRecordMixingSprite(void);
|
||||||
void sub_80FB074(void);
|
void DestroyRecordMixingSprite(void);
|
||||||
void overworld_poison_effect(void);
|
void overworld_poison_effect(void);
|
||||||
bool8 sub_80FADE4(u16, u8);
|
bool8 sub_80FADE4(u16, u8);
|
||||||
|
|
||||||
|
@ -103,6 +103,8 @@ enum LanguageId
|
|||||||
#define VARS_COUNT 256
|
#define VARS_COUNT 256
|
||||||
#define MAIL_COUNT 16
|
#define MAIL_COUNT 16
|
||||||
#define SECRET_BASES_COUNT 20
|
#define SECRET_BASES_COUNT 20
|
||||||
|
#define TV_SHOWS_COUNT 25
|
||||||
|
#define POKE_NEWS_COUNT 16
|
||||||
#define PC_ITEMS_COUNT 50
|
#define PC_ITEMS_COUNT 50
|
||||||
#define BAG_ITEMS_COUNT 30
|
#define BAG_ITEMS_COUNT 30
|
||||||
#define BAG_KEYITEMS_COUNT 30
|
#define BAG_KEYITEMS_COUNT 30
|
||||||
@ -263,6 +265,49 @@ struct UnkRecordMixingStruct
|
|||||||
u8 field_38[10];
|
u8 field_38[10];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct UnknownPokemonStruct
|
||||||
|
{
|
||||||
|
u16 species;
|
||||||
|
u16 heldItem;
|
||||||
|
u16 moves[4];
|
||||||
|
u8 level;
|
||||||
|
u8 ppBonuses;
|
||||||
|
u8 hpEV;
|
||||||
|
u8 attackEV;
|
||||||
|
u8 defenseEV;
|
||||||
|
u8 speedEV;
|
||||||
|
u8 spAttackEV;
|
||||||
|
u8 spDefenseEV;
|
||||||
|
u32 otId;
|
||||||
|
u32 hpIV:5;
|
||||||
|
u32 attackIV:5;
|
||||||
|
u32 defenseIV:5;
|
||||||
|
u32 speedIV:5;
|
||||||
|
u32 spAttackIV:5;
|
||||||
|
u32 spDefenseIV:5;
|
||||||
|
u32 gap:1;
|
||||||
|
u32 altAbility:1;
|
||||||
|
u32 personality;
|
||||||
|
u8 nickname[POKEMON_NAME_LENGTH + 1];
|
||||||
|
u8 friendship;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct EmeraldBattleTowerRecord
|
||||||
|
{
|
||||||
|
/*0x00*/ u8 battleTowerLevelType; // 0 = level 50, 1 = level 100
|
||||||
|
/*0x01*/ u8 trainerClass;
|
||||||
|
/*0x02*/ u16 winStreak;
|
||||||
|
/*0x04*/ u8 name[8];
|
||||||
|
/*0x0C*/ u8 trainerId[4];
|
||||||
|
/*0x10*/ struct {
|
||||||
|
u16 easyChat[6];
|
||||||
|
} greeting;
|
||||||
|
/*0x1C*/ u8 filler_1c[0x18];
|
||||||
|
/*0x34*/ struct UnknownPokemonStruct party[4];
|
||||||
|
/*0xE4*/ u8 language;
|
||||||
|
/*0xE8*/ u32 checksum;
|
||||||
|
};
|
||||||
|
|
||||||
struct SaveBlock2
|
struct SaveBlock2
|
||||||
{
|
{
|
||||||
/*0x00*/ u8 playerName[PLAYER_NAME_LENGTH];
|
/*0x00*/ u8 playerName[PLAYER_NAME_LENGTH];
|
||||||
@ -302,7 +347,7 @@ struct SaveBlock2
|
|||||||
|
|
||||||
// All below could be a one giant struct
|
// All below could be a one giant struct
|
||||||
|
|
||||||
/*0x64C*/ u8 field_64C[236];
|
/*0x64C*/ struct EmeraldBattleTowerRecord battleTower;
|
||||||
/*0x738*/ struct UnknownSaveBlock2Struct field_738[5]; // No idea here, it's probably wrong, no clue.
|
/*0x738*/ struct UnknownSaveBlock2Struct field_738[5]; // No idea here, it's probably wrong, no clue.
|
||||||
/*0xBD4*/ u16 field_BD4;
|
/*0xBD4*/ u16 field_BD4;
|
||||||
/*0xBD6*/ u16 field_BD6;
|
/*0xBD6*/ u16 field_BD6;
|
||||||
@ -763,8 +808,8 @@ struct SaveBlock1
|
|||||||
/*0x????*/ u8 decorDoll[40];
|
/*0x????*/ u8 decorDoll[40];
|
||||||
/*0x????*/ u8 decorCushion[10];
|
/*0x????*/ u8 decorCushion[10];
|
||||||
/*0x27CA*/ u8 padding_27CA[2];
|
/*0x27CA*/ u8 padding_27CA[2];
|
||||||
/*0x27CC*/ TVShow tvShows[25];
|
/*0x27CC*/ TVShow tvShows[TV_SHOWS_COUNT];
|
||||||
/*0x2B50*/ PokeNews pokeNews[16];
|
/*0x2B50*/ PokeNews pokeNews[POKE_NEWS_COUNT];
|
||||||
/*0x2B90*/ u16 outbreakPokemonSpecies;
|
/*0x2B90*/ u16 outbreakPokemonSpecies;
|
||||||
/*0x2B92*/ u8 outbreakLocationMapNum;
|
/*0x2B92*/ u8 outbreakLocationMapNum;
|
||||||
/*0x2B93*/ u8 outbreakLocationMapGroup;
|
/*0x2B93*/ u8 outbreakLocationMapGroup;
|
||||||
|
@ -19,8 +19,8 @@ void ScrSpecial_SetMauvilleOldManMapObjGfx(void);
|
|||||||
u8 sub_81201C8(void);
|
u8 sub_81201C8(void);
|
||||||
void sub_8120B70(OldMan *dest);
|
void sub_8120B70(OldMan *dest);
|
||||||
void sub_8120670(void);
|
void sub_8120670(void);
|
||||||
void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6);
|
void SanitizeReceivedRubyOldMan(union OldMan * oldMan, u32 r1, u32 r6);
|
||||||
void sub_8120CD0(union OldMan * oldMan, u32 unused, u32 a2);
|
void SanitizeReceivedEmeraldOldMan(union OldMan * oldMan, u32 unused, u32 a2);
|
||||||
void ResetMauvilleOldManFlag(void);
|
void ResetMauvilleOldManFlag(void);
|
||||||
|
|
||||||
#endif // GUARD_MAUVILLE_OLD_MAN_H
|
#endif // GUARD_MAUVILLE_OLD_MAN_H
|
||||||
|
@ -6,6 +6,5 @@ bool32 sub_8153884(u32 *a0);
|
|||||||
u32 RunMysteryEventScript(u8 *script);
|
u32 RunMysteryEventScript(u8 *script);
|
||||||
void SetMysteryEventScriptStatus(u32 val);
|
void SetMysteryEventScriptStatus(u32 val);
|
||||||
u16 GetRecordMixingGift(void);
|
u16 GetRecordMixingGift(void);
|
||||||
u16 GetRecordMixingGift(void);
|
|
||||||
|
|
||||||
#endif // GUARD_MYSTERY_EVENT_SCRIPT_H
|
#endif // GUARD_MYSTERY_EVENT_SCRIPT_H
|
||||||
|
@ -240,33 +240,6 @@ struct PokemonStorage
|
|||||||
/*0x83C2*/ u8 boxWallpapers[14];
|
/*0x83C2*/ u8 boxWallpapers[14];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct UnknownPokemonStruct
|
|
||||||
{
|
|
||||||
u16 species;
|
|
||||||
u16 heldItem;
|
|
||||||
u16 moves[4];
|
|
||||||
u8 level;
|
|
||||||
u8 ppBonuses;
|
|
||||||
u8 hpEV;
|
|
||||||
u8 attackEV;
|
|
||||||
u8 defenseEV;
|
|
||||||
u8 speedEV;
|
|
||||||
u8 spAttackEV;
|
|
||||||
u8 spDefenseEV;
|
|
||||||
u32 otId;
|
|
||||||
u32 hpIV:5;
|
|
||||||
u32 attackIV:5;
|
|
||||||
u32 defenseIV:5;
|
|
||||||
u32 speedIV:5;
|
|
||||||
u32 spAttackIV:5;
|
|
||||||
u32 spDefenseIV:5;
|
|
||||||
u32 gap:1;
|
|
||||||
u32 altAbility:1;
|
|
||||||
u32 personality;
|
|
||||||
u8 nickname[POKEMON_NAME_LENGTH + 1];
|
|
||||||
u8 friendship;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct UnknownPokemonSubStruct2
|
struct UnknownPokemonSubStruct2
|
||||||
{
|
{
|
||||||
u16 species;
|
u16 species;
|
||||||
|
@ -26,12 +26,10 @@ struct UnkRecordMixingStruct2
|
|||||||
struct UnkRecordMixingStruct2b field_120[2];
|
struct UnkRecordMixingStruct2b field_120[2];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Exported RAM declarations
|
// Exported RAM declarations
|
||||||
|
|
||||||
// Exported ROM declarations
|
// Exported ROM declarations
|
||||||
|
void sub_80E6BE8(void);
|
||||||
void sub_80E8260(struct UnkRecordMixingStruct2 *arg0);
|
void sub_80E8260(struct UnkRecordMixingStruct2 *arg0);
|
||||||
|
|
||||||
#endif //GUARD_RECORD_MIXING_H
|
#endif //GUARD_RECORD_MIXING_H
|
||||||
|
@ -16,7 +16,7 @@ void sub_80EED10(void);
|
|||||||
void sub_80EED34(void);
|
void sub_80EED34(void);
|
||||||
void sub_80EED60(u16 delta);
|
void sub_80EED60(u16 delta);
|
||||||
void sub_80F01B8(void);
|
void sub_80F01B8(void);
|
||||||
void sub_80F01E8(void *src, u32 size, u8 masterIdx);
|
void ReceiveTvShowsData(void *src, u32 size, u8 masterIdx);
|
||||||
void sub_80EE4DC(struct Pokemon *pokemon, u8 ribbonMonDataIdx);
|
void sub_80EE4DC(struct Pokemon *pokemon, u8 ribbonMonDataIdx);
|
||||||
u32 GetPlayerIDAsU32(void);
|
u32 GetPlayerIDAsU32(void);
|
||||||
bool8 GetPriceReduction(u8 newsKind);
|
bool8 GetPriceReduction(u8 newsKind);
|
||||||
@ -30,7 +30,7 @@ void sub_80EEA70(void);
|
|||||||
void sub_80EDB44(void);
|
void sub_80EDB44(void);
|
||||||
void sub_80EDC60(const u16 *words);
|
void sub_80EDC60(const u16 *words);
|
||||||
void sub_80EDA80(void);
|
void sub_80EDA80(void);
|
||||||
void sub_80F0C7C(void *src, u32 size, u8 masterIdx);
|
void ReceivePokeNewsData(void *src, u32 size, u8 masterIdx);
|
||||||
void sub_80F0BB8(void);
|
void sub_80F0BB8(void);
|
||||||
void sub_80ED950(bool8 flag);
|
void sub_80ED950(bool8 flag);
|
||||||
void sub_80EEC80(void);
|
void sub_80EEC80(void);
|
||||||
|
@ -47,7 +47,7 @@ extern void sub_81B9328(void);
|
|||||||
extern void CB2_ReturnToField(void);
|
extern void CB2_ReturnToField(void);
|
||||||
|
|
||||||
// this file's functions
|
// this file's functions
|
||||||
static void ClearDaycareMonMisc(struct DaycareMiscMon *misc);
|
static void ClearDaycareMonMail(struct DayCareMail *mail);
|
||||||
static void SetInitialEggData(struct Pokemon *mon, u16 species, struct DayCare *daycare);
|
static void SetInitialEggData(struct Pokemon *mon, u16 species, struct DayCare *daycare);
|
||||||
static u8 GetDaycareCompatibilityScore(struct DayCare *daycare);
|
static u8 GetDaycareCompatibilityScore(struct DayCare *daycare);
|
||||||
static void DaycarePrintMonInfo(u8 windowId, s32 daycareSlotId, u8 y);
|
static void DaycarePrintMonInfo(u8 windowId, s32 daycareSlotId, u8 y);
|
||||||
@ -179,13 +179,13 @@ static void StorePokemonInDaycare(struct Pokemon *mon, struct DaycareMon *daycar
|
|||||||
{
|
{
|
||||||
u8 mailId;
|
u8 mailId;
|
||||||
|
|
||||||
StringCopy(daycareMon->misc.OT_name, gSaveBlock2Ptr->playerName);
|
StringCopy(daycareMon->mail.OT_name, gSaveBlock2Ptr->playerName);
|
||||||
GetMonNick(mon, daycareMon->misc.monName);
|
GetMonNick(mon, daycareMon->mail.monName);
|
||||||
StripExtCtrlCodes(daycareMon->misc.monName);
|
StripExtCtrlCodes(daycareMon->mail.monName);
|
||||||
daycareMon->misc.gameLanguage = LANGUAGE_ENGLISH;
|
daycareMon->mail.gameLanguage = LANGUAGE_ENGLISH;
|
||||||
daycareMon->misc.monLanguage = GetMonData(mon, MON_DATA_LANGUAGE);
|
daycareMon->mail.monLanguage = GetMonData(mon, MON_DATA_LANGUAGE);
|
||||||
mailId = GetMonData(mon, MON_DATA_MAIL);
|
mailId = GetMonData(mon, MON_DATA_MAIL);
|
||||||
daycareMon->misc.mail = gSaveBlock1Ptr->mail[mailId];
|
daycareMon->mail.message = gSaveBlock1Ptr->mail[mailId];
|
||||||
TakeMailFromMon(mon);
|
TakeMailFromMon(mon);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -219,10 +219,10 @@ static void ShiftDaycareSlots(struct DayCare *daycare)
|
|||||||
daycare->mons[0].mon = daycare->mons[1].mon;
|
daycare->mons[0].mon = daycare->mons[1].mon;
|
||||||
ZeroBoxMonData(&daycare->mons[1].mon);
|
ZeroBoxMonData(&daycare->mons[1].mon);
|
||||||
|
|
||||||
daycare->mons[0].misc = daycare->mons[1].misc;
|
daycare->mons[0].mail = daycare->mons[1].mail;
|
||||||
daycare->mons[0].steps = daycare->mons[1].steps;
|
daycare->mons[0].steps = daycare->mons[1].steps;
|
||||||
daycare->mons[1].steps = 0;
|
daycare->mons[1].steps = 0;
|
||||||
ClearDaycareMonMisc(&daycare->mons[1].misc);
|
ClearDaycareMonMail(&daycare->mons[1].mail);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,10 +277,10 @@ static u16 TakeSelectedPokemonFromDaycare(struct DaycareMon *daycareMon)
|
|||||||
}
|
}
|
||||||
|
|
||||||
gPlayerParty[PARTY_SIZE - 1] = pokemon;
|
gPlayerParty[PARTY_SIZE - 1] = pokemon;
|
||||||
if (daycareMon->misc.mail.itemId)
|
if (daycareMon->mail.message.itemId)
|
||||||
{
|
{
|
||||||
GiveMailToMon2(&gPlayerParty[PARTY_SIZE - 1], &daycareMon->misc.mail);
|
GiveMailToMon2(&gPlayerParty[PARTY_SIZE - 1], &daycareMon->mail.message);
|
||||||
ClearDaycareMonMisc(&daycareMon->misc);
|
ClearDaycareMonMail(&daycareMon->mail);
|
||||||
}
|
}
|
||||||
|
|
||||||
ZeroBoxMonData(&daycareMon->mon);
|
ZeroBoxMonData(&daycareMon->mon);
|
||||||
@ -364,23 +364,23 @@ u8 GetNumLevelsGainedFromDaycare(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ClearDaycareMonMisc(struct DaycareMiscMon *misc)
|
static void ClearDaycareMonMail(struct DayCareMail *mail)
|
||||||
{
|
{
|
||||||
s32 i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < OT_NAME_LENGTH + 1; i++)
|
for (i = 0; i < OT_NAME_LENGTH + 1; i++)
|
||||||
misc->OT_name[i] = 0;
|
mail->OT_name[i] = 0;
|
||||||
for (i = 0; i < POKEMON_NAME_LENGTH + 1; i++)
|
for (i = 0; i < POKEMON_NAME_LENGTH + 1; i++)
|
||||||
misc->monName[i] = 0;
|
mail->monName[i] = 0;
|
||||||
|
|
||||||
ClearMailStruct(&misc->mail);
|
ClearMailStruct(&mail->message);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ClearDaycareMon(struct DaycareMon *daycareMon)
|
static void ClearDaycareMon(struct DaycareMon *daycareMon)
|
||||||
{
|
{
|
||||||
ZeroBoxMonData(&daycareMon->mon);
|
ZeroBoxMonData(&daycareMon->mon);
|
||||||
daycareMon->steps = 0;
|
daycareMon->steps = 0;
|
||||||
ClearDaycareMonMisc(&daycareMon->misc);
|
ClearDaycareMonMail(&daycareMon->mail);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ClearAllDaycareData(struct DayCare *daycare)
|
static void ClearAllDaycareData(struct DayCare *daycare)
|
||||||
|
@ -158,7 +158,7 @@ static void sub_8122804(struct EasyChatPair *s, u16 b, u8 c)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_812287C(void *a, u32 b, u8 unused)
|
void ReceiveEasyChatPairsData(void *a, u32 b, u8 unused)
|
||||||
{
|
{
|
||||||
u16 i, j, r3, players;
|
u16 i, j, r3, players;
|
||||||
struct EasyChatPair *buffer1, *buffer2, *src, *dst, *foo_of_buffer2;
|
struct EasyChatPair *buffer1, *buffer2, *src, *dst, *foo_of_buffer2;
|
||||||
|
@ -793,11 +793,11 @@ void sub_8120C0C(union OldMan * oldMan, u32 r8, u32 r7, u32 r3)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_8120CD0(union OldMan * oldMan, u32 unused, u32 a2)
|
void SanitizeReceivedEmeraldOldMan(union OldMan * oldMan, u32 version, u32 language)
|
||||||
{
|
{
|
||||||
u8 sp00[8];
|
u8 sp00[8];
|
||||||
s32 i;
|
s32 i;
|
||||||
if (oldMan->common.id == MAUVILLE_MAN_STORYTELLER && a2 == LANGUAGE_JAPANESE)
|
if (oldMan->common.id == MAUVILLE_MAN_STORYTELLER && language == LANGUAGE_JAPANESE)
|
||||||
{
|
{
|
||||||
struct MauvilleManStoryteller * storyteller = &oldMan->storyteller;
|
struct MauvilleManStoryteller * storyteller = &oldMan->storyteller;
|
||||||
|
|
||||||
@ -816,9 +816,10 @@ void sub_8120CD0(union OldMan * oldMan, u32 unused, u32 a2)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
void SanitizeReceivedRubyOldMan(union OldMan * oldMan, u32 version, u32 language)
|
||||||
{
|
{
|
||||||
u32 r2 = (r1 == LANGUAGE_JAPANESE || r1 == LANGUAGE_ENGLISH) ? 1 : 0;
|
bool32 isRuby = (version == VERSION_SAPPHIRE || version == VERSION_RUBY);
|
||||||
|
|
||||||
switch (oldMan->common.id)
|
switch (oldMan->common.id)
|
||||||
{
|
{
|
||||||
case MAUVILLE_MAN_TRADER:
|
case MAUVILLE_MAN_TRADER:
|
||||||
@ -826,7 +827,7 @@ void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
|||||||
struct MauvilleOldManTrader * trader = &oldMan->trader;
|
struct MauvilleOldManTrader * trader = &oldMan->trader;
|
||||||
s32 i;
|
s32 i;
|
||||||
|
|
||||||
if (r2)
|
if (isRuby)
|
||||||
{
|
{
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
@ -837,7 +838,7 @@ void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
|||||||
trader->language[i] = LANGUAGE_JAPANESE;
|
trader->language[i] = LANGUAGE_JAPANESE;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
trader->language[i] = r6;
|
trader->language[i] = language;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -858,12 +859,12 @@ void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
|||||||
struct MauvilleManStoryteller * storyteller = &oldMan->storyteller;
|
struct MauvilleManStoryteller * storyteller = &oldMan->storyteller;
|
||||||
s32 i;
|
s32 i;
|
||||||
|
|
||||||
if (r2)
|
if (isRuby)
|
||||||
{
|
{
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
if (storyteller->gameStatIDs[i] != 0)
|
if (storyteller->gameStatIDs[i] != 0)
|
||||||
storyteller->language[i] = r6;
|
storyteller->language[i] = language;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -872,9 +873,9 @@ void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
|||||||
{
|
{
|
||||||
struct MauvilleManBard * bard = &oldMan->bard;
|
struct MauvilleManBard * bard = &oldMan->bard;
|
||||||
|
|
||||||
if (r2)
|
if (isRuby)
|
||||||
{
|
{
|
||||||
bard->language = r6;
|
bard->language = language;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -882,9 +883,9 @@ void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
|||||||
{
|
{
|
||||||
struct MauvilleManHipster * hipster = &oldMan->hipster;
|
struct MauvilleManHipster * hipster = &oldMan->hipster;
|
||||||
|
|
||||||
if (r2)
|
if (isRuby)
|
||||||
{
|
{
|
||||||
hipster->language = r6;
|
hipster->language = language;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -892,9 +893,9 @@ void sub_8120D34(union OldMan * oldMan, u32 r1, u32 r6)
|
|||||||
{
|
{
|
||||||
struct MauvilleManGiddy * giddy = &oldMan->giddy;
|
struct MauvilleManGiddy * giddy = &oldMan->giddy;
|
||||||
|
|
||||||
if (r2)
|
if (isRuby)
|
||||||
{
|
{
|
||||||
giddy->language = r6;
|
giddy->language = language;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1673,7 +1673,7 @@ void sub_80EAEF4(struct SecretBaseRecordMixer *mixers)
|
|||||||
sub_80EABA4(&mixers[2], 0);
|
sub_80EABA4(&mixers[2], 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_80EAF80(void *records, size_t recordSize, u8 linkIdx)
|
void ReceiveSecretBasesData(void *records, size_t recordSize, u8 linkIdx)
|
||||||
{
|
{
|
||||||
struct SecretBaseRecordMixer mixers[3];
|
struct SecretBaseRecordMixer mixers[3];
|
||||||
u16 i;
|
u16 i;
|
||||||
|
4
src/tv.c
4
src/tv.c
@ -3606,7 +3606,7 @@ void sub_80F01B8(void)
|
|||||||
FlagSet(0x396);
|
FlagSet(0x396);
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_80F01E8(void *src, u32 size, u8 masterIdx)
|
void ReceiveTvShowsData(void *src, u32 size, u8 masterIdx)
|
||||||
{
|
{
|
||||||
u8 i;
|
u8 i;
|
||||||
u16 version;
|
u16 version;
|
||||||
@ -4434,7 +4434,7 @@ static void sub_80F0C04(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_80F0C7C(void *src, u32 size, u8 masterIdx)
|
void ReceivePokeNewsData(void *src, u32 size, u8 masterIdx)
|
||||||
{
|
{
|
||||||
u8 i;
|
u8 i;
|
||||||
PokeNews (*rmBuffer2)[4][16];
|
PokeNews (*rmBuffer2)[4][16];
|
||||||
|
Loading…
Reference in New Issue
Block a user