Merge branch '_pret/master' into _RHH/pr/upcoming/pret_20240210
# Conflicts: # gflib/malloc.c
This commit is contained in:
commit
ec83b11354
13 changed files with 159 additions and 119 deletions
|
@ -38,18 +38,24 @@ void *AllocInternal(void *heapStart, u32 size, const char *location)
|
||||||
if (size & 3)
|
if (size & 3)
|
||||||
size = 4 * ((size / 4) + 1);
|
size = 4 * ((size / 4) + 1);
|
||||||
|
|
||||||
for (;;) {
|
for (;;)
|
||||||
|
{
|
||||||
// Loop through the blocks looking for unused block that's big enough.
|
// Loop through the blocks looking for unused block that's big enough.
|
||||||
|
|
||||||
if (!pos->allocated) {
|
if (!pos->allocated)
|
||||||
|
{
|
||||||
foundBlockSize = pos->size;
|
foundBlockSize = pos->size;
|
||||||
|
|
||||||
if (foundBlockSize >= size) {
|
if (foundBlockSize >= size)
|
||||||
if (foundBlockSize - size < 2 * sizeof(struct MemBlock)) {
|
{
|
||||||
|
if (foundBlockSize - size < 2 * sizeof(struct MemBlock))
|
||||||
|
{
|
||||||
// The block isn't much bigger than the requested size,
|
// The block isn't much bigger than the requested size,
|
||||||
// so just use it.
|
// so just use it.
|
||||||
pos->allocated = TRUE;
|
pos->allocated = TRUE;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// The block is significantly bigger than the requested
|
// The block is significantly bigger than the requested
|
||||||
// size, so split the rest into a separate block.
|
// size, so split the rest into a separate block.
|
||||||
foundBlockSize -= sizeof(struct MemBlock);
|
foundBlockSize -= sizeof(struct MemBlock);
|
||||||
|
@ -104,15 +110,18 @@ void *AllocInternal(void *heapStart, u32 size, const char *location)
|
||||||
|
|
||||||
void FreeInternal(void *heapStart, void *pointer)
|
void FreeInternal(void *heapStart, void *pointer)
|
||||||
{
|
{
|
||||||
if (pointer) {
|
if (pointer)
|
||||||
|
{
|
||||||
struct MemBlock *head = (struct MemBlock *)heapStart;
|
struct MemBlock *head = (struct MemBlock *)heapStart;
|
||||||
struct MemBlock *block = (struct MemBlock *)((u8 *)pointer - sizeof(struct MemBlock));
|
struct MemBlock *block = (struct MemBlock *)((u8 *)pointer - sizeof(struct MemBlock));
|
||||||
block->allocated = FALSE;
|
block->allocated = FALSE;
|
||||||
|
|
||||||
// If the freed block isn't the last one, merge with the next block
|
// If the freed block isn't the last one, merge with the next block
|
||||||
// if it's not in use.
|
// if it's not in use.
|
||||||
if (block->next != head) {
|
if (block->next != head)
|
||||||
if (!block->next->allocated) {
|
{
|
||||||
|
if (!block->next->allocated)
|
||||||
|
{
|
||||||
block->size += sizeof(struct MemBlock) + block->next->size;
|
block->size += sizeof(struct MemBlock) + block->next->size;
|
||||||
block->next->magic = 0;
|
block->next->magic = 0;
|
||||||
block->next = block->next->next;
|
block->next = block->next->next;
|
||||||
|
@ -123,8 +132,10 @@ void FreeInternal(void *heapStart, void *pointer)
|
||||||
|
|
||||||
// If the freed block isn't the first one, merge with the previous block
|
// If the freed block isn't the first one, merge with the previous block
|
||||||
// if it's not in use.
|
// if it's not in use.
|
||||||
if (block != head) {
|
if (block != head)
|
||||||
if (!block->prev->allocated) {
|
{
|
||||||
|
if (!block->prev->allocated)
|
||||||
|
{
|
||||||
block->prev->next = block->next;
|
block->prev->next = block->next;
|
||||||
|
|
||||||
if (block->next != head)
|
if (block->next != head)
|
||||||
|
@ -141,7 +152,8 @@ void *AllocZeroedInternal(void *heapStart, u32 size, const char *location)
|
||||||
{
|
{
|
||||||
void *mem = AllocInternal(heapStart, size, location);
|
void *mem = AllocInternal(heapStart, size, location);
|
||||||
|
|
||||||
if (mem != NULL) {
|
if (mem != NULL)
|
||||||
|
{
|
||||||
if (size & 3)
|
if (size & 3)
|
||||||
size = 4 * ((size / 4) + 1);
|
size = 4 * ((size / 4) + 1);
|
||||||
|
|
||||||
|
|
|
@ -9,18 +9,6 @@
|
||||||
#define METATILE_BattleDome_Door_Lobby 0x209
|
#define METATILE_BattleDome_Door_Lobby 0x209
|
||||||
#define METATILE_BattleDome_Door_PreBattleRoom 0x20A
|
#define METATILE_BattleDome_Door_PreBattleRoom 0x20A
|
||||||
|
|
||||||
// gTileset_BattleFrontierOutsideEast
|
|
||||||
#define METATILE_BattleFrontierOutsideEast_Door 0x3FC
|
|
||||||
#define METATILE_BattleFrontierOutsideEast_Door_BattleArena 0x291
|
|
||||||
#define METATILE_BattleFrontierOutsideEast_Door_BattleTower 0x329
|
|
||||||
#define METATILE_BattleFrontierOutsideEast_Door_Sliding 0x396
|
|
||||||
|
|
||||||
// gTileset_BattleFrontierOutsideWest
|
|
||||||
#define METATILE_BattleFrontierOutsideWest_Door 0x3FC
|
|
||||||
#define METATILE_BattleFrontierOutsideWest_Door_BattleDome 0x28A
|
|
||||||
#define METATILE_BattleFrontierOutsideWest_Door_BattleFactory 0x263
|
|
||||||
#define METATILE_BattleFrontierOutsideWest_Door_Sliding 0x396
|
|
||||||
|
|
||||||
// gTileset_BattleFrontier
|
// gTileset_BattleFrontier
|
||||||
#define METATILE_BattleFrontier_CorridorOpenDoor_Bottom 0x20F
|
#define METATILE_BattleFrontier_CorridorOpenDoor_Bottom 0x20F
|
||||||
#define METATILE_BattleFrontier_CorridorOpenDoor_Top 0x207
|
#define METATILE_BattleFrontier_CorridorOpenDoor_Top 0x207
|
||||||
|
@ -36,6 +24,18 @@
|
||||||
#define METATILE_BattleFrontier_Elevator_Top1 0x32A
|
#define METATILE_BattleFrontier_Elevator_Top1 0x32A
|
||||||
#define METATILE_BattleFrontier_Elevator_Top2 0x32B
|
#define METATILE_BattleFrontier_Elevator_Top2 0x32B
|
||||||
|
|
||||||
|
// gTileset_BattleFrontierOutsideEast
|
||||||
|
#define METATILE_BattleFrontierOutsideEast_Door 0x3FC
|
||||||
|
#define METATILE_BattleFrontierOutsideEast_Door_BattleArena 0x291
|
||||||
|
#define METATILE_BattleFrontierOutsideEast_Door_BattleTower 0x329
|
||||||
|
#define METATILE_BattleFrontierOutsideEast_Door_Sliding 0x396
|
||||||
|
|
||||||
|
// gTileset_BattleFrontierOutsideWest
|
||||||
|
#define METATILE_BattleFrontierOutsideWest_Door 0x3FC
|
||||||
|
#define METATILE_BattleFrontierOutsideWest_Door_BattleDome 0x28A
|
||||||
|
#define METATILE_BattleFrontierOutsideWest_Door_BattleFactory 0x263
|
||||||
|
#define METATILE_BattleFrontierOutsideWest_Door_Sliding 0x396
|
||||||
|
|
||||||
// gTileset_BattlePalace
|
// gTileset_BattlePalace
|
||||||
#define METATILE_BattlePalace_Door 0x219
|
#define METATILE_BattlePalace_Door 0x219
|
||||||
|
|
||||||
|
@ -272,6 +272,18 @@
|
||||||
#define METATILE_Lavaridge_NormalGrass 0x206
|
#define METATILE_Lavaridge_NormalGrass 0x206
|
||||||
#define METATILE_Lavaridge_RockWall 0x274
|
#define METATILE_Lavaridge_RockWall 0x274
|
||||||
|
|
||||||
|
// gTileset_Lilycove
|
||||||
|
#define METATILE_Lilycove_Door 0x246
|
||||||
|
#define METATILE_Lilycove_Door_DeptStore 0x30C
|
||||||
|
#define METATILE_Lilycove_Door_SafariZone 0x32D
|
||||||
|
#define METATILE_Lilycove_Door_Wooden 0x28E
|
||||||
|
#define METATILE_Lilycove_Wailmer0 0x290
|
||||||
|
#define METATILE_Lilycove_Wailmer0_Alt 0x298
|
||||||
|
#define METATILE_Lilycove_Wailmer1 0x291
|
||||||
|
#define METATILE_Lilycove_Wailmer1_Alt 0x299
|
||||||
|
#define METATILE_Lilycove_Wailmer2 0x2A0
|
||||||
|
#define METATILE_Lilycove_Wailmer3 0x2A1
|
||||||
|
|
||||||
// gTileset_LilycoveMuseum
|
// gTileset_LilycoveMuseum
|
||||||
#define METATILE_LilycoveMuseum_Painting0_Left 0x25A
|
#define METATILE_LilycoveMuseum_Painting0_Left 0x25A
|
||||||
#define METATILE_LilycoveMuseum_Painting0_Right 0x25B
|
#define METATILE_LilycoveMuseum_Painting0_Right 0x25B
|
||||||
|
@ -284,17 +296,31 @@
|
||||||
#define METATILE_LilycoveMuseum_Painting4_Left 0x262
|
#define METATILE_LilycoveMuseum_Painting4_Left 0x262
|
||||||
#define METATILE_LilycoveMuseum_Painting4_Right 0x263
|
#define METATILE_LilycoveMuseum_Painting4_Right 0x263
|
||||||
|
|
||||||
// gTileset_Lilycove
|
// gTileset_Mauville
|
||||||
#define METATILE_Lilycove_Door 0x246
|
#define METATILE_Mauville_DeepSand_BottomMid 0x259
|
||||||
#define METATILE_Lilycove_Door_DeptStore 0x30C
|
#define METATILE_Mauville_DeepSand_Center 0x251
|
||||||
#define METATILE_Lilycove_Door_SafariZone 0x32D
|
#define METATILE_Mauville_Door 0x2AC
|
||||||
#define METATILE_Lilycove_Door_Wooden 0x28E
|
#define METATILE_Mauville_Door_BattleTent 0x3D4
|
||||||
#define METATILE_Lilycove_Wailmer0 0x290
|
#define METATILE_Mauville_Door_CyclingRoad 0x289
|
||||||
#define METATILE_Lilycove_Wailmer0_Alt 0x298
|
#define METATILE_Mauville_Door_Verdanturf 0x3A1
|
||||||
#define METATILE_Lilycove_Wailmer1 0x291
|
#define METATILE_Mauville_MirageTower_Tile0 0x3D8
|
||||||
#define METATILE_Lilycove_Wailmer1_Alt 0x299
|
#define METATILE_Mauville_MirageTower_Tile1 0x3D9
|
||||||
#define METATILE_Lilycove_Wailmer2 0x2A0
|
#define METATILE_Mauville_MirageTower_Tile10 0x3E4
|
||||||
#define METATILE_Lilycove_Wailmer3 0x2A1
|
#define METATILE_Mauville_MirageTower_Tile11 0x3E5
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile2 0x3DA
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile3 0x3E0
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile4 0x3E1
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile5 0x3E2
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile6 0x3E8
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile7 0x3E9
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile8 0x3EA
|
||||||
|
#define METATILE_Mauville_MirageTower_Tile9 0x3F0
|
||||||
|
#define METATILE_Mauville_MirageTower_TileA 0x3F1
|
||||||
|
#define METATILE_Mauville_MirageTower_TileB 0x3F2
|
||||||
|
#define METATILE_Mauville_MirageTower_TileC 0x3DB
|
||||||
|
#define METATILE_Mauville_MirageTower_TileD 0x3DC
|
||||||
|
#define METATILE_Mauville_MirageTower_TileE 0x3DD
|
||||||
|
#define METATILE_Mauville_MirageTower_TileF 0x3E3
|
||||||
|
|
||||||
// gTileset_MauvilleGym
|
// gTileset_MauvilleGym
|
||||||
#define METATILE_MauvilleGym_FloorTile 0x21A
|
#define METATILE_MauvilleGym_FloorTile 0x21A
|
||||||
|
@ -325,38 +351,16 @@
|
||||||
#define METATILE_MauvilleGym_RedBeamV1_On 0x241
|
#define METATILE_MauvilleGym_RedBeamV1_On 0x241
|
||||||
#define METATILE_MauvilleGym_RedBeamV2_On 0x249
|
#define METATILE_MauvilleGym_RedBeamV2_On 0x249
|
||||||
|
|
||||||
// gTileset_Mauville
|
|
||||||
#define METATILE_Mauville_DeepSand_BottomMid 0x259
|
|
||||||
#define METATILE_Mauville_DeepSand_Center 0x251
|
|
||||||
#define METATILE_Mauville_Door 0x2AC
|
|
||||||
#define METATILE_Mauville_Door_BattleTent 0x3D4
|
|
||||||
#define METATILE_Mauville_Door_CyclingRoad 0x289
|
|
||||||
#define METATILE_Mauville_Door_Verdanturf 0x3A1
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile0 0x3D8
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile1 0x3D9
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile10 0x3E4
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile11 0x3E5
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile2 0x3DA
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile3 0x3E0
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile4 0x3E1
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile5 0x3E2
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile6 0x3E8
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile7 0x3E9
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile8 0x3EA
|
|
||||||
#define METATILE_Mauville_MirageTower_Tile9 0x3F0
|
|
||||||
#define METATILE_Mauville_MirageTower_TileA 0x3F1
|
|
||||||
#define METATILE_Mauville_MirageTower_TileB 0x3F2
|
|
||||||
#define METATILE_Mauville_MirageTower_TileC 0x3DB
|
|
||||||
#define METATILE_Mauville_MirageTower_TileD 0x3DC
|
|
||||||
#define METATILE_Mauville_MirageTower_TileE 0x3DD
|
|
||||||
#define METATILE_Mauville_MirageTower_TileF 0x3E3
|
|
||||||
|
|
||||||
// gTileset_MeteorFalls
|
// gTileset_MeteorFalls
|
||||||
#define METATILE_MeteorFalls_CaveEntrance_Bottom 0x24E
|
#define METATILE_MeteorFalls_CaveEntrance_Bottom 0x24E
|
||||||
#define METATILE_MeteorFalls_CaveEntrance_Left 0x24D
|
#define METATILE_MeteorFalls_CaveEntrance_Left 0x24D
|
||||||
#define METATILE_MeteorFalls_CaveEntrance_Right 0x24F
|
#define METATILE_MeteorFalls_CaveEntrance_Right 0x24F
|
||||||
#define METATILE_MeteorFalls_CaveEntrance_Top 0x246
|
#define METATILE_MeteorFalls_CaveEntrance_Top 0x246
|
||||||
|
|
||||||
|
// gTileset_Mossdeep
|
||||||
|
#define METATILE_Mossdeep_Door 0x2A1
|
||||||
|
#define METATILE_Mossdeep_Door_SpaceCenter 0x2ED
|
||||||
|
|
||||||
// gTileset_MossdeepGameCorner
|
// gTileset_MossdeepGameCorner
|
||||||
#define METATILE_MossdeepGameCorner_CounterClosed_Bottom 0x232
|
#define METATILE_MossdeepGameCorner_CounterClosed_Bottom 0x232
|
||||||
#define METATILE_MossdeepGameCorner_CounterClosed_Top 0x22A
|
#define METATILE_MossdeepGameCorner_CounterClosed_Top 0x22A
|
||||||
|
@ -366,10 +370,6 @@
|
||||||
// gTileset_MossdeepGym
|
// gTileset_MossdeepGym
|
||||||
#define METATILE_MossdeepGym_YellowArrow_Right 0x250
|
#define METATILE_MossdeepGym_YellowArrow_Right 0x250
|
||||||
|
|
||||||
// gTileset_Mossdeep
|
|
||||||
#define METATILE_Mossdeep_Door 0x2A1
|
|
||||||
#define METATILE_Mossdeep_Door_SpaceCenter 0x2ED
|
|
||||||
|
|
||||||
// gTileset_Pacifidlog
|
// gTileset_Pacifidlog
|
||||||
#define METATILE_Pacifidlog_Door 0x21A
|
#define METATILE_Pacifidlog_Door 0x21A
|
||||||
#define METATILE_Pacifidlog_FloatingLogs_HorizontalLeft 0x250
|
#define METATILE_Pacifidlog_FloatingLogs_HorizontalLeft 0x250
|
||||||
|
@ -388,6 +388,11 @@
|
||||||
#define METATILE_Pacifidlog_SubmergedLogs_VerticalBottom 0x262
|
#define METATILE_Pacifidlog_SubmergedLogs_VerticalBottom 0x262
|
||||||
#define METATILE_Pacifidlog_SubmergedLogs_VerticalTop 0x25A
|
#define METATILE_Pacifidlog_SubmergedLogs_VerticalTop 0x25A
|
||||||
|
|
||||||
|
// gTileset_Petalburg
|
||||||
|
#define METATILE_Petalburg_Door_BirchsLab 0x249
|
||||||
|
#define METATILE_Petalburg_Door_Littleroot 0x248
|
||||||
|
#define METATILE_Petalburg_Door_Oldale 0x287
|
||||||
|
|
||||||
// gTileset_PetalburgGym
|
// gTileset_PetalburgGym
|
||||||
#define METATILE_PetalburgGym_Door 0x224
|
#define METATILE_PetalburgGym_Door 0x224
|
||||||
#define METATILE_PetalburgGym_RoomEntrance_Left 0x210
|
#define METATILE_PetalburgGym_RoomEntrance_Left 0x210
|
||||||
|
@ -398,11 +403,6 @@
|
||||||
#define METATILE_PetalburgGym_SlidingDoor_Frame3 0x21B
|
#define METATILE_PetalburgGym_SlidingDoor_Frame3 0x21B
|
||||||
#define METATILE_PetalburgGym_SlidingDoor_Frame4 0x21C
|
#define METATILE_PetalburgGym_SlidingDoor_Frame4 0x21C
|
||||||
|
|
||||||
// gTileset_Petalburg
|
|
||||||
#define METATILE_Petalburg_Door_BirchsLab 0x249
|
|
||||||
#define METATILE_Petalburg_Door_Littleroot 0x248
|
|
||||||
#define METATILE_Petalburg_Door_Oldale 0x287
|
|
||||||
|
|
||||||
// gTileset_PokemonCenter
|
// gTileset_PokemonCenter
|
||||||
#define METATILE_PokemonCenter_CounterBarrier 0x25D
|
#define METATILE_PokemonCenter_CounterBarrier 0x25D
|
||||||
#define METATILE_PokemonCenter_Door_CableClub 0x264
|
#define METATILE_PokemonCenter_Door_CableClub 0x264
|
||||||
|
@ -431,14 +431,6 @@
|
||||||
#define METATILE_PokemonCenter_Floor_ShadowTop 0x21E
|
#define METATILE_PokemonCenter_Floor_ShadowTop 0x21E
|
||||||
#define METATILE_PokemonCenter_Floor_ShadowTop_Alt 0x2DC
|
#define METATILE_PokemonCenter_Floor_ShadowTop_Alt 0x2DC
|
||||||
|
|
||||||
// gTileset_RSMossdeepGym
|
|
||||||
#define METATILE_RSMossdeepGym_RedArrow_Down 0x205
|
|
||||||
#define METATILE_RSMossdeepGym_RedArrow_Left 0x20C
|
|
||||||
#define METATILE_RSMossdeepGym_RedArrow_Right 0x204
|
|
||||||
#define METATILE_RSMossdeepGym_RedArrow_Up 0x20D
|
|
||||||
#define METATILE_RSMossdeepGym_Switch_Down 0x239
|
|
||||||
#define METATILE_RSMossdeepGym_Switch_Up 0x238
|
|
||||||
|
|
||||||
// gTileset_Rustboro
|
// gTileset_Rustboro
|
||||||
#define METATILE_Rustboro_Door_Gray 0x21F
|
#define METATILE_Rustboro_Door_Gray 0x21F
|
||||||
#define METATILE_Rustboro_Door_Tan 0x22F
|
#define METATILE_Rustboro_Door_Tan 0x22F
|
||||||
|
@ -726,11 +718,6 @@
|
||||||
#define METATILE_Slateport_Door 0x2DC
|
#define METATILE_Slateport_Door 0x2DC
|
||||||
#define METATILE_Slateport_Door_BattleTent 0x393
|
#define METATILE_Slateport_Door_BattleTent 0x393
|
||||||
|
|
||||||
// gTileset_SootopolisGym
|
|
||||||
#define METATILE_SootopolisGym_Ice_Broken 0x206
|
|
||||||
#define METATILE_SootopolisGym_Ice_Cracked 0x20E
|
|
||||||
#define METATILE_SootopolisGym_Stairs 0x207
|
|
||||||
|
|
||||||
// gTileset_Sootopolis
|
// gTileset_Sootopolis
|
||||||
#define METATILE_Sootopolis_Door 0x21E
|
#define METATILE_Sootopolis_Door 0x21E
|
||||||
#define METATILE_Sootopolis_Door_Closed 0x248
|
#define METATILE_Sootopolis_Door_Closed 0x248
|
||||||
|
@ -738,6 +725,11 @@
|
||||||
#define METATILE_Sootopolis_GymDoor_Closed 0x250
|
#define METATILE_Sootopolis_GymDoor_Closed 0x250
|
||||||
#define METATILE_Sootopolis_RoughWater 0x290
|
#define METATILE_Sootopolis_RoughWater 0x290
|
||||||
|
|
||||||
|
// gTileset_SootopolisGym
|
||||||
|
#define METATILE_SootopolisGym_Ice_Broken 0x206
|
||||||
|
#define METATILE_SootopolisGym_Ice_Cracked 0x20E
|
||||||
|
#define METATILE_SootopolisGym_Stairs 0x207
|
||||||
|
|
||||||
// gTileset_TrainerHill
|
// gTileset_TrainerHill
|
||||||
#define METATILE_TrainerHill_CounterDoor 0x334
|
#define METATILE_TrainerHill_CounterDoor 0x334
|
||||||
#define METATILE_TrainerHill_Door_Elevator_Lobby 0x32C
|
#define METATILE_TrainerHill_Door_Elevator_Lobby 0x32C
|
||||||
|
@ -787,4 +779,12 @@
|
||||||
#define METATILE_Underwater_FloorShadow 0x228
|
#define METATILE_Underwater_FloorShadow 0x228
|
||||||
#define METATILE_Underwater_RockWall 0x21E
|
#define METATILE_Underwater_RockWall 0x21E
|
||||||
|
|
||||||
|
// Other
|
||||||
|
#define METATILE_RSMossdeepGym_RedArrow_Down 0x205
|
||||||
|
#define METATILE_RSMossdeepGym_RedArrow_Left 0x20C
|
||||||
|
#define METATILE_RSMossdeepGym_RedArrow_Right 0x204
|
||||||
|
#define METATILE_RSMossdeepGym_RedArrow_Up 0x20D
|
||||||
|
#define METATILE_RSMossdeepGym_Switch_Down 0x239
|
||||||
|
#define METATILE_RSMossdeepGym_Switch_Up 0x238
|
||||||
|
|
||||||
#endif // GUARD_METATILE_LABELS_H
|
#endif // GUARD_METATILE_LABELS_H
|
||||||
|
|
|
@ -694,11 +694,13 @@ static void AnimTask_SpiteTargetShadow_Step1(u8 taskId)
|
||||||
task->data[3] = 16;
|
task->data[3] = 16;
|
||||||
task->data[13] = GetAnimBattlerSpriteId(ANIM_TARGET);
|
task->data[13] = GetAnimBattlerSpriteId(ANIM_TARGET);
|
||||||
task->data[4] = OBJ_PLTT_ID2(gSprites[task->data[13]].oam.paletteNum);
|
task->data[4] = OBJ_PLTT_ID2(gSprites[task->data[13]].oam.paletteNum);
|
||||||
if (position == 1) {
|
if (position == 1)
|
||||||
|
{
|
||||||
u16 mask = DISPCNT_BG1_ON;
|
u16 mask = DISPCNT_BG1_ON;
|
||||||
mask2 = mask;
|
mask2 = mask;
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
u16 mask = DISPCNT_BG2_ON;
|
u16 mask = DISPCNT_BG2_ON;
|
||||||
mask2 = mask;
|
mask2 = mask;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2050,7 +2050,8 @@ static void UpdateSpeedFromHit(u16 cmd)
|
||||||
switch (cmd)
|
switch (cmd)
|
||||||
{
|
{
|
||||||
case LINKCMD_BLENDER_SCORE_BEST:
|
case LINKCMD_BLENDER_SCORE_BEST:
|
||||||
if (sBerryBlender->speed < 1500) {
|
if (sBerryBlender->speed < 1500)
|
||||||
|
{
|
||||||
sBerryBlender->speed += (384 / sNumPlayersToSpeedDivisor[sBerryBlender->numPlayers]);
|
sBerryBlender->speed += (384 / sNumPlayersToSpeedDivisor[sBerryBlender->numPlayers]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -138,7 +138,8 @@ static void ContestEffect_StartleFrontMon(void)
|
||||||
u8 idx = 0;
|
u8 idx = 0;
|
||||||
u8 a = eContestAppealResults.contestant;
|
u8 a = eContestAppealResults.contestant;
|
||||||
|
|
||||||
if (eContestAppealResults.turnOrder[a] != 0) {
|
if (eContestAppealResults.turnOrder[a] != 0)
|
||||||
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < CONTESTANT_COUNT; i++)
|
for (i = 0; i < CONTESTANT_COUNT; i++)
|
||||||
|
|
|
@ -218,7 +218,8 @@ static void UNUSED StitchObjectsOn8x8Canvas(s32 object_size, s32 object_count, u
|
||||||
// While the remaining space will be filled with actual data
|
// While the remaining space will be filled with actual data
|
||||||
if (object_size == 6)
|
if (object_size == 6)
|
||||||
{
|
{
|
||||||
for (k = 0; k < 256; k++) {
|
for (k = 0; k < 256; k++)
|
||||||
|
{
|
||||||
*dest = 0;
|
*dest = 0;
|
||||||
dest++;
|
dest++;
|
||||||
}
|
}
|
||||||
|
@ -228,14 +229,16 @@ static void UNUSED StitchObjectsOn8x8Canvas(s32 object_size, s32 object_count, u
|
||||||
{
|
{
|
||||||
if (object_size == 6)
|
if (object_size == 6)
|
||||||
{
|
{
|
||||||
for (k = 0; k < 32; k++) {
|
for (k = 0; k < 32; k++)
|
||||||
|
{
|
||||||
*dest = 0;
|
*dest = 0;
|
||||||
dest++;
|
dest++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy tile data
|
// Copy tile data
|
||||||
for (k = 0; k < 32 * object_size; k++) {
|
for (k = 0; k < 32 * object_size; k++)
|
||||||
|
{
|
||||||
*dest = *src;
|
*dest = *src;
|
||||||
src++;
|
src++;
|
||||||
dest++;
|
dest++;
|
||||||
|
@ -243,7 +246,8 @@ static void UNUSED StitchObjectsOn8x8Canvas(s32 object_size, s32 object_count, u
|
||||||
|
|
||||||
if (object_size == 6)
|
if (object_size == 6)
|
||||||
{
|
{
|
||||||
for (k = 0; k < 32; k++) {
|
for (k = 0; k < 32; k++)
|
||||||
|
{
|
||||||
*dest = 0;
|
*dest = 0;
|
||||||
dest++;
|
dest++;
|
||||||
}
|
}
|
||||||
|
@ -252,7 +256,8 @@ static void UNUSED StitchObjectsOn8x8Canvas(s32 object_size, s32 object_count, u
|
||||||
|
|
||||||
if (object_size == 6)
|
if (object_size == 6)
|
||||||
{
|
{
|
||||||
for (k = 0; k < 256; k++) {
|
for (k = 0; k < 256; k++)
|
||||||
|
{
|
||||||
*dest = 0;
|
*dest = 0;
|
||||||
dest++;
|
dest++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1340,7 +1340,8 @@ static void DecorationItemsMenuAction_AttemptPlace(u8 taskId)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConvertIntToDecimalStringN(gStringVar1, sDecorationContext.size, STR_CONV_MODE_RIGHT_ALIGN, 2);
|
ConvertIntToDecimalStringN(gStringVar1, sDecorationContext.size, STR_CONV_MODE_RIGHT_ALIGN, 2);
|
||||||
if (sDecorationContext.isPlayerRoom == FALSE) {
|
if (sDecorationContext.isPlayerRoom == FALSE)
|
||||||
|
{
|
||||||
StringExpandPlaceholders(gStringVar4, gText_NoMoreDecorations);
|
StringExpandPlaceholders(gStringVar4, gText_NoMoreDecorations);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2254,7 +2255,8 @@ static void Task_PutAwayDecoration(u8 taskId)
|
||||||
gTasks[taskId].tState = 1;
|
gTasks[taskId].tState = 1;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if (!gPaletteFade.active) {
|
if (!gPaletteFade.active)
|
||||||
|
{
|
||||||
DrawWholeMapView();
|
DrawWholeMapView();
|
||||||
ScriptContext_SetupScript(SecretBase_EventScript_PutAwayDecoration);
|
ScriptContext_SetupScript(SecretBase_EventScript_PutAwayDecoration);
|
||||||
ClearDialogWindowAndFrame(0, TRUE);
|
ClearDialogWindowAndFrame(0, TRUE);
|
||||||
|
|
|
@ -1091,32 +1091,39 @@ static void InitResults_Member(void)
|
||||||
{
|
{
|
||||||
u8 i;
|
u8 i;
|
||||||
|
|
||||||
switch (sGame->state) {
|
switch (sGame->state)
|
||||||
|
{
|
||||||
case 0:
|
case 0:
|
||||||
if (SendBlock(0, sGame->berryResults[sGame->timer], sizeof(sGame->berryResults))) {
|
if (SendBlock(0, sGame->berryResults[sGame->timer], sizeof(sGame->berryResults)))
|
||||||
|
{
|
||||||
sGame->playersReceived = 0;
|
sGame->playersReceived = 0;
|
||||||
sGame->state++;
|
sGame->state++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
if (IsLinkTaskFinished()) {
|
if (IsLinkTaskFinished())
|
||||||
|
{
|
||||||
sGame->state++;
|
sGame->state++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
if (AllLinkBlocksReceived()) {
|
if (AllLinkBlocksReceived())
|
||||||
for (i = 0; i < sGame->numPlayers; i++) {
|
{
|
||||||
|
for (i = 0; i < sGame->numPlayers; i++)
|
||||||
|
{
|
||||||
memcpy(sGame->berryResults, gBlockRecvBuffer, sizeof(sGame->berryResults));
|
memcpy(sGame->berryResults, gBlockRecvBuffer, sizeof(sGame->berryResults));
|
||||||
sGame->playersReceived = sGame->numPlayers;
|
sGame->playersReceived = sGame->numPlayers;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (sGame->playersReceived >= sGame->numPlayers) {
|
if (sGame->playersReceived >= sGame->numPlayers)
|
||||||
|
{
|
||||||
sGame->timer++;
|
sGame->timer++;
|
||||||
sGame->state++;
|
sGame->state++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (WaitFanfare(TRUE)) {
|
if (WaitFanfare(TRUE))
|
||||||
|
{
|
||||||
sGame->maxBerriesPickedInRow = sGame->berryResults[sGame->multiplayerId][BERRY_IN_ROW];
|
sGame->maxBerriesPickedInRow = sGame->berryResults[sGame->multiplayerId][BERRY_IN_ROW];
|
||||||
SetGameFunc(FUNC_RESULTS);
|
SetGameFunc(FUNC_RESULTS);
|
||||||
FadeOutAndPlayNewMapMusic(MUS_RG_VICTORY_WILD, 4);
|
FadeOutAndPlayNewMapMusic(MUS_RG_VICTORY_WILD, 4);
|
||||||
|
|
|
@ -317,8 +317,13 @@ void HideMapNamePopUpWindow(void)
|
||||||
{
|
{
|
||||||
if (FuncIsActiveTask(Task_MapNamePopUpWindow))
|
if (FuncIsActiveTask(Task_MapNamePopUpWindow))
|
||||||
{
|
{
|
||||||
ClearStdWindowAndFrame(GetMapNamePopUpWindowId(), TRUE);
|
#ifdef UBFIX
|
||||||
RemoveMapNamePopUpWindow();
|
if (GetMapNamePopUpWindowId() != WINDOW_NONE)
|
||||||
|
#endif // UBFIX
|
||||||
|
{
|
||||||
|
ClearStdWindowAndFrame(GetMapNamePopUpWindowId(), TRUE);
|
||||||
|
RemoveMapNamePopUpWindow();
|
||||||
|
}
|
||||||
SetGpuReg_ForcedBlank(REG_OFFSET_BG0VOFS, 0);
|
SetGpuReg_ForcedBlank(REG_OFFSET_BG0VOFS, 0);
|
||||||
DestroyTask(sPopupTaskId);
|
DestroyTask(sPopupTaskId);
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,8 +102,10 @@ static s32 _putsAscii(char *s, s32 len, void *buf)
|
||||||
p0 = b->buffer;
|
p0 = b->buffer;
|
||||||
|
|
||||||
/* Copy to buffer */
|
/* Copy to buffer */
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++)
|
||||||
if(b->pbuffer == b->buffer + b->buffer_len - 1) {
|
{
|
||||||
|
if(b->pbuffer == b->buffer + b->buffer_len - 1)
|
||||||
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
*(b->pbuffer ++) = s[i];
|
*(b->pbuffer ++) = s[i];
|
||||||
|
@ -125,8 +127,10 @@ static s32 _putsEncoded(char *s, s32 len, void *buf)
|
||||||
p0 = b->buffer;
|
p0 = b->buffer;
|
||||||
|
|
||||||
/* Copy to buffer */
|
/* Copy to buffer */
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++)
|
||||||
if(b->pbuffer == b->buffer + b->buffer_len - 1) {
|
{
|
||||||
|
if(b->pbuffer == b->buffer + b->buffer_len - 1)
|
||||||
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
*(b->pbuffer ++) = mini_pchar_decode(s[i]);
|
*(b->pbuffer ++) = mini_pchar_decode(s[i]);
|
||||||
|
@ -191,7 +195,8 @@ static s32 mini_pad(char* ptr, s32 len, char pad_char, s32 pad_to, char *buffer)
|
||||||
char * pbuffer = buffer;
|
char * pbuffer = buffer;
|
||||||
if(pad_to == 0)
|
if(pad_to == 0)
|
||||||
pad_to = len;
|
pad_to = len;
|
||||||
if (len > pad_to) {
|
if (len > pad_to)
|
||||||
|
{
|
||||||
len = pad_to;
|
len = pad_to;
|
||||||
overflow = TRUE;
|
overflow = TRUE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3324,7 +3324,8 @@ static void SpriteCB_FlashMatchingLines(struct Sprite *sprite)
|
||||||
if (sprite->sNumFullFlashes)
|
if (sprite->sNumFullFlashes)
|
||||||
sprite->sNumFullFlashes--;
|
sprite->sNumFullFlashes--;
|
||||||
}
|
}
|
||||||
else if (sprite->sColor >= maxColorChange) {
|
else if (sprite->sColor >= maxColorChange)
|
||||||
|
{
|
||||||
// Reached peak darkness, reverse
|
// Reached peak darkness, reverse
|
||||||
sprite->sColorIncr = -sprite->sColorIncr;
|
sprite->sColorIncr = -sprite->sColorIncr;
|
||||||
}
|
}
|
||||||
|
@ -6984,7 +6985,7 @@ static const struct SubspriteTable sSubspriteTable_DigitalDisplay_Win[] =
|
||||||
{ARRAY_COUNT(sSubsprites_DigitalDisplay_Win), sSubsprites_DigitalDisplay_Win}
|
{ARRAY_COUNT(sSubsprites_DigitalDisplay_Win), sSubsprites_DigitalDisplay_Win}
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct Subsprite sSubsprites_DigitalDisplay_Smoke[] =
|
static const struct Subsprite sSubsprites_DigitalDisplay_SmokeBig[] =
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
.x = -16,
|
.x = -16,
|
||||||
|
@ -6996,7 +6997,7 @@ static const struct Subsprite sSubsprites_DigitalDisplay_Smoke[] =
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct Subsprite sSubsprites_DigitalDisplay_Unused2[] =
|
static const struct Subsprite sSubsprites_DigitalDisplay_SmokeSmall[] =
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
.x = -8,
|
.x = -8,
|
||||||
|
@ -7010,12 +7011,8 @@ static const struct Subsprite sSubsprites_DigitalDisplay_Unused2[] =
|
||||||
|
|
||||||
static const struct SubspriteTable sSubspriteTable_DigitalDisplay_Smoke[] =
|
static const struct SubspriteTable sSubspriteTable_DigitalDisplay_Smoke[] =
|
||||||
{
|
{
|
||||||
{ARRAY_COUNT(sSubsprites_DigitalDisplay_Smoke), sSubsprites_DigitalDisplay_Smoke}
|
{ARRAY_COUNT(sSubsprites_DigitalDisplay_SmokeBig), sSubsprites_DigitalDisplay_SmokeBig},
|
||||||
};
|
{ARRAY_COUNT(sSubsprites_DigitalDisplay_SmokeSmall), sSubsprites_DigitalDisplay_SmokeSmall}
|
||||||
|
|
||||||
static const struct SubspriteTable sSubspriteTable_DigitalDisplay_Unused2[] =
|
|
||||||
{
|
|
||||||
{ARRAY_COUNT(sSubsprites_DigitalDisplay_Unused2), sSubsprites_DigitalDisplay_Unused2}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -62,7 +62,7 @@ static unsigned char *ConvertBitDepth(unsigned char *src, int srcBitDepth, int d
|
||||||
|
|
||||||
for (j = 8 - srcBitDepth; j >= 0; j -= srcBitDepth)
|
for (j = 8 - srcBitDepth; j >= 0; j -= srcBitDepth)
|
||||||
{
|
{
|
||||||
unsigned char pixel = (srcByte >> j) % (1 << destBitDepth);
|
unsigned char pixel = ((srcByte >> j) % (1 << srcBitDepth)) % (1 << destBitDepth);
|
||||||
*dest |= pixel << destBit;
|
*dest |= pixel << destBit;
|
||||||
destBit -= destBitDepth;
|
destBit -= destBitDepth;
|
||||||
if (destBit < 0)
|
if (destBit < 0)
|
||||||
|
|
|
@ -105,10 +105,13 @@ int main(int argc, char *argv[])
|
||||||
});
|
});
|
||||||
|
|
||||||
env.add_callback("cleanString", 1, [](Arguments& args) {
|
env.add_callback("cleanString", 1, [](Arguments& args) {
|
||||||
string badChars = ".'{} \n\t-\u00e9";
|
|
||||||
string str = args.at(0)->get<string>();
|
string str = args.at(0)->get<string>();
|
||||||
for (unsigned int i = 0; i < str.length(); i++) {
|
for (unsigned int i = 0; i < str.length(); i++) {
|
||||||
if (badChars.find(str[i]) != std::string::npos) {
|
// This code is not Unicode aware, so UTF-8 is not easily parsable without introducing
|
||||||
|
// another library. Just filter out any non-alphanumeric characters for now.
|
||||||
|
// TODO: proper Unicode string normalization
|
||||||
|
if ((i == 0 && isdigit(str[i]))
|
||||||
|
|| !isalnum(str[i])) {
|
||||||
str[i] = '_';
|
str[i] = '_';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue