From ea01b132b26b5b129a8150f72388aba80a834384 Mon Sep 17 00:00:00 2001 From: GriffinR Date: Thu, 14 May 2020 16:29:19 -0400 Subject: Label in_connection's field in ObjectEventTemplate --- src/event_object_movement.c | 2 +- src/overworld.c | 29 +++++++++++++---------------- 2 files changed, 14 insertions(+), 17 deletions(-) (limited to 'src') diff --git a/src/event_object_movement.c b/src/event_object_movement.c index 72ce58bb5..7d2a13b33 100644 --- a/src/event_object_movement.c +++ b/src/event_object_movement.c @@ -1904,7 +1904,7 @@ int SpawnSpecialObjectEventParameterized(u8 graphicsId, u8 movementBehavior, u8 y -= 7; objectEventTemplate.localId = localId; objectEventTemplate.graphicsId = graphicsId; - objectEventTemplate.unk2 = 0; + objectEventTemplate.inConnection = 0; objectEventTemplate.x = x; objectEventTemplate.y = y; objectEventTemplate.elevation = z; diff --git a/src/overworld.c b/src/overworld.c index 505541e51..ce14ae88b 100644 --- a/src/overworld.c +++ b/src/overworld.c @@ -400,30 +400,27 @@ void ApplyNewEncryptionKeyToGameStats(u32 newKey) // Routines related to object events -static void sub_8054F68(void) +static void LoadObjEventTemplatesFromHeader(void) { u8 i, j; - u8 mapGroup; - u8 mapNum; - u8 localId; - const struct MapHeader * linkedMap; - for (i = 0, j = 0; i < gMapHeader.events->objectEventCount; i++) { - if (gMapHeader.events->objectEvents[i].unk2 == 0xFF) + if (gMapHeader.events->objectEvents[i].inConnection == 0xFF) { - localId = gMapHeader.events->objectEvents[i].elevation; - mapNum = gMapHeader.events->objectEvents[i].trainerType; - mapGroup = gMapHeader.events->objectEvents[i].trainerRange_berryTreeId; - linkedMap = Overworld_GetMapHeaderByGroupAndId(mapGroup, mapNum); - gSaveBlock1Ptr->objectEventTemplates[j] = linkedMap->events->objectEvents[localId - 1]; + // load "in_connection" object from the connecting map + u8 localId = gMapHeader.events->objectEvents[i].elevation; + u8 mapNum = gMapHeader.events->objectEvents[i].trainerType; + u8 mapGroup = gMapHeader.events->objectEvents[i].trainerRange_berryTreeId; + const struct MapHeader * connectionMap = Overworld_GetMapHeaderByGroupAndId(mapGroup, mapNum); + + gSaveBlock1Ptr->objectEventTemplates[j] = connectionMap->events->objectEvents[localId - 1]; gSaveBlock1Ptr->objectEventTemplates[j].localId = gMapHeader.events->objectEvents[i].localId; gSaveBlock1Ptr->objectEventTemplates[j].x = gMapHeader.events->objectEvents[i].x; gSaveBlock1Ptr->objectEventTemplates[j].y = gMapHeader.events->objectEvents[i].y; gSaveBlock1Ptr->objectEventTemplates[j].elevation = localId; gSaveBlock1Ptr->objectEventTemplates[j].trainerType = mapNum; gSaveBlock1Ptr->objectEventTemplates[j].trainerRange_berryTreeId = mapGroup; - gSaveBlock1Ptr->objectEventTemplates[j].unk2 = 0xFF; + gSaveBlock1Ptr->objectEventTemplates[j].inConnection = 0xFF; j++; } else @@ -758,7 +755,7 @@ void LoadMapFromCameraTransition(u8 mapGroup, u8 mapNum) Overworld_TryMapConnectionMusicTransition(); ApplyCurrentWarp(); LoadCurrentMapData(); - sub_8054F68(); + LoadObjEventTemplatesFromHeader(); TrySetMapSaveWarpStatus(); ClearTempFieldEventData(); ResetCyclingRoadChallengeData(); @@ -791,7 +788,7 @@ static void mli0_load_map(bool32 a1) bool8 isOutdoors; LoadCurrentMapData(); - sub_8054F68(); + LoadObjEventTemplatesFromHeader(); isOutdoors = IsMapTypeOutdoors(gMapHeader.mapType); TrySetMapSaveWarpStatus(); @@ -818,7 +815,7 @@ static void sub_80559A8(void) bool8 isOutdoors; LoadCurrentMapData(); - sub_8054F68(); + LoadObjEventTemplatesFromHeader(); isOutdoors = IsMapTypeOutdoors(gMapHeader.mapType); TrySetMapSaveWarpStatus(); SetSav1WeatherFromCurrMapHeader(); -- cgit v1.2.3 From 992fba2bc534e6ceaa69938baada1427e03d83e1 Mon Sep 17 00:00:00 2001 From: GriffinR Date: Thu, 14 May 2020 19:14:34 -0400 Subject: Fix nonmatching build --- src/credits.c | 2 ++ src/event_object_movement.c | 2 +- src/help_message.c | 1 + src/help_system.c | 1 + 4 files changed, 5 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/credits.c b/src/credits.c index e00587ff2..4ef4a1a9d 100644 --- a/src/credits.c +++ b/src/credits.c @@ -9,6 +9,8 @@ #include "graphics.h" #include "strings.h" #include "trainer_pokemon_sprites.h" +#include "menu.h" +#include "field_weather.h" #include "constants/species.h" #include "constants/maps.h" #include "constants/field_weather.h" diff --git a/src/event_object_movement.c b/src/event_object_movement.c index 7d2a13b33..bc3bea584 100644 --- a/src/event_object_movement.c +++ b/src/event_object_movement.c @@ -1335,7 +1335,7 @@ static u8 InitObjectEventStateFromTemplate(struct ObjectEventTemplate *template, s16 y2; s16 elevation2; - if(template->unk2 == 0xFF) + if(template->inConnection == 0xFF) { var = 1; mapNum = template2->trainerType; diff --git a/src/help_message.c b/src/help_message.c index 2fd76e432..49b2c5114 100644 --- a/src/help_message.c +++ b/src/help_message.c @@ -1,4 +1,5 @@ #include "global.h" +#include "malloc.h" #include "menu.h" static EWRAM_DATA u8 sHelpMessageWindowId = 0; diff --git a/src/help_system.c b/src/help_system.c index 9c794f878..87fabbd09 100644 --- a/src/help_system.c +++ b/src/help_system.c @@ -5,6 +5,7 @@ #include "help_system.h" #include "list_menu.h" #include "strings.h" +#include "event_data.h" #include "constants/songs.h" extern u8 gGlyphInfo[]; -- cgit v1.2.3