mirror of
https://github.com/pret/pokefirered.git
synced 2026-05-16 01:05:44 -05:00
Combining pss 8 and 9
This commit is contained in:
parent
2d2d17dde3
commit
9d9c2a9667
|
|
@ -198,12 +198,12 @@ struct StorageMenu
|
|||
|
||||
struct UnkUtilData
|
||||
{
|
||||
const u8 *unk_00;
|
||||
u8 *unk_04;
|
||||
u16 unk_08;
|
||||
u16 unk_0a;
|
||||
u16 newField;
|
||||
void (*unk_0c)(struct UnkUtilData *data);
|
||||
const u8 *src;
|
||||
u8 *dest;
|
||||
u16 size;
|
||||
u16 unk;
|
||||
u16 height;
|
||||
void (*func)(struct UnkUtilData *data);
|
||||
};
|
||||
|
||||
struct UnkUtil
|
||||
|
|
|
|||
|
|
@ -137,7 +137,6 @@ SECTIONS {
|
|||
src/pokemon_storage_system_6.o(.text);
|
||||
src/pokemon_storage_system_7.o(.text);
|
||||
src/pokemon_storage_system_8.o(.text);
|
||||
src/pokemon_storage_system_9.o(.text);
|
||||
src/pokemon_icon.o(.text);
|
||||
src/script_movement.o(.text);
|
||||
src/fldeff_cut.o(.text);
|
||||
|
|
|
|||
|
|
@ -778,3 +778,87 @@ static void SpriteCB_ItemIcon_HideParty(struct Sprite *sprite)
|
|||
#undef sItemIconId
|
||||
#undef sCursorArea
|
||||
#undef sCursorPos
|
||||
|
||||
static EWRAM_DATA struct UnkUtil *gUnknown_203982C = NULL;
|
||||
|
||||
static void sub_8096CDC(struct UnkUtilData *unkStruct);
|
||||
static void sub_8096D70(struct UnkUtilData *unkStruct);
|
||||
|
||||
void sub_8096BE4(struct UnkUtil *arg0, struct UnkUtilData *arg1, u32 arg2)
|
||||
{
|
||||
gUnknown_203982C = arg0;
|
||||
arg0->unk_00 = arg1;
|
||||
arg0->unk_05 = arg2;
|
||||
arg0->unk_04 = 0;
|
||||
}
|
||||
|
||||
void sub_8096BF8(void)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
if (gUnknown_203982C->unk_04)
|
||||
{
|
||||
for (i = 0; i < gUnknown_203982C->unk_04; i++)
|
||||
{
|
||||
struct UnkUtilData *unkStruct = &gUnknown_203982C->unk_00[i];
|
||||
unkStruct->func(unkStruct);
|
||||
}
|
||||
|
||||
gUnknown_203982C->unk_04 = 0;
|
||||
}
|
||||
}
|
||||
|
||||
static bool8 sub_8096C40(u8 *dest, u16 dLeft, u16 dTop, const u8 *src, u16 sLeft, u16 sTop, u16 width, u16 height, u16 unkArg)
|
||||
{
|
||||
struct UnkUtilData *unkStruct;
|
||||
|
||||
if (gUnknown_203982C->unk_04 >= gUnknown_203982C->unk_05)
|
||||
return FALSE;
|
||||
|
||||
unkStruct = &gUnknown_203982C->unk_00[gUnknown_203982C->unk_04++];
|
||||
unkStruct->size = width * 2;
|
||||
unkStruct->dest = dest + 2 * (dTop * 32 + dLeft);
|
||||
unkStruct->src = src + 2 * (sTop * unkArg + sLeft);
|
||||
unkStruct->height = height;
|
||||
unkStruct->unk = unkArg;
|
||||
unkStruct->func = sub_8096CDC;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void sub_8096CDC(struct UnkUtilData *unkStruct)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
for (i = 0; i < unkStruct->height; i++)
|
||||
{
|
||||
CpuCopy16(unkStruct->src, unkStruct->dest, unkStruct->size);
|
||||
unkStruct->dest += 64;
|
||||
unkStruct->src += (unkStruct->unk * 2);
|
||||
}
|
||||
}
|
||||
|
||||
static bool8 sub_8096D14(void *dest, u16 dLeft, u16 dTop, u16 width, u16 height)
|
||||
{
|
||||
struct UnkUtilData *unkStruct;
|
||||
|
||||
if (gUnknown_203982C->unk_04 >= gUnknown_203982C->unk_05)
|
||||
return FALSE;
|
||||
|
||||
unkStruct = &gUnknown_203982C->unk_00[gUnknown_203982C->unk_04++];
|
||||
unkStruct->size = width * 2;
|
||||
unkStruct->dest = dest + ((dTop * 32) + dLeft) * 2;
|
||||
unkStruct->height = height;
|
||||
unkStruct->func = sub_8096D70;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void sub_8096D70(struct UnkUtilData *data)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
for (i = 0; i < data->height; i++)
|
||||
{
|
||||
Dma3FillLarge_(0, data->dest, data->size, 16);
|
||||
data->dest += 64;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,87 +0,0 @@
|
|||
#include "global.h"
|
||||
#include "gflib.h"
|
||||
#include "pokemon_storage_system_internal.h"
|
||||
|
||||
static EWRAM_DATA struct UnkUtil *gUnknown_203982C = NULL;
|
||||
|
||||
static void sub_8096CDC(struct UnkUtilData *unkStruct);
|
||||
static void sub_8096D70(struct UnkUtilData *unkStruct);
|
||||
|
||||
void sub_8096BE4(struct UnkUtil *arg0, struct UnkUtilData *arg1, u32 arg2)
|
||||
{
|
||||
gUnknown_203982C = arg0;
|
||||
arg0->unk_00 = arg1;
|
||||
arg0->unk_05 = arg2;
|
||||
arg0->unk_04 = 0;
|
||||
}
|
||||
|
||||
void sub_8096BF8(void)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
if (gUnknown_203982C->unk_04)
|
||||
{
|
||||
for (i = 0; i < gUnknown_203982C->unk_04; i++)
|
||||
{
|
||||
struct UnkUtilData *unkStruct = &gUnknown_203982C->unk_00[i];
|
||||
unkStruct->unk_0c(unkStruct);
|
||||
}
|
||||
|
||||
gUnknown_203982C->unk_04 = 0;
|
||||
}
|
||||
}
|
||||
|
||||
static bool8 sub_8096C40(u8 *dest, u16 dLeft, u16 dTop, const u8 *src, u16 sLeft, u16 sTop, u16 width, u16 height, u16 unkArg)
|
||||
{
|
||||
struct UnkUtilData *unkStruct;
|
||||
|
||||
if (gUnknown_203982C->unk_04 >= gUnknown_203982C->unk_05)
|
||||
return FALSE;
|
||||
|
||||
unkStruct = &gUnknown_203982C->unk_00[gUnknown_203982C->unk_04++];
|
||||
unkStruct->unk_08 = width * 2;
|
||||
unkStruct->unk_04 = dest + 2 * (dTop * 32 + dLeft);
|
||||
unkStruct->unk_00 = src + 2 * (sTop * unkArg + sLeft);
|
||||
unkStruct->newField = height;
|
||||
unkStruct->unk_0a = unkArg;
|
||||
unkStruct->unk_0c = sub_8096CDC;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void sub_8096CDC(struct UnkUtilData *unkStruct)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
for (i = 0; i < unkStruct->newField; i++)
|
||||
{
|
||||
CpuCopy16(unkStruct->unk_00, unkStruct->unk_04, unkStruct->unk_08);
|
||||
unkStruct->unk_04 += 64;
|
||||
unkStruct->unk_00 += (unkStruct->unk_0a * 2);
|
||||
}
|
||||
}
|
||||
|
||||
static bool8 sub_8096D14(void *dest, u16 dLeft, u16 dTop, u16 width, u16 height)
|
||||
{
|
||||
struct UnkUtilData *unkStruct;
|
||||
|
||||
if (gUnknown_203982C->unk_04 >= gUnknown_203982C->unk_05)
|
||||
return FALSE;
|
||||
|
||||
unkStruct = &gUnknown_203982C->unk_00[gUnknown_203982C->unk_04++];
|
||||
unkStruct->unk_08 = width * 2;
|
||||
unkStruct->unk_04 = dest + ((dTop * 32) + dLeft) * 2;
|
||||
unkStruct->newField = height;
|
||||
unkStruct->unk_0c = sub_8096D70;
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void sub_8096D70(struct UnkUtilData *unkStruct)
|
||||
{
|
||||
u16 i;
|
||||
|
||||
for (i = 0; i < unkStruct->newField; i++)
|
||||
{
|
||||
Dma3FillLarge_(0, unkStruct->unk_04, unkStruct->unk_08, 16);
|
||||
unkStruct->unk_04 += 64;
|
||||
}
|
||||
}
|
||||
|
|
@ -42,7 +42,7 @@
|
|||
.include "src/pokemon_storage_system_3.o"
|
||||
.include "src/pokemon_storage_system_5.o"
|
||||
.include "src/pokemon_storage_system_7.o"
|
||||
.include "src/pokemon_storage_system_9.o"
|
||||
.include "src/pokemon_storage_system_8.o"
|
||||
.include "src/script_movement.o"
|
||||
.include "src/fldeff_cut.o"
|
||||
.include "src/item_menu_icons.o"
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user