summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMarijn van der Werf <marijn.vanderwerf@gmail.com>2016-12-02 19:06:22 +0100
committerYamaArashi <YamaArashi@users.noreply.github.com>2016-12-02 10:06:22 -0800
commit1f222c04ef1d10ff5a5c6bb98cd4380ecf2bba86 (patch)
tree573d6368233110b17292e498f49532c1c9244404 /src
parent4258e60771aa9fdabd678930eca534423bd371b8 (diff)
[WIP] Extract all external function declarations to headers (#114)
* Extract other external function declarations * Fix GBA compilation * Revert `sub_803C434` to asm
Diffstat (limited to 'src')
-rw-r--r--src/battle_ai.c10
-rw-r--r--src/battle_setup.c56
-rw-r--r--src/berry.c12
-rw-r--r--src/decompress.c3
-rw-r--r--src/dewford_trend.c13
-rw-r--r--src/diploma.c7
-rw-r--r--src/field_camera.c10
-rw-r--r--src/field_door.c5
-rw-r--r--src/field_effect.c12
-rw-r--r--src/field_player_avatar.c102
-rw-r--r--src/field_poison.c5
-rw-r--r--src/fldeff_emotion.c6
-rw-r--r--src/intro.c34
-rw-r--r--src/link.c5
-rw-r--r--src/main.c9
-rw-r--r--src/main_menu.c17
-rw-r--r--src/map_obj_80643A4.c6
-rw-r--r--src/map_obj_lock.c10
-rw-r--r--src/mori_debug_menu.c6
-rw-r--r--src/new_game.c2
-rw-r--r--src/palette.c4
-rw-r--r--src/pokedex.c2
-rw-r--r--src/pokemon_1.c4
-rw-r--r--src/pokemon_2.c81
-rw-r--r--src/record_mixing.c18
-rw-r--r--src/rom4.c131
-rw-r--r--src/safari_zone.c4
-rw-r--r--src/save.c4
-rw-r--r--src/save_menu_util.c1
-rw-r--r--src/scrcmd.c98
-rw-r--r--src/sound.c3
-rw-r--r--src/start_menu.c21
-rw-r--r--src/starter_choose.c7
-rw-r--r--src/title_screen.c9
-rw-r--r--src/trainer_see.c20
-rw-r--r--src/truck_scene.c4
-rw-r--r--src/wallclock.c4
-rw-r--r--src/weather.c1
-rw-r--r--src/wild_encounter.c9
39 files changed, 145 insertions, 610 deletions
diff --git a/src/battle_ai.c b/src/battle_ai.c
index 945176b64..a2db200ac 100644
--- a/src/battle_ai.c
+++ b/src/battle_ai.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "battle.h"
+#include "asm.h"
#include "pokemon.h"
#include "rng.h"
@@ -13,11 +14,6 @@ all the way to at least 0x2016800, in addition to extremely hard functions that
as it currently is until someone bothers to document this huge struct.
*/
-extern u8 sub_8015A98(u8, u8, u8);
-extern u8 battle_side_get_owner(u8);
-extern s16 battle_get_per_side_status(u8);
-extern u8 b_first_side(u8, u8, u8);
-
extern u16 gUnknown_020239F8;
extern u8 gUnknown_02024A60;
extern u8 gUnknown_02024C07;
@@ -1248,8 +1244,8 @@ void BattleAICmd_get_ability(void)
if(battle_side_get_owner(var) == 0)
{
//register u8 unk asm("r1") = battle_get_per_side_status(var) & 1;
- s32 unk = battle_get_per_side_status(var) & 1;
-
+ u16 unk = battle_get_per_side_status(var) & 1;
+
if(unk_2016A00.unk20[unk] != 0)
{
((struct UnknownStruct2 *)((u8 *)&unk_2016A00 - 512))->unk8 = unk_2016A00.unk20[unk];
diff --git a/src/battle_setup.c b/src/battle_setup.c
index fd44d2fc6..312dcdbeb 100644
--- a/src/battle_setup.c
+++ b/src/battle_setup.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "battle_setup.h"
+#include "asm.h"
#include "safari_zone.h"
#include "weather.h"
#include "palette.h"
@@ -9,6 +10,7 @@
#include "main.h"
#include "species.h"
#include "songs.h"
+#include "sound.h"
#include "task.h"
#include "string_util.h"
#include "rng.h"
@@ -22,41 +24,6 @@
#define NUM_TRAINER_EYE_TRAINERS 56
#define TRAINER_REMATCH_STEPS 255
-extern void prev_quest_postbuffer_cursor_backup_reset(void);
-extern void overworld_poison_timer_set(void);
-extern void current_map_music_set__default_for_battle(u16);
-extern void c2_exit_to_overworld_1_continue_scripts_restart_music(void);
-extern void c2_exit_to_overworld_2_switch(void);
-extern void npc_set_running_behaviour_etc(struct MapObject *, u8);
-extern u8 npc_running_behaviour_by_direction(u8);
-extern void c2_whiteout(void);
-extern void sub_800E7C4(void);
-extern void sub_8081AA4(void);
-extern void sub_8081A18(void);
-extern void sub_8081C8C(void);
-extern void sub_8081CEC(void);
-extern void sub_8080E44(void);
-extern void sub_80821D8(void);
-extern void sub_8082228(void);
-extern void sub_808260C(void);
-extern void sub_8082CB8(void);
-extern void sub_811AAD8(u8);
-extern u8 *sub_80BCCE8(void);
-extern void sub_811AABC(u8);
-extern u8 sub_811AAE8(void);
-extern u8 GetFieldObjectIdByLocalIdAndMap(u8, u8, u8);
-extern u8 *sub_8082880(void);
-extern u8 sub_803FC58(u16);
-extern bool32 FieldPoisonEffectIsRunning(void);
-extern void player_bitmagic(void);
-extern void sub_80408BC();
-
-u8 GetWildBattleTransition(void);
-u8 GetTrainerBattleTransition(void);
-bool32 battle_exit_is_player_defeat(u32 a1);
-u8 *sub_808281C(void);
-u16 sub_8082C4C(u16 a1);
-
extern u16 gScriptResult;
struct TrainerPartyMember0
@@ -104,19 +71,6 @@ struct TrainerEyeTrainer
u16 mapNum;
};
-extern bool8 MetatileBehavior_IsTallGrass(char);
-extern bool8 MetatileBehavior_IsLongGrass(char);
-extern bool8 MetatileBehavior_IsSandOrDeepSand(char);
-extern bool8 MetatileBehavior_IsSurfableWaterOrUnderwater(char);
-extern bool8 MetatileBehavior_IsBridge(char);
-extern bool8 sub_80574C4(char);
-extern bool8 sub_80574D8(char);
-extern bool8 sub_8057568(char);
-extern u8 sub_8057450(u8);
-extern void PlayNewMapMusic(u16);
-
-extern u8 ScriptGiveMon(u16, u8, u16, u32, u32, u8);
-
extern void (*gUnknown_0300485C)(void);
extern struct Pokemon gEnemyParty[];
@@ -164,8 +118,6 @@ extern u8 gStringVar4[];
extern u8 gBattleTransitionTable_Wild[][2];
extern u8 gBattleTransitionTable_Trainer[][2];
-void sub_8082188(void);
-
void task01_battle_start(u8 taskId)
{
s16 *data = gTasks[taskId].data;
@@ -732,10 +684,10 @@ void TrainerWantsBattle(u8 trainerMapObjId, u8 *trainerScript)
ScriptContext2_Enable();
}
-u8 GetTrainerFlagFromScriptPointer(u8 *data)
+u8* GetTrainerFlagFromScriptPointer(u8 *data)
{
u32 flag = TrainerBattleLoadArg16(data + 2);
- return FlagGet(TRAINER_FLAG_START + flag);
+ return (u8*)FlagGet(TRAINER_FLAG_START + flag);
}
void sub_8082524(void)
diff --git a/src/berry.c b/src/berry.c
index 2d7b50e2b..aee624c33 100644
--- a/src/berry.c
+++ b/src/berry.c
@@ -1,4 +1,6 @@
#include "global.h"
+#include "berry.h"
+#include "asm.h"
#include "item.h"
#include "main.h"
#include "text.h"
@@ -7,14 +9,6 @@
#define FIRST_BERRY 0x85 // ITEM_CHERI_BERRY
#define LAST_BERRY 0xaf // ITEM_ENIGMA_BERRY
-extern u8 GetStageByBerryTreeId(u8);
-extern u16 GetStageDurationByBerryType(u8);
-extern void sub_80A68CC();
-extern u8 sub_8060234(u8, u8, u8);
-extern void sub_8060288(u8, u8, u8);
-extern u8 FieldObjectGetBerryTreeId(u8);
-extern u8 *GetFieldObjectScriptPointerForComparison();
-
extern struct Berry gBerries[];
extern u8 BerryTreeScript;
extern struct BerryTree gUnknown_083CD780;
@@ -24,8 +18,6 @@ extern u16 gSpecialVar_0x8004;
extern u16 gSpecialVar_0x8005;
extern u16 gSpecialVar_0x8006;
-u8 CalcBerryYield(struct BerryTree *tree);
-
void unref_sub_80B4884(void)
{
CpuFill16(0, &gSaveBlock1.enigmaBerry, sizeof(gSaveBlock1.enigmaBerry));
diff --git a/src/decompress.c b/src/decompress.c
index 16c9f39ed..7f8ed9271 100644
--- a/src/decompress.c
+++ b/src/decompress.c
@@ -1,6 +1,7 @@
#include "global.h"
#include "decompress.h"
#include "species.h"
+#include "asm.h"
#define WRAM 0x02000000
@@ -8,8 +9,6 @@ extern struct SpriteSheet gMonFrontPicTable[];
extern struct SpriteSheet gMonBackPicTable[];
extern void *gUnknown_081FAF4C[];
-extern void DrawSpindaSpots(u16, u32, void *, u8);
-
void sub_800D238(const void *src, void *dest)
{
LZ77UnCompWram(src, dest);
diff --git a/src/dewford_trend.c b/src/dewford_trend.c
index 8d683e072..ae1397852 100644
--- a/src/dewford_trend.c
+++ b/src/dewford_trend.c
@@ -1,23 +1,14 @@
#include "global.h"
+#include "asm.h"
#include "link.h"
#include "rng.h"
#include "flag.h"
-extern u8 GetLinkPlayerCount(void);
-extern u16 sub_80EB72C(u16);
-extern u8 ConvertEasyChatWordsToString(u8 *dst, u16 *words, u16, u16);
-
extern struct EasyChatPair unk_2007800[5];
extern struct EasyChatPair unk_2007900[5];
extern u16 gScriptResult;
extern u16 gSpecialVar_0x8004;
-void sub_80FA740(struct EasyChatPair *);
-void sub_80FA46C(struct EasyChatPair *, u16, u8);
-bool8 sub_80FA670(struct EasyChatPair *, struct EasyChatPair *, u8);
-bool8 IsEasyChatPairEqual(u16 *, u16 *);
-bool8 SB1ContainsWords(u16 *);
-
void sub_80FA17C(void)
{
u16 i;
@@ -394,7 +385,7 @@ void sub_80FA4E4(u8 *a, u32 b)
}
#else
__attribute__((naked))
-void sub_80FA4E4(u8 *a, u32 b)
+void sub_80FA4E4(struct EasyChatPair *a, u32 b, u8 c)
{
asm(".syntax unified\n\
push {r4-r7,lr}\n\
diff --git a/src/diploma.c b/src/diploma.c
index 4d81ad4b0..8fabe3a2f 100644
--- a/src/diploma.c
+++ b/src/diploma.c
@@ -1,16 +1,15 @@
#include "global.h"
+#include "asm.h"
#include "main.h"
#include "menu.h"
#include "palette.h"
+#include "pokedex.h"
+#include "rom4.h"
#include "sprite.h"
#include "string_util.h"
#include "task.h"
#include "text.h"
-extern void remove_some_task(void);
-extern void sub_80546F0(void);
-extern u16 sub_8090FF4(void);
-
extern u8 gDiplomaTiles[];
extern u8 gDiplomaTilemap[];
extern u8 gDiplomaPalettes[];
diff --git a/src/field_camera.c b/src/field_camera.c
index 1986e33d7..b9a813bdf 100644
--- a/src/field_camera.c
+++ b/src/field_camera.c
@@ -1,5 +1,7 @@
#include "global.h"
#include "field_camera.h"
+#include "asm.h"
+#include "berry.h"
#include "field_player_avatar.h"
#include "asm_fieldmap.h"
#include "sprite.h"
@@ -7,11 +9,6 @@
extern u16 gBGTilemapBuffers[4][0x400];
-
-//ToDo: argument types
-extern void ResetBerryTreeSparkleFlags(void);
-extern void RotatingGatePuzzleCameraUpdate(s16, s16);
-
extern u8 gUnknown_0202E854;
@@ -49,13 +46,10 @@ static void RedrawMapSliceSouth(struct UnknownStruct *a, struct MapData *mapData
static void RedrawMapSliceEast(struct UnknownStruct *a, struct MapData *mapData);
static void RedrawMapSliceWest(struct UnknownStruct *a, struct MapData *mapData);
static s32 MapPosToBgTilemapOffset(struct UnknownStruct *a, s32 x, s32 y);
-void CameraUpdate(void);
static void DrawWholeMapViewInternal(int x, int y, struct MapData *mapData);
static void DrawMetatileAt(struct MapData *mapData, u16, int, int);
static void DrawMetatile(s32 a, u16 *b, u16 c);
-u8 AddCameraObject(u8);
-void UpdateFieldObjectsForCameraUpdate(s16, s16);
static void CameraPanningCB_PanAhead(void);
static void move_tilemap_camera_to_upper_left_corner_(struct UnknownStruct *a)
diff --git a/src/field_door.c b/src/field_door.c
index 8aac6cce3..da57988ca 100644
--- a/src/field_door.c
+++ b/src/field_door.c
@@ -1,9 +1,8 @@
#include "global.h"
+#include "asm.h"
#include "task.h"
#include "field_camera.h"
-extern u8 MetatileBehavior_IsDoor(u8);
-
struct DoorGraphics
{
u16 metatileNum;
@@ -225,7 +224,7 @@ bool8 FieldIsDoorAnimationRunning(void)
return FuncIsActiveTask(Task_AnimateDoor);
}
-u8 sub_8058790(u32 x, u32 y)
+u32 sub_8058790(u32 x, u32 y)
{
if (cur_mapdata_get_door_x2_at(gDoorAnimGraphicsTable, x, y) == 0)
return 8;
diff --git a/src/field_effect.c b/src/field_effect.c
index 480e970ab..fe586fcb6 100644
--- a/src/field_effect.c
+++ b/src/field_effect.c
@@ -11,18 +11,6 @@ extern u8 *gFieldEffectScriptPointers[];
extern FldEffCmd gFieldEffectScriptFuncs[];
-void FieldEffectScript_LoadTiles(u8 **script);
-void FieldEffectScript_LoadFadedPalette(u8 **script);
-void FieldEffectScript_LoadPalette(u8 **script);
-void FieldEffectScript_CallNative(u8 **script, u32 *val);
-void FieldEffectFreeGraphicsResources(struct Sprite *sprite);
-void FieldEffectStop(struct Sprite *sprite, u8 id);
-void FieldEffectFreeTilesIfUnused(u16 tileStart);
-void FieldEffectFreePaletteIfUnused(u8 paletteNum);
-void FieldEffectActiveListClear(void);
-void FieldEffectActiveListAdd(u8 id);
-void FieldEffectActiveListRemove(u8 id);
-
u32 FieldEffectStart(u8 id)
{
u8 *script;
diff --git a/src/field_player_avatar.c b/src/field_player_avatar.c
index be9d07582..a6b53b7a6 100644
--- a/src/field_player_avatar.c
+++ b/src/field_player_avatar.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "field_player_avatar.h"
+#include "asm.h"
#include "field_map_obj.h"
#include "rom4.h"
#include "flag.h"
@@ -14,94 +15,6 @@
#include "wild_encounter.h"
#include "asm_fieldmap.h"
-struct UnknownStruct
-{
- u8 unk0;
- u8 unk1;
- u8 unk2;
- s16 unk4;
- s16 unk6;
- u8 unk8;
- u8 unk9;
- u8 unkA_0:4;
- u8 unkA_4:4;
- u16 unkC;
- u16 unkE;
- u32 unk10;
- u16 unk14;
-};
-
-extern u8 SpawnSpecialFieldObject(struct UnknownStruct *);
-extern u8 sub_8126B54(void);
-extern bool8 FieldObjectIsSpecialAnimOrDirectionSequenceAnimActive(struct MapObject *);
-extern u8 FieldObjectClearAnimIfSpecialAnimFinished(struct MapObject *);
-extern u8 FieldObjectGetSpecialAnim(struct MapObject *);
-extern bool8 FieldObjectSetSpecialAnim(struct MapObject *, u8);
-extern void FieldObjectClearAnim(struct MapObject *);
-extern s16 sub_80E6034(void);
-extern bool8 MetatileBehavior_IsSurfableFishableWater(u8);
-extern bool8 FieldObjectCheckIfSpecialAnimFinishedOrInactive(struct MapObject *);
-extern void sub_806451C(void);
-extern void sub_805B980(struct MapObject *, u8);
-extern void sub_8127ED0(u8, u8);
-extern bool8 is_tile_x69_2_warp_door(u8);
-extern bool8 pokemon_has_move(struct Pokemon *, u8);
-extern u8 GetSimpleGoAnimId(u8);
-extern u8 GetStepInPlaceDelay16AnimId(u8);
-extern u8 sub_806084C(u8);
-extern u8 GetOppositeDirection(u8);
-extern u8 GetFaceDirectionAnimId(u8);
-extern u8 sub_80608D0(u8);
-extern bool8 GetFishingWildMonListHeader(void);
-extern u8 npc_block_way(struct MapObject *, s16, s16, u8);
-extern u8 GetFieldObjectIdByXY(s16, s16);
-extern u8 sub_8056F08(u8);
-extern u8 GetLedgeJumpDirection(s16, s16, u8);
-extern u8 GetFieldObjectIdByXYZ(u16, u16, int);
-extern u32 CheckForRotatingGatePuzzleCollision(u8, s16, s16);
-extern u8 sub_805FDF8(u8);
-extern void sub_80BE97C(u8);
-extern void sub_8127F28(u8, u8, s16);
-extern u8 sub_805FE08(u8);
-extern void FieldObjectClearAnimIfSpecialAnimActive(struct MapObject *);
-extern u8 FieldObjectDirectionToImageAnimId(u8);
-extern u8 sub_805FD98(u8);
-extern u8 sub_805FDE8(u8);
-extern void sub_8053F84(void);
-extern u8 sub_80609D8(u8);
-extern u8 sub_8060A04(u8);
-extern u8 sub_8060A30(u8);
-extern u8 sub_8060A5C(u8);
-extern u8 sub_8060A88(u8);
-extern u8 sub_8060AB4(u8);
-extern u8 sub_8060878(u8);
-extern u8 sub_8060AE0(u8);
-extern u8 sub_8060B0C(u8);
-extern u8 sub_8060B38(u8);
-extern u8 sub_8060B64(u8);
-extern void objid_set_invisible(u8);
-extern void FieldObjectTurn(struct MapObject *, u8);
-extern u8 sub_8128124(u8 id);
-extern u8 sub_80607F4(u8 a);
-extern u8 GetGoSpeed0AnimId(u8 a);
-extern u8 sub_8060744(u8 a);
-extern u8 d2s_08064034(u8 a);
-extern u8 sub_806079C(u8 a);
-extern void FieldObjectForceSetSpecialAnim(struct MapObject *pObject, u8 a);
-extern u8 GetStepInPlaceDelay8AnimId(u8 a);
-extern u8 GetStepInPlaceDelay32AnimId(u8 a);
-extern u8 GetJumpLedgeAnimId(u8 a);
-
-// Bike
-extern void MovePlayerOnBike(u8, u16, u16);
-extern void sub_80E5B38(u16 i, u16 c);
-extern u8 sub_80E5DEC(u8);
-extern bool8 player_should_look_direction_be_enforced_upon_movement(void);
-extern void sub_80E5FCC(int i, int i1);
-extern void sub_80E6010(int i);
-extern void sub_80E6084();
-extern void sub_8126BC4(u8 unk_1B, u8 r6, s16 x, s16 y);
-
extern u8 gOtherText_OhABite[];
extern u8 gOtherText_PokeOnHook[];
extern u8 gOtherText_NotEvenANibble[];
@@ -149,7 +62,6 @@ static u8 GetForcedMovementByMetatileBehavior(void);
static void MovePlayerNotOnBike(u8 a, u16 b);
static u8 CheckMovementInputNotOnBike(u8 a);
static u8 CheckForPlayerAvatarCollision(u8 a);
-u8 CheckForFieldObjectCollision(struct MapObject *a, s16 b, s16 c, u8 d, u8 e);
static u8 sub_8058EF0(s16 a, s16 b, u8 c);
static bool8 ShouldJumpLedge(s16 a, s16 b, u8 c);
static u8 sub_8058F6C(s16 a, s16 b, u8 c);
@@ -159,22 +71,12 @@ static bool8 player_is_anim_in_certain_ranges(void);
static bool8 sub_80592A4(void);
static bool8 PlayerIsAnimActive(void);
static bool8 PlayerCheckIfAnimFinishedOrInactive(void);
-void PlayerGoSpeed0(u8 a);
-void sub_80593C4(u8 a);
-void npc_use_some_d2s(u8 a);
-void sub_805940C(u8 a);
static void PlayerNotOnBikeCollide(u8 a);
-void PlayerFaceDirection(u8 a);
-void PlayerTurnInPlace(u8 a);
-void PlayerJumpLedge(u8 a);
static void PlayCollisionSoundIfNotFacingWarp(u8 a);
-u8 GetPlayerAvatarGraphicsIdByStateId(u8 a);
-void SetPlayerAvatarStateMask(u8 a);
static void sub_8059D60(struct MapObject *a);
static void StartStrengthAnim(u8 a, u8 b);
static void sub_8059F94(void);
static void sub_805A06C(void);
-void sub_805A20C(u8 a);
void sub_80587B4(struct Sprite *sprite)
{
@@ -1093,7 +995,7 @@ void SetPlayerAvatarExtraStateTransition(u8 a, u8 b)
void InitPlayerAvatar(s16 a, s16 b, u8 c, u8 d)
{
- struct UnknownStruct s;
+ struct UnknownStruct_FPA s;
u8 mapObjectId;
struct MapObject *mapObject;
diff --git a/src/field_poison.c b/src/field_poison.c
index a51fe5546..309ec1d71 100644
--- a/src/field_poison.c
+++ b/src/field_poison.c
@@ -1,14 +1,11 @@
#include "global.h"
+#include "asm.h"
#include "field_message_box.h"
#include "pokemon.h"
#include "script.h"
#include "string_util.h"
#include "task.h"
-extern void AdjustFriendship(struct Pokemon *, u8);
-extern u8 pokemon_ailments_get_primary(u32);
-extern void DoFieldPoisonEffect(void);
-
extern struct Pokemon gPlayerParty[6];
extern u16 gScriptResult;
extern u8 fieldPoisonText_PokemonFainted[];
diff --git a/src/fldeff_emotion.c b/src/fldeff_emotion.c
index 81ab135c4..efe4ef683 100644
--- a/src/fldeff_emotion.c
+++ b/src/fldeff_emotion.c
@@ -1,4 +1,5 @@
#include "global.h"
+#include "asm.h"
#include "sprite.h"
#include "asm_fieldmap.h"
#include "field_effect.h"
@@ -8,11 +9,6 @@ extern u32 gUnknown_0202FF84[];
extern struct SpriteTemplate gSpriteTemplate_839B510;
extern struct SpriteTemplate gSpriteTemplate_839B528;
-bool8 TryGetFieldObjectIdByLocalIdAndMap(u8, u8, u8, u8 *);
-
-void sub_8084894(struct Sprite *sprite, u16 a2, u8 a3);
-void objc_exclamation_mark_probably(struct Sprite *sprite);
-
u8 FldEff_ExclamationMarkIcon1(void)
{
u8 spriteId = CreateSpriteAtEnd(&gSpriteTemplate_839B510, 0, 0, 0x53);
diff --git a/src/intro.c b/src/intro.c
index 3d32cb18e..13e35976e 100644
--- a/src/intro.c
+++ b/src/intro.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "intro.h"
+#include "asm.h"
#include "gba/m4a_internal.h"
#include "m4a.h"
#include "libgncmultiboot.h"
@@ -60,39 +61,6 @@ extern const u8 gIntroCopyright_Gfx[];
extern const u16 gIntroCopyright_Pal[];
extern const u16 gIntroCopyright_Tilemap[];
-// rom_813BA94
-extern void sub_813CAF4(u8);
-extern void intro_reset_and_hide_bgs(void);
-extern void sub_813CCE8(u8);
-extern void sub_813CE30(u16, u16, u16, u16);
-extern u8 sub_813CE88(/*TODO: arg types*/);
-extern u8 sub_813CFA8(/*TODO: arg types*/);
-extern void sub_813D084(/*TODO: arg types*/);
-extern u8 sub_813D584(/*TODO: arg types*/);
-extern void sub_813D788(struct Sprite *);
-extern void sub_813D880(struct Sprite *);
-extern void sub_813D954(/*TODO: arg types*/);
-extern void sub_813DB9C(struct Sprite *);
-extern void sub_813DE70(struct Sprite *);
-extern void sub_813E10C(struct Sprite *);
-extern void sub_813E210(struct Sprite *);
-extern void sub_813E7C0(u8);
-extern void sub_813E930(/*TODO: arg types*/);
-extern void sub_813EB4C(u8);
-extern void sub_813EDBC(/*TODO: arg types*/);
-
-// rom_8148B8C
-extern void load_intro_part2_graphics(/*TODO: arg types*/);
-extern void sub_8148C78(/*TODO: arg types*/);
-extern u8 sub_8148EC0(/*TODO: arg types*/);
-extern void sub_8149020(/*TODO: arg types*/);
-extern u8 intro_create_brendan_sprite(/*TODO: arg types*/);
-extern u8 intro_create_may_sprite(/*TODO: arg types*/);
-extern u8 intro_create_latios_sprite(/*TODO: arg types*/);
-extern u8 intro_create_latias_sprite(/*TODO: arg types*/);
-
-extern void remove_some_task(void);
-
static void MainCB2_EndIntro(void);
static void Task_IntroLoadPart1Graphics(u8);
static void Task_IntroFadeIn(u8);
diff --git a/src/link.c b/src/link.c
index 2208390da..56635def2 100644
--- a/src/link.c
+++ b/src/link.c
@@ -1,10 +1,11 @@
#include "global.h"
+#include "link.h"
+#include "asm.h"
#include "main.h"
#include "task.h"
#include "text.h"
#include "sprite.h"
#include "songs.h"
-#include "link.h"
#include "palette.h"
#include "rng.h"
#include "menu.h"
@@ -30,8 +31,6 @@ struct LinkTestBGInfo
u32 dummy_C;
};
-extern void sub_80516C4(u8, u16);
-
extern u8 unk_2000000[];
extern u8 unk_2004000[];
extern u16 gUnknown_020239F8;
diff --git a/src/main.c b/src/main.c
index 0023925f8..a14663d32 100644
--- a/src/main.c
+++ b/src/main.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "main.h"
+#include "asm.h"
#include "play_time.h"
#include "m4a.h"
#include "gba/m4a_internal.h"
@@ -8,6 +9,7 @@
#include "rtc.h"
#include "link.h"
#include "rng.h"
+#include "rom4.h"
#include "sound.h"
#include "intro.h"
@@ -65,13 +67,6 @@ u8 gPcmDmaCounter;
EWRAM_DATA void (*gFlashTimerIntrFunc)(void) = NULL;
-extern void sub_800C35C(void);
-extern void remove_some_task(void);
-extern u32 sub_80558AC(void);
-extern u32 sub_8055910(void);
-extern u32 sub_8055940(void);
-extern void CheckForFlashMemory(void);
-
static void UpdateLinkAndCallCallbacks(void);
static void InitMainCallbacks(void);
static void CallCallbacks(void);
diff --git a/src/main_menu.c b/src/main_menu.c
index eb5867d5d..176d6bd99 100644
--- a/src/main_menu.c
+++ b/src/main_menu.c
@@ -1,10 +1,13 @@
#include "global.h"
+#include "main_menu.h"
+#include "asm.h"
#include "save_menu_util.h"
#include "option_menu.h"
#include "text.h"
#include "sprite.h"
#include "task.h"
#include "main.h"
+#include "rom4.h"
#include "rtc.h"
#include "songs.h"
#include "palette.h"
@@ -18,16 +21,6 @@
#define BirchSpeechUpdateWindowText() ((u8)MenuUpdateWindowText_OverrideLineLength(24))
-extern void remove_some_task(void);
-extern void CreatePokeballSprite(u8 r0, u8 r1, u8 r2, u8 r3, u8 s1, u8 s2, u8 s3, u16 s4);
-extern bool32 IsMysteryGiftAvailable(void);
-extern void CB2_ContinueSavedGame(void);
-extern void CB2_InitMysteryEventMenu(void);
-extern void DoNamingScreen(u8 r0, struct SaveBlock2 *r1, u16 r2, u16 r3, u8 s0, MainCallback s4);
-extern void CB2_NewGame(void);
-extern u8 CreateBirchSprite(u8, u8, u8);
-extern u8 CreateTrainerSprite_BirchSpeech(u8, u16, u16, u8, void *);
-
extern struct PaletteFadeControl gPaletteFade;
extern u8 gSaveFileDeletedMessage[];
extern u8 gSaveFileCorruptMessage[];
@@ -43,9 +36,6 @@ extern u8 gMainMenuString_Time[];
extern u8 gMainMenuString_Pokedex[];
extern u8 gMainMenuString_Badges[];
-void CB2_MainMenu(void);
-void VBlankCB_MainMenu(void);
-void CB2_InitMainMenu(void);
static void sub_80096FC(void);
static u32 InitMainMenu(bool8 a1);
static void Task_MainMenuCheckSave(u8 taskId);
@@ -65,7 +55,6 @@ static void PrintPlayerName(void);
static void PrintPlayTime(void);
static void PrintPokedexCount(void);
static void PrintBadgeCount(void);
-void Task_NewGameSpeech1(u8);
extern u16 gMainMenuPalette[];
diff --git a/src/map_obj_80643A4.c b/src/map_obj_80643A4.c
index d30fab49c..20c5303c4 100644
--- a/src/map_obj_80643A4.c
+++ b/src/map_obj_80643A4.c
@@ -1,13 +1,9 @@
#include "global.h"
+#include "asm.h"
#include "sprite.h"
#include "asm_fieldmap.h"
#include "field_effect.h"
-extern void SetObjectSubpriorityByZCoord(u8, struct Sprite *, u8);
-extern u8 FieldObjectDirectionToImageAnimId(u8);
-extern void FieldObjectGetLocalIdAndMap(struct MapObject *, u8 *, u8 *, u8 *);
-extern struct MapObjectGraphicsInfo *GetFieldObjectGraphicsInfo(u8);
-
typedef void (*SpriteStepFunc)(struct Sprite *sprite, u8 dir);
extern u32 gUnknown_0202FF84[];
diff --git a/src/map_obj_lock.c b/src/map_obj_lock.c
index bbe08ac37..cc2befa6d 100644
--- a/src/map_obj_lock.c
+++ b/src/map_obj_lock.c
@@ -1,17 +1,9 @@
#include "global.h"
#include "map_obj_lock.h"
+#include "asm.h"
#include "field_player_avatar.h"
#include "task.h"
-extern void player_bitmagic(void);
-extern void sub_80643A4(struct MapObject *);
-extern void sub_8064470(u8);
-extern u8 GetFieldObjectIdByLocalIdAndMap(u8, u8, u8);
-extern u8 FieldObjectClearAnimIfSpecialAnimFinished(void *);
-extern void sub_80A2178(void);
-extern void sub_806451C(void);
-extern u8 FieldObjectFaceOppositeDirection(void *, u8);
-
extern u16 gScriptFacing;
bool8 walkrun_is_standing_still(void)
diff --git a/src/mori_debug_menu.c b/src/mori_debug_menu.c
index 3353ec58e..b8fe92b9a 100644
--- a/src/mori_debug_menu.c
+++ b/src/mori_debug_menu.c
@@ -1,17 +1,13 @@
#include "global.h"
#include "mori_debug_menu.h"
+#include "asm.h"
#include "start_menu.h"
#include "menu.h"
#include "main.h"
#include "string_util.h"
-extern u16 sub_8041870(u16);
-extern void sub_810CA6C(s32);
extern u8 (*gCallback_03004AE8)(void);
-extern u8 daycare_count_pokemon(u32);
-extern u8 daycare_relationship_score_from_savegame(void);
-
struct DebugMenuAction
{
u8 *text;
diff --git a/src/new_game.c b/src/new_game.c
index 97a6c6ee0..c8221fa5d 100644
--- a/src/new_game.c
+++ b/src/new_game.c
@@ -1,5 +1,7 @@
#include "global.h"
#include "new_game.h"
+#include "asm.h"
+#include "berry.h"
#include "play_time.h"
#include "pokemon_size_record.h"
#include "script.h"
diff --git a/src/palette.c b/src/palette.c
index 53ade0105..bf93a036c 100644
--- a/src/palette.c
+++ b/src/palette.c
@@ -1,5 +1,7 @@
#include "global.h"
#include "palette.h"
+#include "asm.h"
+#include "blend_palette.h"
#include "decompress.h"
enum
@@ -38,8 +40,6 @@ struct PaletteStruct
u8 ps_field_9;
};
-extern void BlendPalette(u16, u16, u8, u16);
-
EWRAM_DATA u16 gPlttBufferUnfaded[0x200] = {0};
EWRAM_DATA u16 gPlttBufferFaded[0x200] = {0};
EWRAM_DATA static struct PaletteStruct sPaletteStructs[0x10] = {0};
diff --git a/src/pokedex.c b/src/pokedex.c
index c7f3b5f5c..8d574ed57 100644
--- a/src/pokedex.c
+++ b/src/pokedex.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "pokedex.h"
+#include "asm.h"
#include "gba/m4a_internal.h"
#include "string_util.h"
#include "m4a.h"
@@ -107,7 +108,6 @@ extern u8 gDexText_RegisterComplete[];
extern void m4aMPlayVolumeControl(struct MusicPlayerInfo *mplayInfo, u16 trackBits, u16 volume);
extern bool8 BeginNormalPaletteFade(u32, s8, u8, u8, u16);
extern void remove_some_task(void);
-extern bool32 IsNationalPokedex(void);
extern u8 sub_8091E3C(void);
extern void sub_80690C8(void);
extern void sub_805469C(void);
diff --git a/src/pokemon_1.c b/src/pokemon_1.c
index 0c34279f7..3971e08dd 100644
--- a/src/pokemon_1.c
+++ b/src/pokemon_1.c
@@ -1,7 +1,9 @@
#include "global.h"
+#include "asm.h"
#include "text.h"
#include "string_util.h"
#include "pokemon.h"
+#include "rom4.h"
#include "species.h"
#include "main.h"
#include "rng.h"
@@ -13,8 +15,6 @@
//Extracts the lower 16 bits of a 32-bit number
#define LOHALF(n) ((n) & 0xFFFF)
-extern u8 sav1_map_get_name();
-
extern struct Pokemon gPlayerParty[6]; // 0x3004360
extern struct Pokemon gEnemyParty[6]; // 0x30045C0
diff --git a/src/pokemon_2.c b/src/pokemon_2.c
index 78b394b87..aeffb29a0 100644
--- a/src/pokemon_2.c
+++ b/src/pokemon_2.c
@@ -1,7 +1,9 @@
#include "global.h"
+#include "asm.h"
#include "text.h"
#include "string_util.h"
#include "pokemon.h"
+#include "rng.h"
#include "species.h"
#include "main.h"
#include "sprite.h"
@@ -49,11 +51,6 @@ extern u8 gUnknown_0820823C[];
extern u8 gStatStageRatios[][2];
extern u8 gHoldEffectToType[][2];
-extern u8 battle_side_get_owner(u8);
-extern u8 battle_get_side_with_given_state(u8);
-extern u32 battle_get_per_side_status(u8);
-extern u8 sub_8018324(u8, u8, u8, u8, u16);
-
u8 sub_803C348(u8 a1)
{
s32 i;
@@ -87,6 +84,7 @@ u8 sub_803C348(u8 a1)
return retVal;
}
+#ifdef NONMATCHING
u8 sub_803C434(u8 a1)
{
u32 status0 = battle_get_per_side_status(a1);
@@ -111,7 +109,7 @@ u8 sub_803C434(u8 a1)
if (sub_803C348(0) > 1)
{
- u32 r = Random();
+ u16 r = Random();
register u32 val asm("r1") = mask2;
val &= r;
if (!val)
@@ -133,6 +131,77 @@ u8 sub_803C434(u8 a1)
return battle_get_side_with_given_state(status);
}
}
+#else
+__attribute__((naked))
+u8 sub_803C434(u8 a1) {
+ asm(".syntax unified\n\
+ push {r4-r6,lr}\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ bl battle_get_per_side_status\n\
+ movs r1, 0x1\n\
+ movs r6, 0x1\n\
+ adds r4, r6, 0\n\
+ ands r4, r0\n\
+ eors r4, r1\n\
+ adds r5, r4, 0\n\
+ ldr r0, _0803C45C\n\
+ ldrh r1, [r0]\n\
+ adds r0, r6, 0\n\
+ ands r0, r1\n\
+ cmp r0, 0\n\
+ bne _0803C460\n\
+ adds r0, r4, 0\n\
+ b _0803C4AA\n\
+ .align 2, 0\n\
+_0803C45C: .4byte gUnknown_020239F8\n\
+_0803C460:\n\
+ movs r0, 0\n\
+ bl sub_803C348\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ cmp r0, 0x1\n\
+ bls _0803C484\n\
+ bl Random\n\
+ adds r1, r6, 0\n\
+ ands r1, r0\n\
+ cmp r1, 0\n\
+ bne _0803C480\n\
+ movs r0, 0x2\n\
+ eors r0, r4\n\
+ b _0803C4AA\n\
+_0803C480:\n\
+ adds r0, r4, 0\n\
+ b _0803C4AA\n\
+_0803C484:\n\
+ ldr r0, _0803C49C\n\
+ ldrb r1, [r0]\n\
+ ldr r2, _0803C4A0\n\
+ lsls r0, r4, 2\n\
+ adds r0, r2\n\
+ ldr r0, [r0]\n\
+ ands r1, r0\n\
+ cmp r1, 0\n\
+ bne _0803C4A4\n\
+ adds r0, r4, 0\n\
+ b _0803C4AA\n\
+ .align 2, 0\n\
+_0803C49C: .4byte gUnknown_02024C0C\n\
+_0803C4A0: .4byte gBitTable\n\
+_0803C4A4:\n\
+ movs r0, 0x2\n\
+ eors r5, r0\n\
+ adds r0, r5, 0\n\
+_0803C4AA:\n\
+ bl battle_get_side_with_given_state\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ pop {r4-r6}\n\
+ pop {r1}\n\
+ bx r1\n\
+ .syntax divided\n");
+}
+#endif
u8 GetMonGender(struct Pokemon *mon)
{
diff --git a/src/record_mixing.c b/src/record_mixing.c
index 1bcd83882..281ab2803 100644
--- a/src/record_mixing.c
+++ b/src/record_mixing.c
@@ -1,7 +1,9 @@
#include "global.h"
#include "record_mixing.h"
+#include "asm.h"
#include "link.h"
#include "menu.h"
+#include "rom4.h"
#include "script.h"
#include "songs.h"
#include "sound.h"
@@ -32,22 +34,6 @@ extern bool8 gReceivedRemoteLinkPlayers;
extern u8 gBlockSendBuffer[BLOCK_BUFFER_SIZE];
extern u16 gBlockRecvBuffer[MAX_LINK_PLAYERS][BLOCK_BUFFER_SIZE / 2];
-extern void sub_8083A84(TaskFunc);
-extern void sub_8041324(struct BoxPokemon *, void *);
-extern void sub_80BD674(void *, u32, u8);
-extern void sub_80BFD44(void *, u32, u8);
-extern void sub_80C0514(void *, u32, u8);
-// UB: sub_80FA4E4 declared with 3 arguments instead of 2
-extern void sub_80FA4E4(void *, u32, u8);
-extern u16 sub_8126338(void);
-extern u8 sub_8083664(void);
-extern void sub_80720B0(void);
-extern void CreateRecordMixingSprite(void);
-extern void DestroyRecordMixingSprite(void);
-extern u16 sub_8055588(void);
-extern void sub_80F7F30(void);
-extern void sub_8134AC0(void *);
-
#define BUFFER_CHUNK_SIZE 200
void sub_80B929C(void)
diff --git a/src/rom4.c b/src/rom4.c
index 493f37513..2fdee966c 100644
--- a/src/rom4.c
+++ b/src/rom4.c
@@ -1,5 +1,10 @@
#include "global.h"
#include "rom4.h"
+#include "asm.h"
+#include "asm_fieldmap.h"
+#include "battle_setup.h"
+#include "berry.h"
+#include "field_map_obj.h"
#include "field_player_avatar.h"
#include "menu.h"
#include "weather.h"
@@ -11,6 +16,7 @@
#include "new_game.h"
#include "heal_location.h"
#include "field_message_box.h"
+#include "safari_zone.h"
#include "script.h"
#include "songs.h"
#include "sound.h"
@@ -23,7 +29,6 @@
#include "field_camera.h"
#include "field_effect.h"
#include "wild_encounter.h"
-#include "asm_fieldmap.h"
#ifdef SAPPHIRE
#define LEGENDARY_MUSIC BGM_OOAME // Heavy Rain
@@ -37,37 +42,6 @@ struct UnkTVStruct
u32 tv_field_4;
};
-struct UnkPlayerStruct
-{
- u8 player_field_0;
- u8 player_field_1;
-};
-
-struct UnkInputStruct
-{
- u8 input_field_0;
- u8 input_field_1;
- u8 input_field_2;
- u8 input_field_3;
-};
-
-struct UnkStruct_8054FF8_Substruct
-{
- s16 x;
- s16 y;
- u8 field_8;
-};
-
-struct UnkStruct_8054FF8
-{
- u8 a;
- u8 b;
- u8 c;
- u8 d;
- struct UnkStruct_8054FF8_Substruct sub;
- u16 field_C;
-};
-
struct LinkPlayerMapObject
{
u8 active;
@@ -140,99 +114,6 @@ extern const struct WarpData gDummyWarpData;
extern s32 gUnknown_0839ACE8;
extern u32 gUnknown_08216694[];
-extern u8 sub_810D32C(void);
-extern void sub_8080B60(void);
-extern void sub_810CC80(void);
-extern void sub_8080AC4(void);
-extern void sub_8080A3C(void);
-extern void atk17_seteffectuser(void);
-extern void sub_80809B0(void);
-extern void sub_8080990(void);
-extern u8 sub_80BBB24(void);
-extern u8 *sub_80682A8(void *, u8, u8);
-extern u8 *sub_8068E24(struct UnkStruct_8054FF8_Substruct *);
-extern u8 ZCoordToPriority(u8);
-
-void sub_8082BD0(u16, u16);
-void player_avatar_init_params_reset(void);
-u8 player_get_direction_lower_nybble(void);
-u8 sub_8053B00(struct UnkPlayerStruct *playerStruct, u16, u8);
-u8 sub_8053B60(struct UnkPlayerStruct *playerStruct, u8, u16, u8);
-u8 MetatileBehavior_IsSurfableWaterOrUnderwater(u8);
-bool8 sub_8056F24(u8);
-bool8 sub_8056F08(u8);
-bool8 MetatileBehavior_IsDoor(u8);
-bool8 MetatileBehavior_IsSouthArrowWarp(u8);
-bool8 MetatileBehavior_IsNorthArrowWarp(u8);
-bool8 MetatileBehavior_IsWestArrowWarp(u8);
-bool8 MetatileBehavior_IsEastArrowWarp(u8);
-bool8 MetatileBehavior_IsLadder(u8);
-u16 cur_mapdata_block_role_at_screen_center_acc_to_sav1(void);
-bool32 sub_8053C44(void);
-void sub_8053C98(void);
-void sub_8053F0C(void);
-u8 is_light_level_8_or_9(u8);
-void sub_8054164(void);
-void sub_8055354(void);
-void c2_overworld(void);
-void CB2_LoadMap2(void);
-void c2_80567AC(void);
-void c2_exit_to_overworld_2_link(void);
-void c2_exit_to_overworld_2_local(void);
-void FieldClearVBlankHBlankCallbacks(void);
-void SetFieldVBlankCallback(void);
-void VBlankCB_Field(void);
-bool32 sub_805483C(u8 *);
-bool32 sub_805493C(u8 *, u32);
-bool32 sub_8054A4C(u8 *);
-bool32 sub_8054A9C(u8 *a1);
-void do_load_map_stuff_loop(u8 *a1);
-void sub_8054BA8(void);
-void sub_8054C2C(void);
-void sub_8054C54(void);
-void sub_8054D4C(u32 a1);
-void sub_8054D90(void);
-void mli4_mapscripts_and_other(void);
-void sub_8054E20(void);
-void sub_8054E34(void);
-void sub_8054E60(void);
-void sub_8054E7C(void);
-void sub_8054E98(void);
-void sub_8054EC8(void);
-void sub_8054F48(void);
-void sub_8054F70(void);
-u16 sub_805530C(u16);
-void sub_8055340(u16 *);
-u16 sub_8055390(u32);
-u16 sub_80553E4(u32);
-u16 sub_8055408(u32);
-u16 sub_8055438(u32);
-bool32 sub_8055618(struct UnkStruct_8054FF8 *);
-bool32 sub_8055630(struct UnkStruct_8054FF8 *);
-u8 *sub_8055648(struct UnkStruct_8054FF8 *);
-bool32 sub_8055660(struct UnkStruct_8054FF8 *);
-u8 *sub_805568C(struct UnkStruct_8054FF8 *);
-u16 sub_8055758(u8 *);
-void sub_80557E8(void);
-void sub_80557F4(void);
-void sub_8055808(u8 *);
-void sub_8055824(void);
-void sub_8055840(u8 *);
-void sub_805585C(void);
-bool32 sub_8055870(void);
-void SpawnLinkPlayerMapObject(u8, s16, s16, u8);
-void InitLinkPlayerMapObjectPos(struct MapObject *, s16, s16);
-void sub_80555B0(int, int, struct UnkStruct_8054FF8 *);
-u8 sub_8055AE8(u8);
-void sub_8055B08(u8, u16 *, u16 *);
-u8 sub_8055B30(u8);
-u8 sub_8055B50(u8);
-u8 GetLinkPlayerIdAt(s16, s16);
-void sub_8055BFC(u8, u8);
-u8 npc_something3(u8, u8);
-u8 LinkPlayerDetectCollision(u8, u8, s16, s16);
-void CreateLinkPlayerSprite(u8);
-void SpriteCB_LinkPlayer(struct Sprite *);
void sub_8052F5C(void)
{
diff --git a/src/safari_zone.c b/src/safari_zone.c
index deb8817ec..118797136 100644
--- a/src/safari_zone.c
+++ b/src/safari_zone.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "safari_zone.h"
+#include "asm.h"
#include "field_player_avatar.h"
#include "flag.h"
#include "main.h"
@@ -20,9 +21,6 @@ struct PokeblockFeeder
static void ClearAllPokeblockFeeders(void);
static void DecrementFeederStepCounters(void);
-extern void c2_exit_to_overworld_2_switch(void);
-extern void c2_exit_to_overworld_1_continue_scripts_restart_music(void);
-extern void sub_8080E44(void);
extern u8 gUnknown_02024D26;
diff --git a/src/save.c b/src/save.c
index 6d9ec8b03..80e913794 100644
--- a/src/save.c
+++ b/src/save.c
@@ -1,12 +1,10 @@
#include "global.h"
#include "save.h"
+#include "asm.h"
#include "gba/gba.h"
#include "rom4.h"
#include "gba/flash_internal.h"
-extern u32 sub_8053108(u8);
-extern u32 ProgramFlashSectorAndVerifyNBytes(u16 sectorNum, u8 *src, u32 n);
-
extern struct SaveSection unk_2000000;
extern u32 gUnknown_02039284;
diff --git a/src/save_menu_util.c b/src/save_menu_util.c
index c315acda5..ff42d66ea 100644
--- a/src/save_menu_util.c
+++ b/src/save_menu_util.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "save_menu_util.h"
+#include "asm.h"
#include "menu.h"
#include "flag.h"
#include "string_util.h"
diff --git a/src/scrcmd.c b/src/scrcmd.c
index e80777489..8051b0cb0 100644
--- a/src/scrcmd.c
+++ b/src/scrcmd.c
@@ -1,4 +1,7 @@
#include "global.h"
+#include "asm.h"
+#include "battle_setup.h"
+#include "berry.h"
#include "field_player_avatar.h"
#include "item.h"
#include "script.h"
@@ -21,101 +24,6 @@
#include "coins.h"
#include "field_effect.h"
-extern void ClearRamScript(void);
-extern void sub_8126160(u8);
-extern u8 IsThereStorageSpaceForDecoration(u8);
-extern s8 sub_81340A8(u8);
-extern u8 sub_8134074(u8);
-extern u8 sub_8133FE4(u8);
-extern void sub_8081594(u8);
-extern void sub_8053CE4(u32);
-extern void DoTimeBasedEvents(void);
-extern void activate_per_step_callback(u8);
-extern void sub_8053D14(u16);
-extern void sub_8080E88(void);
-extern void player_avatar_init_params_reset(void);
-extern void sp13E_warp_to_last_warp(void);
-extern void sub_8080EF0(void);
-extern void sp13F_fall_to_last_warp(void);
-extern void sub_8053720(s16, s16);
-extern void sub_8080F68(void);
-extern void saved_warp2_set_2(s8, s8, s8, s8, s8, s8);
-extern void sub_8053690(s8, s8, s8, s8, s8);
-extern void sub_80536E4(s8, s8, s8, s8, s8);
-extern void sav1_set_battle_music_maybe(u16);
-extern void sub_8053F84(void);
-extern void sub_8053FB0(u16);
-extern u8 exec_movement(u8, u8, u8, void *);
-extern bool8 sub_80A212C(u8, u8, u8);
-extern void RemoveFieldObjectByLocalIdAndMap(u8, u8, u8);
-extern u8 show_sprite(u8, u8, u8);
-extern void sub_805C0F8(u8, u8, u8, s16, s16);
-extern void update_saveblock1_field_object_coords(u8, s16, s16);
-extern void sub_805C78C(u8, u8, u8);
-extern void npc_by_local_id_and_map_set_field_1_bit_x20(u8, u8, u8, u8);
-extern void sub_805BCF0(u8, u8, u8, u8);
-extern void sub_805BD48(u8, u8, u8);
-extern u8 FieldObjectFaceOppositeDirection(void *, u8);
-extern void FieldObjectTurnByLocalIdAndMap(u8, u8, u8, u8);
-extern void update_saveblock1_field_object_movement_behavior(u8, u8);
-extern u8 sub_805B410(u8, u8, s16, s16, u8, u8);
-extern void sub_8064990(u8, u8);
-extern bool32 is_c1_link_related_active(void);
-extern u8 GetFieldObjectIdByLocalIdAndMap(u8, u8, u8);
-extern u8 FieldObjectClearAnimIfSpecialAnimFinished(void *);
-extern void sub_80A2178(void);
-extern void sub_806451C(void);
-extern bool8 yes_no_box(u8, u8);
-extern bool8 sub_80B5054(u8, u8, u8, u8);
-extern bool8 sub_80B50B0(u8, u8, u8, u8, u8);
-extern bool8 sub_80B5578(u8, u8, u8, u8, u8);
-extern bool8 Multichoice(u8, u8, u8, u8);
-extern bool8 sub_80B58C4(u16, u8, u8);
-extern void *picbox_close(void);
-extern void sub_8106630(u32);
-extern void ShowContestWinner(void);
-extern u8 GetLeadMonIndex(void);
-extern u8 sub_80BF0B8(u32);
-extern void sub_80B79B8(u32 *, u32);
-extern void sub_80B79E0(u32 *, u32);
-extern bool8 IsEnoughMoney(u32, u32);
-extern void sub_80B7C14(u32, u8, u8);
-extern void RemoveMoneyLabelObject(u8, u8);
-extern void sub_80B7BEC(u32, u8, u8);
-extern void *TrainerBattleConfigure(u8 *);
-extern void sub_80825E4(void);
-extern u8 *sub_80826E8(void);
-extern u8 *sub_8082700(void);
-extern u8 trainer_flag_check(u16);
-extern void trainer_flag_set(u16);
-extern void trainer_flag_clear(u16);
-extern void ScriptWildBattle(u16, u8, u16);
-extern void sub_8081B3C(void);
-extern void CreatePokemartMenu(void *);
-extern void CreateDecorationShop1Menu(void *);
-extern void CreateDecorationShop2Menu(void *);
-extern void PlaySlotMachine(u8, void *);
-extern void PlantBerryTree(u8, u8, u8, bool8);
-extern bool8 GetPriceReduction(u8);
-extern void sub_80F99CC(void);
-extern void sub_80C48C8(void);
-extern void sub_80C4940(void);
-extern void sub_80C4980(u8);
-extern void sub_8053588(u8);
-extern u16 sub_8058790(u32, u32);
-extern bool8 FieldAnimateDoorOpen(u32, u32);
-extern bool8 FieldAnimateDoorClose(u32, u32);
-extern bool8 FieldIsDoorAnimationRunning(void);
-extern void FieldSetDoorOpened(u32, u32);
-extern void FieldSetDoorClosed(u32, u32);
-extern void ScriptAddElevatorMenuItem(u8, u8, u8, u8);
-extern void ScriptShowElevatorMenu(void);
-extern u8 ScriptGiveMon(u16, u8, u16, u32, u32, u8);
-extern u8 ScriptGiveEgg(u16);
-extern void ScriptSetMonMoveSlot(u8, u16, u8);
-extern bool8 pokemon_has_move(struct Pokemon *, u16);
-extern void c2_exit_to_overworld_1_continue_scripts_restart_music(void);
-
typedef u16 (*SpecialFunc)(void);
typedef void (*NativeFunc)(void);
diff --git a/src/sound.c b/src/sound.c
index 77ad2b9f6..56719aa08 100644
--- a/src/sound.c
+++ b/src/sound.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "sound.h"
+#include "asm.h"
#include "gba/m4a_internal.h"
#include "task.h"
#include "songs.h"
@@ -11,8 +12,6 @@ struct Fanfare
u16 duration;
};
-extern u32 SpeciesToCryId(u32);
-
extern u16 gUnknown_020239F8;
extern struct MusicPlayerInfo *gMPlay_PokemonCry;
extern u8 gPokemonCryBGMDuckingCounter;
diff --git a/src/start_menu.c b/src/start_menu.c
index 3237632a8..3cffae111 100644
--- a/src/start_menu.c
+++ b/src/start_menu.c
@@ -1,8 +1,10 @@
#include "global.h"
#include "start_menu.h"
+#include "asm.h"
#include "main.h"
#include "menu.h"
#include "palette.h"
+#include "pokedex.h"
#include "script.h"
#include "songs.h"
#include "sound.h"
@@ -19,25 +21,6 @@
#include "map_obj_lock.h"
#include "save_menu_util.h"
-//External functions
-extern void sub_8047A1C(void);
-extern void sub_8047A34(void);
-extern void remove_some_task(void);
-extern void dp12_8087EA4(void);
-extern void sub_8093130(u8, void (*)(void));
-extern void sub_805469C(void);
-extern void SafariZoneRetirePrompt(void);
-extern void sub_8093110(void (*)(void));
-extern void sub_80EBA5C(void);
-extern void sub_80A53F8(void);
-extern void sub_8089A70(void);
-extern void CB2_InitPokedex(void);
-extern u16 GetNationalPokedexCount(u8);
-extern bool32 is_c1_link_related_active();
-extern void player_bitmagic(void);
-extern u8 *sub_8072C44(u8 *, s32, u8, u8);
-extern bool32 is_c1_link_related_active(void);
-
//Menu actions
enum {
MENU_ACTION_POKEDEX,
diff --git a/src/starter_choose.c b/src/starter_choose.c
index 725d481be..f21ddde1c 100644
--- a/src/starter_choose.c
+++ b/src/starter_choose.c
@@ -1,8 +1,10 @@
#include "global.h"
#include "starter_choose.h"
+#include "asm.h"
#include "main.h"
#include "menu.h"
#include "palette.h"
+#include "pokedex.h"
#include "songs.h"
#include "sound.h"
#include "string_util.h"
@@ -10,10 +12,6 @@
#include "trig.h"
#include "decompress.h"
-//Functions that need to be put in headers
-void remove_some_task(void);
-u16 SpeciesToNationalPokedexNum(u16);
-
struct MonCoords
{
u8 x, y;
@@ -54,7 +52,6 @@ static void Task_StarterChoose4(u8 taskId);
static void Task_StarterChoose5(u8 taskId);
static void Task_StarterChoose6(u8 taskId);
-extern u8 *GetPokemonCategory(u16);
static void CreateStarterPokemonLabel(u8, u8);
static u8 CreatePokemonFrontSprite(u16, u8, u8);
diff --git a/src/title_screen.c b/src/title_screen.c
index 72833a4e9..6100fbdc5 100644
--- a/src/title_screen.c
+++ b/src/title_screen.c
@@ -1,5 +1,9 @@
#include "global.h"
#include "title_screen.h"
+#include "asm.h"
+#include "clear_save_data_menu.h"
+#include "m4a.h"
+#include "main_menu.h"
#include "intro.h"
#include "gba/m4a_internal.h"
#include "main.h"
@@ -9,11 +13,6 @@
#include "task.h"
#include "decompress.h"
-extern void m4aSongNumStart(u16);
-extern void CB2_InitMainMenu(void);
-extern void CB2_InitClearSaveDataScreen(void);
-extern void CB2_InitResetRtcScreen(void);
-
extern u8 gReservedSpritePaletteCount;
extern struct MusicPlayerInfo gMPlay_BGM;
extern u8 gUnknown_0202F7E4;
diff --git a/src/trainer_see.c b/src/trainer_see.c
index 6e2292067..ed0b5caf4 100644
--- a/src/trainer_see.c
+++ b/src/trainer_see.c
@@ -1,5 +1,7 @@
#include "global.h"
#include "trainer_see.h"
+#include "asm.h"
+#include "battle_setup.h"
#include "field_player_avatar.h"
#include "field_map_obj.h"
#include "asm_fieldmap.h"
@@ -8,24 +10,6 @@
#include "field_effect.h"
#include "script.h"
-extern u8 * GetFieldObjectScriptPointerByFieldObjectId(u8);
-extern u8 * GetTrainerFlagFromScriptPointer(u8 *);
-extern u8 sub_8060024(struct MapObject *, s16, s16, u8);
-extern u8 npc_block_way(struct MapObject *, s16, s16, u8);
-extern u8 npc_running_behaviour_by_direction(u8);
-extern u8 GetGoSpeed0AnimId(u8);
-extern u8 GetOppositeDirection(u8);
-extern u8 GetFaceDirectionAnimId(u8);
-extern bool8 FieldObjectIsSpecialAnimOrDirectionSequenceAnimActive(struct MapObject *);
-extern bool8 FieldObjectCheckIfSpecialAnimFinishedOrInactive(struct MapObject *);
-extern bool8 FieldObjectClearAnimIfSpecialAnimFinished(struct MapObject *);
-extern void FieldObjectClearAnim(struct MapObject *);
-extern void TrainerWantsBattle(u8, u8 *);
-extern void FieldObjectSetSpecialAnim(struct MapObject *, u8);
-extern void LoadWordFromTwoHalfwords(u32, u8 *);
-extern void StoreWordInTwoHalfwords(u32, u8 *);
-
-
extern bool8 (*gIsTrainerInRange[])(struct MapObject *, u16, s16, s16);
extern bool8 (*gTrainerSeeFuncList[])(u8, struct Task *, struct MapObject *);
extern bool8 (*gTrainerSeeFuncList2[])(u8, struct Task *, struct MapObject *);
diff --git a/src/truck_scene.c b/src/truck_scene.c
index c8997a643..4e45bd165 100644
--- a/src/truck_scene.c
+++ b/src/truck_scene.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "truck_scene.h"
+#include "asm.h"
#include "palette.h"
#include "task.h"
#include "script.h"
@@ -9,9 +10,6 @@
extern s8 gTruckCamera_HorizontalTable[];
-extern void SetCameraPanning(s16 a1, s16 a2);
-extern void sub_805BD90(u8 localId, u8 mapNum, u8 mapGroup, s16 x, s16 y);
-
s32 GetTruckCameraBobbingY(int a1)
{
s32 result;
diff --git a/src/wallclock.c b/src/wallclock.c
index e41bf761d..abfc4a12a 100644
--- a/src/wallclock.c
+++ b/src/wallclock.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "wallclock.h"
+#include "asm.h"
#include "decompress.h"
#include "main.h"
#include "menu.h"
@@ -10,9 +11,6 @@
#include "trig.h"
#include "sound.h"
-//Functions that need to be put in headers
-void remove_some_task(void);
-
extern u16 gSpecialVar_0x8004;
extern u16 gMiscClockMale_Pal[];
extern u16 gMiscClockFemale_Pal[];
diff --git a/src/weather.c b/src/weather.c
index 07a8f9f91..90831f014 100644
--- a/src/weather.c
+++ b/src/weather.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "weather.h"
+#include "asm.h"
#include "task.h"
#include "sprite.h"
#include "palette.h"
diff --git a/src/wild_encounter.c b/src/wild_encounter.c
index d021189e9..84943b0d5 100644
--- a/src/wild_encounter.c
+++ b/src/wild_encounter.c
@@ -1,5 +1,6 @@
#include "global.h"
#include "wild_encounter.h"
+#include "asm.h"
#include "field_player_avatar.h"
#include "safari_zone.h"
#include "battle_setup.h"
@@ -34,14 +35,6 @@ struct WildPokemonHeader
struct WildPokemonInfo *fishingMonsInfo;
};
-extern bool8 sub_805759C(u8);
-extern s16 sub_810CAE4(u8, struct Pokeblock *);
-extern u8 MetatileBehavior_IsLandWildEncounter(u8);
-extern u8 sub_81344CC(void);
-extern u8 MetatileBehavior_IsWaterWildEncounter(u8);
-extern u8 MetatileBehavior_IsBridge(u8);
-extern void sub_80BEA50(u16);
-
extern u16 gRoute119WaterTileData[];
extern struct WildPokemonHeader gWildMonHeaders[];
extern struct Pokemon gEnemyParty[6];