mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-11-16 11:37:40 +01:00
start coins decomp
This commit is contained in:
parent
307278374b
commit
3355389eab
144
asm/coins.s
144
asm/coins.s
@ -5,148 +5,8 @@
|
|||||||
|
|
||||||
.text
|
.text
|
||||||
|
|
||||||
thumb_func_start PrintCoinsString
|
|
||||||
@ void PrintCoinsString(s32 coinAmount)
|
|
||||||
PrintCoinsString: @ 8145B54
|
|
||||||
push {r4,lr}
|
|
||||||
sub sp, 0xC
|
|
||||||
adds r1, r0, 0
|
|
||||||
ldr r0, =gStringVar1
|
|
||||||
movs r2, 0x1
|
|
||||||
movs r3, 0x4
|
|
||||||
bl ConvertIntToDecimalStringN
|
|
||||||
ldr r4, =gStringVar4
|
|
||||||
ldr r1, =gUnknown_085E8DAB
|
|
||||||
adds r0, r4, 0
|
|
||||||
bl StringExpandPlaceholders
|
|
||||||
movs r0, 0x1
|
|
||||||
adds r1, r4, 0
|
|
||||||
movs r2, 0x40
|
|
||||||
bl GetStringRightAlignXOffset
|
|
||||||
adds r3, r0, 0
|
|
||||||
ldr r0, =gUnknown_0203AB9C
|
|
||||||
ldrb r0, [r0]
|
|
||||||
lsls r3, 24
|
|
||||||
lsrs r3, 24
|
|
||||||
movs r1, 0x1
|
|
||||||
str r1, [sp]
|
|
||||||
movs r1, 0
|
|
||||||
str r1, [sp, 0x4]
|
|
||||||
str r1, [sp, 0x8]
|
|
||||||
movs r1, 0x1
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl PrintTextOnWindow
|
|
||||||
add sp, 0xC
|
|
||||||
pop {r4}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end PrintCoinsString
|
|
||||||
|
|
||||||
thumb_func_start ShowCoinsWindow
|
|
||||||
@ void ShowCoinsWindow(s32 coinAmount, u8 x, u8 y)
|
|
||||||
ShowCoinsWindow: @ 8145BAC
|
|
||||||
push {r4,r5,lr}
|
|
||||||
sub sp, 0x18
|
|
||||||
adds r5, r0, 0
|
|
||||||
adds r4, r1, 0
|
|
||||||
adds r3, r2, 0
|
|
||||||
lsls r4, 24
|
|
||||||
lsrs r4, 24
|
|
||||||
lsls r3, 24
|
|
||||||
lsrs r3, 24
|
|
||||||
movs r0, 0x8
|
|
||||||
str r0, [sp]
|
|
||||||
movs r0, 0x2
|
|
||||||
str r0, [sp, 0x4]
|
|
||||||
movs r0, 0xF
|
|
||||||
str r0, [sp, 0x8]
|
|
||||||
ldr r0, =0x00000141
|
|
||||||
str r0, [sp, 0xC]
|
|
||||||
add r0, sp, 0x10
|
|
||||||
movs r1, 0
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl rbox_template_set
|
|
||||||
ldr r4, =gUnknown_0203AB9C
|
|
||||||
add r0, sp, 0x10
|
|
||||||
bl AddWindow
|
|
||||||
strb r0, [r4]
|
|
||||||
ldrb r0, [r4]
|
|
||||||
movs r1, 0
|
|
||||||
bl FillWindowPixelBuffer
|
|
||||||
ldrb r0, [r4]
|
|
||||||
bl PutWindowTilemap
|
|
||||||
ldrb r0, [r4]
|
|
||||||
movs r2, 0x85
|
|
||||||
lsls r2, 2
|
|
||||||
movs r1, 0
|
|
||||||
movs r3, 0xE
|
|
||||||
bl SetWindowBorderStyle
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl PrintCoinsString
|
|
||||||
add sp, 0x18
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end ShowCoinsWindow
|
|
||||||
|
|
||||||
thumb_func_start HideCoinsWindow
|
|
||||||
@ void HideCoinsWindow()
|
|
||||||
HideCoinsWindow: @ 8145C14
|
|
||||||
push {r4,lr}
|
|
||||||
ldr r4, =gUnknown_0203AB9C
|
|
||||||
ldrb r0, [r4]
|
|
||||||
movs r1, 0x1
|
|
||||||
bl sub_819746C
|
|
||||||
ldrb r0, [r4]
|
|
||||||
bl RemoveWindow
|
|
||||||
pop {r4}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end HideCoinsWindow
|
|
||||||
|
|
||||||
thumb_func_start GetCoins
|
|
||||||
@ u16 GetCoins()
|
|
||||||
GetCoins: @ 8145C30
|
|
||||||
ldr r0, =gSaveBlock1Ptr
|
|
||||||
ldr r1, [r0]
|
|
||||||
ldr r0, =0x00000494
|
|
||||||
adds r1, r0
|
|
||||||
ldr r0, =gSaveBlock2Ptr
|
|
||||||
ldr r0, [r0]
|
|
||||||
adds r0, 0xAC
|
|
||||||
ldr r0, [r0]
|
|
||||||
ldrh r1, [r1]
|
|
||||||
eors r0, r1
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r0, 16
|
|
||||||
bx lr
|
|
||||||
.pool
|
|
||||||
thumb_func_end GetCoins
|
|
||||||
|
|
||||||
thumb_func_start SetCoins
|
|
||||||
@ void SetCoins(u16 amount)
|
|
||||||
SetCoins: @ 8145C58
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r0, 16
|
|
||||||
ldr r1, =gSaveBlock1Ptr
|
|
||||||
ldr r2, [r1]
|
|
||||||
ldr r1, =gSaveBlock2Ptr
|
|
||||||
ldr r1, [r1]
|
|
||||||
adds r1, 0xAC
|
|
||||||
ldr r1, [r1]
|
|
||||||
eors r0, r1
|
|
||||||
ldr r1, =0x00000494
|
|
||||||
adds r2, r1
|
|
||||||
strh r0, [r2]
|
|
||||||
bx lr
|
|
||||||
.pool
|
|
||||||
thumb_func_end SetCoins
|
|
||||||
|
|
||||||
thumb_func_start AddCoins
|
thumb_func_start AddCoins
|
||||||
@ bool8 AddCoins(u16 amount)
|
@ bool8 AddCoins(u16 toAdd)
|
||||||
AddCoins: @ 8145C80
|
AddCoins: @ 8145C80
|
||||||
push {r4,lr}
|
push {r4,lr}
|
||||||
lsls r0, 16
|
lsls r0, 16
|
||||||
@ -187,7 +47,7 @@ _08145CC0:
|
|||||||
thumb_func_end AddCoins
|
thumb_func_end AddCoins
|
||||||
|
|
||||||
thumb_func_start SubtractCoins
|
thumb_func_start SubtractCoins
|
||||||
@ bool8 SubtractCoins(u16 amount)
|
@ bool8 SubtractCoins(u16 toSub)
|
||||||
SubtractCoins: @ 8145CCC
|
SubtractCoins: @ 8145CCC
|
||||||
push {r4,lr}
|
push {r4,lr}
|
||||||
lsls r0, 16
|
lsls r0, 16
|
||||||
|
@ -52968,7 +52968,7 @@ sub_80248B0: @ 80248B0
|
|||||||
movs r1, 0
|
movs r1, 0
|
||||||
movs r2, 0x1
|
movs r2, 0x1
|
||||||
movs r3, 0x1
|
movs r3, 0x1
|
||||||
bl rbox_template_set
|
bl SetWindowTemplateFields
|
||||||
ldr r4, =gUnknown_02022C94
|
ldr r4, =gUnknown_02022C94
|
||||||
add r0, sp, 0x10
|
add r0, sp, 0x10
|
||||||
bl AddWindow
|
bl AddWindow
|
||||||
|
@ -202,7 +202,7 @@ sub_80E52EC: @ 80E52EC
|
|||||||
add r0, sp, 0x10
|
add r0, sp, 0x10
|
||||||
movs r1, 0
|
movs r1, 0
|
||||||
adds r2, r4, 0
|
adds r2, r4, 0
|
||||||
bl rbox_template_set
|
bl SetWindowTemplateFields
|
||||||
ldr r4, =gUnknown_02039F98
|
ldr r4, =gUnknown_02039F98
|
||||||
add r0, sp, 0x10
|
add r0, sp, 0x10
|
||||||
bl AddWindow
|
bl AddWindow
|
||||||
|
@ -19160,9 +19160,9 @@ sub_81989B8: @ 81989B8
|
|||||||
bx r0
|
bx r0
|
||||||
thumb_func_end sub_81989B8
|
thumb_func_end sub_81989B8
|
||||||
|
|
||||||
thumb_func_start rbox_template_set
|
thumb_func_start SetWindowTemplateFields
|
||||||
@ void rbox_template_set(WindowTemplate *template, char bg_id, char x, char y, char w, char h, char a7, s16 a8)
|
@ void SetWindowTemplateFields(WindowTemplate *template, char bg_id, char x, char y, char w, char h, char a7, s16 a8)
|
||||||
rbox_template_set: @ 8198A24
|
SetWindowTemplateFields: @ 8198A24
|
||||||
push {r4-r7,lr}
|
push {r4-r7,lr}
|
||||||
mov r7, r8
|
mov r7, r8
|
||||||
push {r7}
|
push {r7}
|
||||||
@ -19184,7 +19184,7 @@ rbox_template_set: @ 8198A24
|
|||||||
pop {r4-r7}
|
pop {r4-r7}
|
||||||
pop {r0}
|
pop {r0}
|
||||||
bx r0
|
bx r0
|
||||||
thumb_func_end rbox_template_set
|
thumb_func_end SetWindowTemplateFields
|
||||||
|
|
||||||
thumb_func_start sub_8198A50
|
thumb_func_start sub_8198A50
|
||||||
sub_8198A50: @ 8198A50
|
sub_8198A50: @ 8198A50
|
||||||
@ -19216,7 +19216,7 @@ sub_8198A50: @ 8198A50
|
|||||||
str r5, [sp, 0x8]
|
str r5, [sp, 0x8]
|
||||||
str r6, [sp, 0xC]
|
str r6, [sp, 0xC]
|
||||||
add r0, sp, 0x10
|
add r0, sp, 0x10
|
||||||
bl rbox_template_set
|
bl SetWindowTemplateFields
|
||||||
ldr r0, [sp, 0x10]
|
ldr r0, [sp, 0x10]
|
||||||
ldr r1, [sp, 0x14]
|
ldr r1, [sp, 0x14]
|
||||||
mov r2, r8
|
mov r2, r8
|
||||||
@ -19263,7 +19263,7 @@ sub_8198AA4: @ 8198AA4
|
|||||||
adds r1, r4, 0
|
adds r1, r4, 0
|
||||||
adds r2, r5, 0
|
adds r2, r5, 0
|
||||||
adds r3, r6, 0
|
adds r3, r6, 0
|
||||||
bl rbox_template_set
|
bl SetWindowTemplateFields
|
||||||
add r0, sp, 0x10
|
add r0, sp, 0x10
|
||||||
bl AddWindow
|
bl AddWindow
|
||||||
lsls r0, 16
|
lsls r0, 16
|
||||||
@ -70120,7 +70120,7 @@ _081B31D2:
|
|||||||
add r0, sp, 0x14
|
add r0, sp, 0x14
|
||||||
movs r1, 0x2
|
movs r1, 0x2
|
||||||
movs r2, 0x13
|
movs r2, 0x13
|
||||||
bl rbox_template_set
|
bl SetWindowTemplateFields
|
||||||
b _081B3226
|
b _081B3226
|
||||||
.pool
|
.pool
|
||||||
_081B320C:
|
_081B320C:
|
||||||
|
@ -420,7 +420,7 @@ gUnknown_085E8DA0:: @ 85E8DA0
|
|||||||
.string "×{STR_VAR_1}$"
|
.string "×{STR_VAR_1}$"
|
||||||
.string " BERRY$"
|
.string " BERRY$"
|
||||||
|
|
||||||
gUnknown_085E8DAB:: @ 85E8DAB
|
gOtherText_Coins2:: @ 85E8DAB
|
||||||
|
|
||||||
.string "{STR_VAR_1} COINS$"
|
.string "{STR_VAR_1} COINS$"
|
||||||
|
|
||||||
|
@ -1,6 +1,12 @@
|
|||||||
#ifndef GUARD_COINS_H
|
#ifndef GUARD_COINS_H
|
||||||
#define GUARD_COINS_H
|
#define GUARD_COINS_H
|
||||||
|
|
||||||
void SetCoins(u16 newValue);
|
void PrintCoinsString(u32 coinAmount);
|
||||||
|
void ShowCoinsWindow(u32 coinAmount, u8 x, u8 y);
|
||||||
|
void HideCoinsWindow(void);
|
||||||
|
u16 GetCoins(void);
|
||||||
|
void SetCoins(u16 coinAmount);
|
||||||
|
bool8 AddCoins(u16 toAdd);
|
||||||
|
bool8 SubtractCoins(u16 toSub);
|
||||||
|
|
||||||
#endif // GUARD_COINS_H
|
#endif // GUARD_COINS_H
|
||||||
|
@ -180,6 +180,7 @@ SECTIONS {
|
|||||||
asm/evolution_scene.o(.text);
|
asm/evolution_scene.o(.text);
|
||||||
asm/roulette.o(.text);
|
asm/roulette.o(.text);
|
||||||
asm/pokedex_cry_screen.o(.text);
|
asm/pokedex_cry_screen.o(.text);
|
||||||
|
src/coins.o(.text);
|
||||||
asm/coins.o(.text);
|
asm/coins.o(.text);
|
||||||
asm/landmark.o(.text);
|
asm/landmark.o(.text);
|
||||||
asm/fldeff_strength.o(.text);
|
asm/fldeff_strength.o(.text);
|
||||||
|
77
src/coins.c
Normal file
77
src/coins.c
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
#include "global.h"
|
||||||
|
#include "coins.h"
|
||||||
|
#include "text.h"
|
||||||
|
#include "window.h"
|
||||||
|
#include "text_window.h"
|
||||||
|
#include "string_util.h"
|
||||||
|
|
||||||
|
#define MAX_COINS 9999
|
||||||
|
|
||||||
|
EWRAM_DATA u8 sCoinsWindowId = 0;
|
||||||
|
|
||||||
|
extern s32 GetStringRightAlignXOffset(u8 fontId, u8 *str, s32 totalWidth);
|
||||||
|
extern void SetWindowTemplateFields(struct WindowTemplate* template, u8 priority, u8 tilemapLeft, u8 tilemapTop, u8 width, u8 height, u8 palNum, u16 baseBlock);
|
||||||
|
extern void SetWindowBorderStyle(u8 windowId, bool8 copyToVram, s16 tileStart, s8 palette);
|
||||||
|
extern void sub_819746C(u8 windowId, bool8 copyToVram);
|
||||||
|
|
||||||
|
extern const u8 gOtherText_Coins2[];
|
||||||
|
|
||||||
|
void PrintCoinsString(u32 coinAmount)
|
||||||
|
{
|
||||||
|
u32 xAlign;
|
||||||
|
|
||||||
|
ConvertIntToDecimalStringN(gStringVar1, coinAmount, STR_CONV_MODE_RIGHT_ALIGN, 4);
|
||||||
|
StringExpandPlaceholders(gStringVar4, gOtherText_Coins2);
|
||||||
|
|
||||||
|
xAlign = GetStringRightAlignXOffset(1, gStringVar4, 0x40);
|
||||||
|
PrintTextOnWindow(sCoinsWindowId, 1, gStringVar4, xAlign, 1, 0, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ShowCoinsWindow(u32 coinAmount, u8 x, u8 y)
|
||||||
|
{
|
||||||
|
struct WindowTemplate template;
|
||||||
|
SetWindowTemplateFields(&template, 0, x, y, 8, 2, 0xF, 0x141);
|
||||||
|
sCoinsWindowId = AddWindow(&template);
|
||||||
|
FillWindowPixelBuffer(sCoinsWindowId, 0);
|
||||||
|
PutWindowTilemap(sCoinsWindowId);
|
||||||
|
SetWindowBorderStyle(sCoinsWindowId, FALSE, 0x214, 0xE);
|
||||||
|
PrintCoinsString(coinAmount);
|
||||||
|
}
|
||||||
|
|
||||||
|
void HideCoinsWindow(void)
|
||||||
|
{
|
||||||
|
sub_819746C(sCoinsWindowId, TRUE);
|
||||||
|
RemoveWindow(sCoinsWindowId);
|
||||||
|
}
|
||||||
|
|
||||||
|
u16 GetCoins(void)
|
||||||
|
{
|
||||||
|
return gSaveBlock1Ptr->coins ^ gSaveBlock2Ptr->encryptionKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetCoins(u16 coinAmount)
|
||||||
|
{
|
||||||
|
gSaveBlock1Ptr->coins = coinAmount ^ gSaveBlock2Ptr->encryptionKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Can't match it lol
|
||||||
|
bool8 AddCoins(u16 toAdd)
|
||||||
|
{
|
||||||
|
u16 newAmount;
|
||||||
|
u16 ownedCoins = GetCoins();
|
||||||
|
if (ownedCoins >= MAX_COINS)
|
||||||
|
return FALSE;
|
||||||
|
// check overflow, can't have less coins than previously
|
||||||
|
if (ownedCoins > ownedCoins + toAdd)
|
||||||
|
{
|
||||||
|
newAmount = MAX_COINS;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
newAmount = ownedCoins + toAdd;
|
||||||
|
if (newAmount > MAX_COINS)
|
||||||
|
newAmount = MAX_COINS;
|
||||||
|
}
|
||||||
|
SetCoins(newAmount);
|
||||||
|
return TRUE;
|
||||||
|
}*/
|
@ -1514,9 +1514,9 @@ gUnknown_0203AB94: @ 203AB94
|
|||||||
gUnknown_0203AB98: @ 203AB98
|
gUnknown_0203AB98: @ 203AB98
|
||||||
.space 0x4
|
.space 0x4
|
||||||
|
|
||||||
gUnknown_0203AB9C: @ 203AB9C
|
.include "src/coins.o"
|
||||||
.space 0x4
|
|
||||||
|
.align 2
|
||||||
sTransitionStructPtr: @ 203ABA0
|
sTransitionStructPtr: @ 203ABA0
|
||||||
.space 0x4
|
.space 0x4
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user