mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2024-12-27 04:04:17 +01:00
merge with master
This commit is contained in:
commit
039c9f4bd8
74
asm/coins.s
74
asm/coins.s
@ -1,74 +0,0 @@
|
|||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
thumb_func_start GiveCoins
|
|
||||||
@ bool8 GiveCoins(u16 toAdd)
|
|
||||||
GiveCoins: @ 8145C80
|
|
||||||
push {r4,lr}
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r4, r0, 16
|
|
||||||
bl GetCoins
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r1, r0, 16
|
|
||||||
ldr r0, =0x0000270e
|
|
||||||
cmp r1, r0
|
|
||||||
bls _08145C9C
|
|
||||||
movs r0, 0
|
|
||||||
b _08145CC0
|
|
||||||
.pool
|
|
||||||
_08145C9C:
|
|
||||||
adds r0, r1, r4
|
|
||||||
cmp r1, r0
|
|
||||||
ble _08145CAC
|
|
||||||
ldr r0, =0x0000270f
|
|
||||||
b _08145CBA
|
|
||||||
.pool
|
|
||||||
_08145CAC:
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r1, r0, 16
|
|
||||||
ldr r0, =0x0000270f
|
|
||||||
cmp r1, r0
|
|
||||||
bls _08145CB8
|
|
||||||
adds r1, r0, 0
|
|
||||||
_08145CB8:
|
|
||||||
adds r0, r1, 0
|
|
||||||
_08145CBA:
|
|
||||||
bl SetCoins
|
|
||||||
movs r0, 0x1
|
|
||||||
_08145CC0:
|
|
||||||
pop {r4}
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
.pool
|
|
||||||
thumb_func_end GiveCoins
|
|
||||||
|
|
||||||
thumb_func_start TakeCoins
|
|
||||||
@ bool8 TakeCoins(u16 toSub)
|
|
||||||
TakeCoins: @ 8145CCC
|
|
||||||
push {r4,lr}
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r4, r0, 16
|
|
||||||
bl GetCoins
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r0, 16
|
|
||||||
cmp r0, r4
|
|
||||||
bcs _08145CE2
|
|
||||||
movs r0, 0
|
|
||||||
b _08145CEE
|
|
||||||
_08145CE2:
|
|
||||||
subs r0, r4
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r0, 16
|
|
||||||
bl SetCoins
|
|
||||||
movs r0, 0x1
|
|
||||||
_08145CEE:
|
|
||||||
pop {r4}
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end TakeCoins
|
|
||||||
|
|
||||||
.align 2, 0 @ Don't pad with nop.
|
|
@ -1,323 +0,0 @@
|
|||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
thumb_func_start sub_80F9568
|
|
||||||
sub_80F9568: @ 80F9568
|
|
||||||
push {lr}
|
|
||||||
movs r1, 0x41
|
|
||||||
bl GetMonData
|
|
||||||
lsls r0, 16
|
|
||||||
lsrs r1, r0, 16
|
|
||||||
cmp r1, 0
|
|
||||||
beq _080F9580
|
|
||||||
movs r0, 0xCE
|
|
||||||
lsls r0, 1
|
|
||||||
cmp r1, r0
|
|
||||||
bne _080F9584
|
|
||||||
_080F9580:
|
|
||||||
movs r0, 0
|
|
||||||
b _080F9586
|
|
||||||
_080F9584:
|
|
||||||
movs r0, 0x1
|
|
||||||
_080F9586:
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end sub_80F9568
|
|
||||||
|
|
||||||
thumb_func_start sub_80F958C
|
|
||||||
sub_80F958C: @ 80F958C
|
|
||||||
push {r4,r5,lr}
|
|
||||||
ldr r4, =gPlayerParty
|
|
||||||
movs r5, 0
|
|
||||||
_080F9592:
|
|
||||||
adds r0, r4, 0
|
|
||||||
bl sub_80F9568
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F95B0
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x39
|
|
||||||
bl GetMonData
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F95B0
|
|
||||||
movs r0, 0
|
|
||||||
b _080F95BA
|
|
||||||
.pool
|
|
||||||
_080F95B0:
|
|
||||||
adds r5, 0x1
|
|
||||||
adds r4, 0x64
|
|
||||||
cmp r5, 0x5
|
|
||||||
ble _080F9592
|
|
||||||
movs r0, 0x1
|
|
||||||
_080F95BA:
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end sub_80F958C
|
|
||||||
|
|
||||||
thumb_func_start sub_80F95C0
|
|
||||||
sub_80F95C0: @ 80F95C0
|
|
||||||
push {r4,r5,lr}
|
|
||||||
sub sp, 0x4
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
movs r1, 0x64
|
|
||||||
adds r4, r0, 0
|
|
||||||
muls r4, r1
|
|
||||||
ldr r0, =gPlayerParty
|
|
||||||
adds r4, r0
|
|
||||||
movs r0, 0
|
|
||||||
str r0, [sp]
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x7
|
|
||||||
bl AdjustFriendship
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x37
|
|
||||||
mov r2, sp
|
|
||||||
bl SetMonData
|
|
||||||
ldr r5, =gStringVar1
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x2
|
|
||||||
adds r2, r5, 0
|
|
||||||
bl GetMonData
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl StringGetEnd10
|
|
||||||
add sp, 0x4
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_80F95C0
|
|
||||||
|
|
||||||
thumb_func_start sub_80F960C
|
|
||||||
sub_80F960C: @ 80F960C
|
|
||||||
push {r4,lr}
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
movs r1, 0x64
|
|
||||||
muls r1, r0
|
|
||||||
ldr r0, =gPlayerParty
|
|
||||||
adds r4, r1, r0
|
|
||||||
adds r0, r4, 0
|
|
||||||
bl sub_80F9568
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F964C
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x39
|
|
||||||
bl GetMonData
|
|
||||||
cmp r0, 0
|
|
||||||
bne _080F964C
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x37
|
|
||||||
bl GetMonData
|
|
||||||
bl pokemon_ailments_get_primary
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
cmp r0, 0x1
|
|
||||||
bne _080F964C
|
|
||||||
movs r0, 0x1
|
|
||||||
b _080F964E
|
|
||||||
.pool
|
|
||||||
_080F964C:
|
|
||||||
movs r0, 0
|
|
||||||
_080F964E:
|
|
||||||
pop {r4}
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end sub_80F960C
|
|
||||||
|
|
||||||
thumb_func_start sub_80F9654
|
|
||||||
sub_80F9654: @ 80F9654
|
|
||||||
push {r4-r6,lr}
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r6, r0, 24
|
|
||||||
lsls r0, r6, 2
|
|
||||||
adds r0, r6
|
|
||||||
lsls r0, 3
|
|
||||||
ldr r1, =gTasks + 0x8
|
|
||||||
adds r4, r0, r1
|
|
||||||
movs r0, 0
|
|
||||||
ldrsh r5, [r4, r0]
|
|
||||||
cmp r5, 0x1
|
|
||||||
beq _080F96AE
|
|
||||||
cmp r5, 0x1
|
|
||||||
bgt _080F967C
|
|
||||||
cmp r5, 0
|
|
||||||
beq _080F9682
|
|
||||||
b _080F9722
|
|
||||||
.pool
|
|
||||||
_080F967C:
|
|
||||||
cmp r5, 0x2
|
|
||||||
beq _080F96C0
|
|
||||||
b _080F9722
|
|
||||||
_080F9682:
|
|
||||||
ldrh r1, [r4, 0x2]
|
|
||||||
movs r2, 0x2
|
|
||||||
ldrsh r0, [r4, r2]
|
|
||||||
cmp r0, 0x5
|
|
||||||
bgt _080F96A8
|
|
||||||
_080F968C:
|
|
||||||
lsls r0, r1, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
bl sub_80F960C
|
|
||||||
cmp r0, 0
|
|
||||||
bne _080F96FC
|
|
||||||
ldrh r0, [r4, 0x2]
|
|
||||||
adds r0, 0x1
|
|
||||||
strh r0, [r4, 0x2]
|
|
||||||
adds r1, r0, 0
|
|
||||||
lsls r0, 16
|
|
||||||
asrs r0, 16
|
|
||||||
cmp r0, 0x5
|
|
||||||
ble _080F968C
|
|
||||||
_080F96A8:
|
|
||||||
movs r0, 0x2
|
|
||||||
strh r0, [r4]
|
|
||||||
b _080F9722
|
|
||||||
_080F96AE:
|
|
||||||
bl IsFieldMessageBoxHidden
|
|
||||||
lsls r0, 24
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F9722
|
|
||||||
ldrh r0, [r4]
|
|
||||||
subs r0, 0x1
|
|
||||||
strh r0, [r4]
|
|
||||||
b _080F9722
|
|
||||||
_080F96C0:
|
|
||||||
bl sub_80F958C
|
|
||||||
adds r1, r0, 0
|
|
||||||
cmp r1, 0
|
|
||||||
beq _080F9714
|
|
||||||
bl InBattlePyramid
|
|
||||||
adds r4, r0, 0
|
|
||||||
bl InBattlePike
|
|
||||||
orrs r4, r0
|
|
||||||
lsls r4, 24
|
|
||||||
cmp r4, 0
|
|
||||||
bne _080F96E6
|
|
||||||
bl sub_81D5C18
|
|
||||||
lsls r0, 24
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F96F0
|
|
||||||
_080F96E6:
|
|
||||||
ldr r0, =gSpecialVar_Result
|
|
||||||
strh r5, [r0]
|
|
||||||
b _080F9718
|
|
||||||
.pool
|
|
||||||
_080F96F0:
|
|
||||||
ldr r1, =gSpecialVar_Result
|
|
||||||
movs r0, 0x1
|
|
||||||
strh r0, [r1]
|
|
||||||
b _080F9718
|
|
||||||
.pool
|
|
||||||
_080F96FC:
|
|
||||||
ldrb r0, [r4, 0x2]
|
|
||||||
bl sub_80F95C0
|
|
||||||
ldr r0, =gText_PkmnFainted3
|
|
||||||
bl ShowFieldMessage
|
|
||||||
ldrh r0, [r4]
|
|
||||||
adds r0, 0x1
|
|
||||||
strh r0, [r4]
|
|
||||||
b _080F9722
|
|
||||||
.pool
|
|
||||||
_080F9714:
|
|
||||||
ldr r0, =gSpecialVar_Result
|
|
||||||
strh r1, [r0]
|
|
||||||
_080F9718:
|
|
||||||
bl EnableBothScriptContexts
|
|
||||||
adds r0, r6, 0
|
|
||||||
bl DestroyTask
|
|
||||||
_080F9722:
|
|
||||||
pop {r4-r6}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_80F9654
|
|
||||||
|
|
||||||
thumb_func_start sub_80F972C
|
|
||||||
sub_80F972C: @ 80F972C
|
|
||||||
push {lr}
|
|
||||||
ldr r0, =sub_80F9654
|
|
||||||
movs r1, 0x50
|
|
||||||
bl CreateTask
|
|
||||||
bl ScriptContext1_Stop
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_80F972C
|
|
||||||
|
|
||||||
thumb_func_start overworld_poison
|
|
||||||
overworld_poison: @ 80F9744
|
|
||||||
push {r4-r7,lr}
|
|
||||||
sub sp, 0x4
|
|
||||||
ldr r4, =gPlayerParty
|
|
||||||
movs r7, 0
|
|
||||||
movs r6, 0
|
|
||||||
movs r5, 0x5
|
|
||||||
_080F9750:
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x5
|
|
||||||
bl GetMonData
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F9794
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x37
|
|
||||||
bl GetMonData
|
|
||||||
bl pokemon_ailments_get_primary
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
cmp r0, 0x1
|
|
||||||
bne _080F9794
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x39
|
|
||||||
bl GetMonData
|
|
||||||
str r0, [sp]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080F9786
|
|
||||||
subs r0, 0x1
|
|
||||||
str r0, [sp]
|
|
||||||
cmp r0, 0
|
|
||||||
bne _080F9788
|
|
||||||
_080F9786:
|
|
||||||
adds r6, 0x1
|
|
||||||
_080F9788:
|
|
||||||
adds r0, r4, 0
|
|
||||||
movs r1, 0x39
|
|
||||||
mov r2, sp
|
|
||||||
bl SetMonData
|
|
||||||
adds r7, 0x1
|
|
||||||
_080F9794:
|
|
||||||
adds r4, 0x64
|
|
||||||
subs r5, 0x1
|
|
||||||
cmp r5, 0
|
|
||||||
bge _080F9750
|
|
||||||
cmp r6, 0
|
|
||||||
bne _080F97A4
|
|
||||||
cmp r7, 0
|
|
||||||
beq _080F97A8
|
|
||||||
_080F97A4:
|
|
||||||
bl overworld_posion_effect
|
|
||||||
_080F97A8:
|
|
||||||
cmp r6, 0
|
|
||||||
beq _080F97B4
|
|
||||||
movs r0, 0x2
|
|
||||||
b _080F97BE
|
|
||||||
.pool
|
|
||||||
_080F97B4:
|
|
||||||
cmp r7, 0
|
|
||||||
bne _080F97BC
|
|
||||||
movs r0, 0
|
|
||||||
b _080F97BE
|
|
||||||
_080F97BC:
|
|
||||||
movs r0, 0x1
|
|
||||||
_080F97BE:
|
|
||||||
add sp, 0x4
|
|
||||||
pop {r4-r7}
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end overworld_poison
|
|
||||||
|
|
||||||
.align 2, 0 @ Don't pad with nop.
|
|
@ -2200,8 +2200,8 @@ _080FAE2A:
|
|||||||
.pool
|
.pool
|
||||||
thumb_func_end sub_80FADE4
|
thumb_func_end sub_80FADE4
|
||||||
|
|
||||||
thumb_func_start task50_overworld_posion_effect
|
thumb_func_start task50_overworld_poison_effect
|
||||||
task50_overworld_posion_effect: @ 80FAE38
|
task50_overworld_poison_effect: @ 80FAE38
|
||||||
push {lr}
|
push {lr}
|
||||||
lsls r0, 24
|
lsls r0, 24
|
||||||
lsrs r2, r0, 24
|
lsrs r2, r0, 24
|
||||||
@ -2260,25 +2260,25 @@ _080FAE92:
|
|||||||
_080FAEA2:
|
_080FAEA2:
|
||||||
pop {r0}
|
pop {r0}
|
||||||
bx r0
|
bx r0
|
||||||
thumb_func_end task50_overworld_posion_effect
|
thumb_func_end task50_overworld_poison_effect
|
||||||
|
|
||||||
thumb_func_start overworld_posion_effect
|
thumb_func_start overworld_poison_effect
|
||||||
overworld_posion_effect: @ 80FAEA8
|
overworld_poison_effect: @ 80FAEA8
|
||||||
push {lr}
|
push {lr}
|
||||||
movs r0, 0x4F
|
movs r0, 0x4F
|
||||||
bl PlaySE
|
bl PlaySE
|
||||||
ldr r0, =task50_overworld_posion_effect
|
ldr r0, =task50_overworld_poison_effect
|
||||||
movs r1, 0x50
|
movs r1, 0x50
|
||||||
bl CreateTask
|
bl CreateTask
|
||||||
pop {r0}
|
pop {r0}
|
||||||
bx r0
|
bx r0
|
||||||
.pool
|
.pool
|
||||||
thumb_func_end overworld_posion_effect
|
thumb_func_end overworld_poison_effect
|
||||||
|
|
||||||
thumb_func_start FieldPoisonEffectIsRunning
|
thumb_func_start FieldPoisonEffectIsRunning
|
||||||
FieldPoisonEffectIsRunning: @ 80FAEC0
|
FieldPoisonEffectIsRunning: @ 80FAEC0
|
||||||
push {lr}
|
push {lr}
|
||||||
ldr r0, =task50_overworld_posion_effect
|
ldr r0, =task50_overworld_poison_effect
|
||||||
bl FuncIsActiveTask
|
bl FuncIsActiveTask
|
||||||
lsls r0, 24
|
lsls r0, 24
|
||||||
lsrs r0, 24
|
lsrs r0, 24
|
||||||
|
@ -1,57 +0,0 @@
|
|||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
thumb_func_start sub_81BAD84
|
|
||||||
sub_81BAD84: @ 81BAD84
|
|
||||||
push {r4-r6,lr}
|
|
||||||
movs r6, 0x80
|
|
||||||
lsls r6, 19
|
|
||||||
movs r2, 0
|
|
||||||
strh r2, [r6]
|
|
||||||
ldr r1, =0x04000010
|
|
||||||
strh r2, [r1]
|
|
||||||
adds r1, 0x2
|
|
||||||
strh r2, [r1]
|
|
||||||
adds r1, 0x3E
|
|
||||||
strh r2, [r1]
|
|
||||||
ldr r5, =gUnknown_08617128
|
|
||||||
lsls r4, r0, 1
|
|
||||||
adds r4, r0
|
|
||||||
lsls r4, 2
|
|
||||||
adds r0, r4, r5
|
|
||||||
ldr r0, [r0]
|
|
||||||
movs r1, 0xC0
|
|
||||||
lsls r1, 19
|
|
||||||
bl LZ77UnCompVram
|
|
||||||
adds r0, r5, 0x4
|
|
||||||
adds r0, r4, r0
|
|
||||||
ldr r0, [r0]
|
|
||||||
ldr r1, =0x0600f800
|
|
||||||
bl LZ77UnCompVram
|
|
||||||
adds r5, 0x8
|
|
||||||
adds r4, r5
|
|
||||||
ldr r0, [r4]
|
|
||||||
movs r1, 0xA0
|
|
||||||
lsls r1, 19
|
|
||||||
movs r4, 0x80
|
|
||||||
lsls r4, 1
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl CpuSet
|
|
||||||
ldr r1, =0x04000008
|
|
||||||
movs r2, 0xF8
|
|
||||||
lsls r2, 5
|
|
||||||
adds r0, r2, 0
|
|
||||||
strh r0, [r1]
|
|
||||||
strh r4, [r6]
|
|
||||||
pop {r4-r6}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_81BAD84
|
|
||||||
|
|
||||||
|
|
||||||
.align 2, 0 @ Don't pad with nop.
|
|
@ -1,7 +0,0 @@
|
|||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.section .rodata
|
|
||||||
|
|
||||||
gUnknown_08617128:: @ 8617128
|
|
||||||
.incbin "baserom.gba", 0x617128, 0x48
|
|
@ -88,6 +88,7 @@
|
|||||||
|
|
||||||
#define BATTLE_OUTCOME_BIT_x80 0x80
|
#define BATTLE_OUTCOME_BIT_x80 0x80
|
||||||
|
|
||||||
|
#define STATUS_NONE 0x0
|
||||||
#define STATUS_SLEEP 0x7
|
#define STATUS_SLEEP 0x7
|
||||||
#define STATUS_POISON 0x8
|
#define STATUS_POISON 0x8
|
||||||
#define STATUS_BURN 0x10
|
#define STATUS_BURN 0x10
|
||||||
|
@ -5,5 +5,6 @@ void sub_81A8934(u8);
|
|||||||
void sub_81A895C(void);
|
void sub_81A895C(void);
|
||||||
u16 sub_81A89A0(u8);
|
u16 sub_81A89A0(u8);
|
||||||
void sub_81A8AF8(void);
|
void sub_81A8AF8(void);
|
||||||
|
bool8 InBattlePike(void);
|
||||||
|
|
||||||
#endif // GUARD_BATTLE_FRONTIER_2_H
|
#endif // GUARD_BATTLE_FRONTIER_2_H
|
||||||
|
19
include/field_poison.h
Normal file
19
include/field_poison.h
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
#ifndef GUARD_FIELD_POISON_H
|
||||||
|
#define GUARD_FIELD_POISON_H
|
||||||
|
|
||||||
|
// Exported type declarations
|
||||||
|
|
||||||
|
// Exported RAM declarations
|
||||||
|
|
||||||
|
// Exported ROM declarations
|
||||||
|
|
||||||
|
enum {
|
||||||
|
FLDPSN_NONE,
|
||||||
|
FLDPSN_PSN,
|
||||||
|
FLDPSN_FNT
|
||||||
|
};
|
||||||
|
|
||||||
|
void sub_80F972C(void);
|
||||||
|
unsigned int overworld_poison(void);
|
||||||
|
|
||||||
|
#endif //GUARD_FIELD_POISON_H
|
@ -9,5 +9,6 @@
|
|||||||
|
|
||||||
void sub_80FA5E4(s16 id, s16 x, s16 y);
|
void sub_80FA5E4(s16 id, s16 x, s16 y);
|
||||||
void sub_80FA794(s16 x, s16 y);
|
void sub_80FA794(s16 x, s16 y);
|
||||||
|
void overworld_poison_effect(void);
|
||||||
|
|
||||||
#endif //GUARD_FLDEFF_80F9BCC_H
|
#endif //GUARD_FLDEFF_80F9BCC_H
|
||||||
|
@ -91,5 +91,23 @@ extern const u8 gUnknown_08DB9F08[];
|
|||||||
extern const u8 gUnknown_08DB9FFC[];
|
extern const u8 gUnknown_08DB9FFC[];
|
||||||
extern const u8 gUnknown_08DBA020[];
|
extern const u8 gUnknown_08DBA020[];
|
||||||
extern const u8 gUnknown_08DBA12C[];
|
extern const u8 gUnknown_08DBA12C[];
|
||||||
|
extern const u8 gUnknown_08DD87C0[];
|
||||||
|
extern const u8 gUnknown_08DD8EE0[];
|
||||||
|
extern const u16 gUnknown_08DD8780[];
|
||||||
|
extern const u8 gUnknown_08DD90E0[];
|
||||||
|
extern const u8 gUnknown_08DD9718[];
|
||||||
|
extern const u16 gUnknown_08DD9080[];
|
||||||
|
extern const u8 gUnknown_08DD98B4[];
|
||||||
|
extern const u8 gUnknown_08DD9E58[];
|
||||||
|
extern const u16 gUnknown_08DD9874[];
|
||||||
|
extern const u8 gUnknown_08DDA02C[];
|
||||||
|
extern const u8 gUnknown_08DDA63C[];
|
||||||
|
extern const u16 gUnknown_08DD9FEC[];
|
||||||
|
extern const u8 gUnknown_08DDA840[];
|
||||||
|
extern const u8 gUnknown_08DDAE40[];
|
||||||
|
extern const u16 gUnknown_08DDA800[];
|
||||||
|
extern const u8 gUnknown_08DDB020[];
|
||||||
|
extern const u8 gUnknown_08DDB2C4[];
|
||||||
|
extern const u16 gUnknown_08DDAFE0[];
|
||||||
|
|
||||||
#endif //GUARD_GRAPHICS_H
|
#endif //GUARD_GRAPHICS_H
|
||||||
|
@ -1,8 +1,18 @@
|
|||||||
#ifndef GUARD_PARTY_MENU_H
|
#ifndef GUARD_PARTY_MENU_H
|
||||||
#define GUARD_PARTY_MENU_H
|
#define GUARD_PARTY_MENU_H
|
||||||
|
|
||||||
|
enum {
|
||||||
|
AILMENT_NONE,
|
||||||
|
AILMENT_PSN,
|
||||||
|
AILMENT_PRZ,
|
||||||
|
AILMENT_SLP,
|
||||||
|
AILMENT_FRZ,
|
||||||
|
AILMENT_BRN
|
||||||
|
};
|
||||||
|
|
||||||
bool8 pokemon_has_move(struct Pokemon *, u16);
|
bool8 pokemon_has_move(struct Pokemon *, u16);
|
||||||
void sub_81B58A8(void);
|
void sub_81B58A8(void);
|
||||||
void DoWallyTutorialBagMenu(void);
|
void DoWallyTutorialBagMenu(void);
|
||||||
|
u8 pokemon_ailments_get_primary(u32 status);
|
||||||
|
|
||||||
#endif // GUARD_PARTY_MENU_H
|
#endif // GUARD_PARTY_MENU_H
|
||||||
|
6
include/pokenav.h
Normal file
6
include/pokenav.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#ifndef GUARD_POKENAV_H
|
||||||
|
#define GUARD_POKENAV_H
|
||||||
|
|
||||||
|
bool8 sub_81D5C18(void);
|
||||||
|
|
||||||
|
#endif //GUARD_POKENAV_H
|
@ -83,5 +83,7 @@ extern const u8 gText_OkayToDeleteFromRegistry[];
|
|||||||
extern const u8 gText_RegisteredDataDeleted[];
|
extern const u8 gText_RegisteredDataDeleted[];
|
||||||
extern const u8 gUnknown_085EA79D[];
|
extern const u8 gUnknown_085EA79D[];
|
||||||
extern const u8 gText_EmptyString2[];
|
extern const u8 gText_EmptyString2[];
|
||||||
|
extern const u8 gText_PkmnFainted3[];
|
||||||
|
extern const u8 gText_Coins[];
|
||||||
|
|
||||||
#endif //GUARD_STRINGS_H
|
#endif //GUARD_STRINGS_H
|
||||||
|
@ -152,7 +152,7 @@ SECTIONS {
|
|||||||
src/tv.o(.text);
|
src/tv.o(.text);
|
||||||
asm/contest_link_80F57C4.o(.text);
|
asm/contest_link_80F57C4.o(.text);
|
||||||
asm/script_pokemon_util_80F87D8.o(.text);
|
asm/script_pokemon_util_80F87D8.o(.text);
|
||||||
asm/field_poison.o(.text);
|
src/field_poison.o(.text);
|
||||||
src/pokemon_size_record.o(.text);
|
src/pokemon_size_record.o(.text);
|
||||||
asm/fldeff_80F9BCC.o(.text);
|
asm/fldeff_80F9BCC.o(.text);
|
||||||
src/field_special_scene.o(.text);
|
src/field_special_scene.o(.text);
|
||||||
@ -185,7 +185,6 @@ SECTIONS {
|
|||||||
asm/roulette.o(.text);
|
asm/roulette.o(.text);
|
||||||
asm/pokedex_cry_screen.o(.text);
|
asm/pokedex_cry_screen.o(.text);
|
||||||
src/coins.o(.text);
|
src/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);
|
||||||
asm/battle_transition.o(.text);
|
asm/battle_transition.o(.text);
|
||||||
@ -250,7 +249,7 @@ SECTIONS {
|
|||||||
asm/battle_tent.o(.text);
|
asm/battle_tent.o(.text);
|
||||||
src/unk_text_util_2.o(.text);
|
src/unk_text_util_2.o(.text);
|
||||||
src/multiboot.o(.text);
|
src/multiboot.o(.text);
|
||||||
asm/unk_81BAD84.o(.text);
|
src/unk_81BAD84.o(.text);
|
||||||
src/battle_controller_player_partner.o(.text);
|
src/battle_controller_player_partner.o(.text);
|
||||||
asm/fldeff_groundshake.o(.text);
|
asm/fldeff_groundshake.o(.text);
|
||||||
asm/fossil_specials.o(.text);
|
asm/fossil_specials.o(.text);
|
||||||
@ -471,7 +470,7 @@ SECTIONS {
|
|||||||
data/party_menu.o(.rodata);
|
data/party_menu.o(.rodata);
|
||||||
data/battle_tent.o(.rodata);
|
data/battle_tent.o(.rodata);
|
||||||
src/unk_text_util_2.o(.rodata);
|
src/unk_text_util_2.o(.rodata);
|
||||||
data/unk_81BAD84.o(.rodata);
|
src/unk_81BAD84.o(.rodata);
|
||||||
src/battle_controller_player_partner.o(.rodata);
|
src/battle_controller_player_partner.o(.rodata);
|
||||||
data/fossil_special_fldeff_groundshake.o(.rodata);
|
data/fossil_special_fldeff_groundshake.o(.rodata);
|
||||||
src/berry_fix_program.o(.rodata);
|
src/berry_fix_program.o(.rodata);
|
||||||
|
28
src/coins.c
28
src/coins.c
@ -2,8 +2,9 @@
|
|||||||
#include "coins.h"
|
#include "coins.h"
|
||||||
#include "text.h"
|
#include "text.h"
|
||||||
#include "window.h"
|
#include "window.h"
|
||||||
#include "text_window.h"
|
#include "strings.h"
|
||||||
#include "string_util.h"
|
#include "string_util.h"
|
||||||
|
#include "new_menu_helpers.h"
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
#include "international_string_util.h"
|
#include "international_string_util.h"
|
||||||
|
|
||||||
@ -11,10 +12,6 @@
|
|||||||
|
|
||||||
EWRAM_DATA u8 sCoinsWindowId = 0;
|
EWRAM_DATA u8 sCoinsWindowId = 0;
|
||||||
|
|
||||||
extern void sub_819746C(u8 windowId, bool8 copyToVram);
|
|
||||||
|
|
||||||
extern const u8 gText_Coins[];
|
|
||||||
|
|
||||||
void PrintCoinsString(u32 coinAmount)
|
void PrintCoinsString(u32 coinAmount)
|
||||||
{
|
{
|
||||||
u32 xAlign;
|
u32 xAlign;
|
||||||
@ -53,7 +50,6 @@ void SetCoins(u16 coinAmount)
|
|||||||
gSaveBlock1Ptr->coins = coinAmount ^ gSaveBlock2Ptr->encryptionKey;
|
gSaveBlock1Ptr->coins = coinAmount ^ gSaveBlock2Ptr->encryptionKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Can't match it lol
|
|
||||||
bool8 GiveCoins(u16 toAdd)
|
bool8 GiveCoins(u16 toAdd)
|
||||||
{
|
{
|
||||||
u16 newAmount;
|
u16 newAmount;
|
||||||
@ -67,10 +63,22 @@ bool8 GiveCoins(u16 toAdd)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
newAmount = ownedCoins + toAdd;
|
ownedCoins += toAdd;
|
||||||
if (newAmount > MAX_COINS)
|
if (ownedCoins > MAX_COINS)
|
||||||
newAmount = MAX_COINS;
|
ownedCoins = MAX_COINS;
|
||||||
|
newAmount = ownedCoins;
|
||||||
}
|
}
|
||||||
SetCoins(newAmount);
|
SetCoins(newAmount);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}*/
|
}
|
||||||
|
|
||||||
|
bool8 TakeCoins(u16 toSub)
|
||||||
|
{
|
||||||
|
u16 ownedCoins = GetCoins();
|
||||||
|
if (ownedCoins >= toSub)
|
||||||
|
{
|
||||||
|
SetCoins(ownedCoins - toSub);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
148
src/field_poison.c
Normal file
148
src/field_poison.c
Normal file
@ -0,0 +1,148 @@
|
|||||||
|
#include "global.h"
|
||||||
|
#include "string_util.h"
|
||||||
|
#include "party_menu.h"
|
||||||
|
#include "species.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "field_message_box.h"
|
||||||
|
#include "strings.h"
|
||||||
|
#include "rom_818CFC8.h"
|
||||||
|
#include "battle_frontier_2.h"
|
||||||
|
#include "pokenav.h"
|
||||||
|
#include "event_data.h"
|
||||||
|
#include "script.h"
|
||||||
|
#include "battle.h"
|
||||||
|
#include "fldeff_80F9BCC.h"
|
||||||
|
#include "field_poison.h"
|
||||||
|
|
||||||
|
static bool32 sub_80F9568(struct Pokemon *pokemon)
|
||||||
|
{
|
||||||
|
u16 species = GetMonData(pokemon, MON_DATA_SPECIES2);
|
||||||
|
if (species == SPECIES_NONE || species == SPECIES_EGG)
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool32 sub_80F958C(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
struct Pokemon *pokemon;
|
||||||
|
|
||||||
|
for (pokemon = gPlayerParty, i = 0; i < PARTY_SIZE; i++, pokemon++)
|
||||||
|
{
|
||||||
|
if (sub_80F9568(pokemon) && GetMonData(pokemon, MON_DATA_HP) != 0)
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sub_80F95C0(u8 partyIdx)
|
||||||
|
{
|
||||||
|
struct Pokemon *pokemon = gPlayerParty + partyIdx;
|
||||||
|
unsigned int status = STATUS_NONE;
|
||||||
|
AdjustFriendship(pokemon, 0x07);
|
||||||
|
SetMonData(pokemon, MON_DATA_STATUS, &status);
|
||||||
|
GetMonData(pokemon, MON_DATA_NICKNAME, gStringVar1);
|
||||||
|
StringGetEnd10(gStringVar1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool32 sub_80F960C(u8 partyIdx)
|
||||||
|
{
|
||||||
|
struct Pokemon *pokemon = gPlayerParty + partyIdx;
|
||||||
|
if (sub_80F9568(pokemon) && GetMonData(pokemon, MON_DATA_HP) == 0 && pokemon_ailments_get_primary(GetMonData(pokemon, MON_DATA_STATUS)) == AILMENT_PSN)
|
||||||
|
{
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sub_80F9654(u8 taskId)
|
||||||
|
{
|
||||||
|
s16 *data = gTasks[taskId].data;
|
||||||
|
switch (data[0])
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
for (; data[1] < PARTY_SIZE; data[1]++)
|
||||||
|
{
|
||||||
|
if (sub_80F960C(data[1]))
|
||||||
|
{
|
||||||
|
sub_80F95C0(data[1]);
|
||||||
|
ShowFieldMessage(gText_PkmnFainted3);
|
||||||
|
data[0]++;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
data[0] = 2;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
if (IsFieldMessageBoxHidden())
|
||||||
|
{
|
||||||
|
data[0]--;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
if (sub_80F958C())
|
||||||
|
{
|
||||||
|
if (InBattlePyramid() | InBattlePike() || sub_81D5C18())
|
||||||
|
{
|
||||||
|
gSpecialVar_Result = 2;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gSpecialVar_Result = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gSpecialVar_Result = 0;
|
||||||
|
}
|
||||||
|
EnableBothScriptContexts();
|
||||||
|
DestroyTask(taskId);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_80F972C(void)
|
||||||
|
{
|
||||||
|
CreateTask(sub_80F9654, 80);
|
||||||
|
ScriptContext1_Stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned int overworld_poison(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
unsigned int hp;
|
||||||
|
struct Pokemon *pokemon = gPlayerParty;
|
||||||
|
unsigned int numPoisoned = 0;
|
||||||
|
unsigned int numFainted = 0;
|
||||||
|
for (i = 0; i < PARTY_SIZE; i++)
|
||||||
|
{
|
||||||
|
if (GetMonData(pokemon, MON_DATA_SANITY_BIT2) && pokemon_ailments_get_primary(GetMonData(pokemon, MON_DATA_STATUS)) == AILMENT_PSN)
|
||||||
|
{
|
||||||
|
hp = GetMonData(pokemon, MON_DATA_HP);
|
||||||
|
if (hp == 0 || --hp == 0)
|
||||||
|
{
|
||||||
|
numFainted++;
|
||||||
|
}
|
||||||
|
SetMonData(pokemon, MON_DATA_HP, &hp);
|
||||||
|
numPoisoned++;
|
||||||
|
}
|
||||||
|
pokemon++;
|
||||||
|
}
|
||||||
|
if (numFainted != 0 || numPoisoned != 0)
|
||||||
|
{
|
||||||
|
overworld_poison_effect();
|
||||||
|
}
|
||||||
|
if (numFainted != 0)
|
||||||
|
{
|
||||||
|
return FLDPSN_FNT;
|
||||||
|
}
|
||||||
|
if (numPoisoned != 0)
|
||||||
|
{
|
||||||
|
return FLDPSN_PSN;
|
||||||
|
}
|
||||||
|
return FLDPSN_NONE;
|
||||||
|
}
|
47
src/unk_81BAD84.c
Normal file
47
src/unk_81BAD84.c
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
#include "global.h"
|
||||||
|
#include "graphics.h"
|
||||||
|
|
||||||
|
const struct {
|
||||||
|
const u8 *gfx;
|
||||||
|
const u8 *tileMap;
|
||||||
|
const u16 *pltt;
|
||||||
|
} gUnknown_08617128[] = {
|
||||||
|
{
|
||||||
|
gUnknown_08DD87C0,
|
||||||
|
gUnknown_08DD8EE0,
|
||||||
|
gUnknown_08DD8780
|
||||||
|
}, {
|
||||||
|
gUnknown_08DD90E0,
|
||||||
|
gUnknown_08DD9718,
|
||||||
|
gUnknown_08DD9080
|
||||||
|
}, {
|
||||||
|
gUnknown_08DD98B4,
|
||||||
|
gUnknown_08DD9E58,
|
||||||
|
gUnknown_08DD9874
|
||||||
|
}, {
|
||||||
|
gUnknown_08DDA02C,
|
||||||
|
gUnknown_08DDA63C,
|
||||||
|
gUnknown_08DD9FEC
|
||||||
|
}, {
|
||||||
|
gUnknown_08DDA840,
|
||||||
|
gUnknown_08DDAE40,
|
||||||
|
gUnknown_08DDA800
|
||||||
|
}, {
|
||||||
|
gUnknown_08DDB020,
|
||||||
|
gUnknown_08DDB2C4,
|
||||||
|
gUnknown_08DDAFE0
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void sub_81BAD84(u32 idx)
|
||||||
|
{
|
||||||
|
REG_DISPCNT = 0x0000;
|
||||||
|
REG_BG0HOFS = 0x0000;
|
||||||
|
REG_BG0VOFS = 0x0000;
|
||||||
|
REG_BLDCNT = 0x0000;
|
||||||
|
LZ77UnCompVram(gUnknown_08617128[idx].gfx, (void *)BG_CHAR_ADDR(0));
|
||||||
|
LZ77UnCompVram(gUnknown_08617128[idx].tileMap, (void *)BG_SCREEN_ADDR(31));
|
||||||
|
CpuCopy16(gUnknown_08617128[idx].pltt, (void *)PLTT, 0x200);
|
||||||
|
REG_BG0CNT = 0x1f00;
|
||||||
|
REG_DISPCNT = DISPCNT_BG0_ON;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user