diff options
| author | scnorton <scnorton@biociphers.org> | 2017-06-20 10:07:50 -0400 | 
|---|---|---|
| committer | scnorton <scnorton@biociphers.org> | 2017-06-20 10:07:50 -0400 | 
| commit | c54e2be332b56395ae2e913bd2d3bb3d25cc3336 (patch) | |
| tree | 104d7378adf815cce05650414d36eea394847d21 | |
| parent | 5aeef909084e6dd8ea75cfc34cdd2601cab1de39 (diff) | |
Up through GetLeadMonFriendshipScore
| -rwxr-xr-x | asm/field_specials.s | 135 | ||||
| -rwxr-xr-x | src/field_specials.c | 58 | 
2 files changed, 58 insertions, 135 deletions
| diff --git a/asm/field_specials.s b/asm/field_specials.s index 63eda00b6..7bf12b5aa 100755 --- a/asm/field_specials.s +++ b/asm/field_specials.s @@ -6,141 +6,6 @@  	.text -	thumb_func_start CableCarWarp -CableCarWarp: @ 810E30C -	push {lr} -	sub sp, 0x4 -	ldr r0, _0810E32C @ =gSpecialVar_0x8004 -	ldrh r0, [r0] -	cmp r0, 0 -	beq _0810E330 -	movs r2, 0x1 -	negs r2, r2 -	movs r0, 0x4 -	str r0, [sp] -	movs r0, 0x13 -	movs r1, 0 -	movs r3, 0x6 -	bl warp1_set -	b _0810E342 -	.align 2, 0 -_0810E32C: .4byte gSpecialVar_0x8004 -_0810E330: -	movs r2, 0x1 -	negs r2, r2 -	movs r0, 0x4 -	str r0, [sp] -	movs r0, 0x13 -	movs r1, 0x1 -	movs r3, 0x6 -	bl warp1_set -_0810E342: -	add sp, 0x4 -	pop {r0} -	bx r0 -	thumb_func_end CableCarWarp - -	thumb_func_start SetFlagInVar -SetFlagInVar: @ 810E348 -	push {lr} -	ldr r0, _0810E358 @ =gSpecialVar_0x8004 -	ldrh r0, [r0] -	bl FlagSet -	pop {r0} -	bx r0 -	.align 2, 0 -_0810E358: .4byte gSpecialVar_0x8004 -	thumb_func_end SetFlagInVar - -	thumb_func_start GetWeekCount -GetWeekCount: @ 810E35C -	push {lr} -	ldr r0, _0810E37C @ =gLocalTime -	movs r1, 0 -	ldrsh r0, [r0, r1] -	movs r1, 0x7 -	bl __divsi3 -	lsls r0, 16 -	lsrs r0, 16 -	ldr r1, _0810E380 @ =0x0000270f -	cmp r0, r1 -	bls _0810E376 -	adds r0, r1, 0 -_0810E376: -	pop {r1} -	bx r1 -	.align 2, 0 -_0810E37C: .4byte gLocalTime -_0810E380: .4byte 0x0000270f -	thumb_func_end GetWeekCount - -	thumb_func_start GetLeadMonFriendshipScore -GetLeadMonFriendshipScore: @ 810E384 -	push {r4,lr} -	bl GetLeadMonIndex -	lsls r0, 24 -	lsrs r0, 24 -	movs r1, 0x64 -	muls r1, r0 -	ldr r0, _0810E3A8 @ =gPlayerParty -	adds r4, r1, r0 -	adds r0, r4, 0 -	movs r1, 0x20 -	bl GetMonData -	cmp r0, 0xFF -	bne _0810E3AC -	movs r0, 0x6 -	b _0810E3FE -	.align 2, 0 -_0810E3A8: .4byte gPlayerParty -_0810E3AC: -	adds r0, r4, 0 -	movs r1, 0x20 -	bl GetMonData -	cmp r0, 0xC7 -	bls _0810E3BC -	movs r0, 0x5 -	b _0810E3FE -_0810E3BC: -	adds r0, r4, 0 -	movs r1, 0x20 -	bl GetMonData -	cmp r0, 0x95 -	bls _0810E3CC -	movs r0, 0x4 -	b _0810E3FE -_0810E3CC: -	adds r0, r4, 0 -	movs r1, 0x20 -	bl GetMonData -	cmp r0, 0x63 -	bls _0810E3DC -	movs r0, 0x3 -	b _0810E3FE -_0810E3DC: -	adds r0, r4, 0 -	movs r1, 0x20 -	bl GetMonData -	cmp r0, 0x31 -	bls _0810E3EC -	movs r0, 0x2 -	b _0810E3FE -_0810E3EC: -	adds r0, r4, 0 -	movs r1, 0x20 -	bl GetMonData -	cmp r0, 0 -	bne _0810E3FC -	movs r0, 0 -	b _0810E3FE -_0810E3FC: -	movs r0, 0x1 -_0810E3FE: -	pop {r4} -	pop {r1} -	bx r1 -	thumb_func_end GetLeadMonFriendshipScore -  	thumb_func_start CB2_FieldShowRegionMap  CB2_FieldShowRegionMap: @ 810E404  	push {lr} diff --git a/src/field_specials.c b/src/field_specials.c index ed2718d3d..0bee955c2 100755 --- a/src/field_specials.c +++ b/src/field_specials.c @@ -17,6 +17,7 @@  #include "text.h"  #include "wallclock.h"  #include "tv.h" +#include "rtc.h"  #include "link.h"  #include "songs.h"  #include "sound.h" @@ -672,3 +673,60 @@ u8 sub_810E300(void)  {      return gUnknown_02024D26;  } + +void CableCarWarp(void) +{ +    if (gSpecialVar_0x8004 != 0) +    { +        warp1_set(MAP_GROUP_ROUTE112_CABLE_CAR_STATION, MAP_ID_ROUTE112_CABLE_CAR_STATION, -1, 6, 4); +    } +    else +    { +        warp1_set(MAP_GROUP_MT_CHIMNEY_CABLE_CAR_STATION, MAP_ID_MT_CHIMNEY_CABLE_CAR_STATION, -1, 6, 4); +    } +} + +void SetFlagInVar(void) +{ +    FlagSet(gSpecialVar_0x8004); +} + +u16 GetWeekCount(void) +{ +    u16 weekCount = gLocalTime.days / 7; +    if (weekCount > 9999) +    { +        weekCount = 9999; +    } +    return weekCount; +} + +u8 GetLeadMonFriendshipScore(void) +{ +    struct Pokemon *pokemon = &gPlayerParty[GetLeadMonIndex()]; +    if (GetMonData(pokemon, MON_DATA_FRIENDSHIP) == 255) +    { +        return 6; +    } +    if (GetMonData(pokemon, MON_DATA_FRIENDSHIP) >= 200) +    { +        return 5; +    } +    if (GetMonData(pokemon, MON_DATA_FRIENDSHIP) >= 150) +    { +        return 4; +    } +    if (GetMonData(pokemon, MON_DATA_FRIENDSHIP) >= 100) +    { +        return 3; +    } +    if (GetMonData(pokemon, MON_DATA_FRIENDSHIP) >= 50) +    { +        return 2; +    } +    if (GetMonData(pokemon, MON_DATA_FRIENDSHIP) >= 1) +    { +        return 1; +    } +    return 0; +} | 
