calc_item_damage_enemy and some others (#641)

* SFX funcs, configure fix

* the actual rename (oops)

* 3 sprite funcs

* 2 funcz

* calc_item_damage_enemy and cleanup, others

* cleanup

* Warnings

* clean fx_api

* match npc_raycast_general and name npc_collision.c

* PR comment
This commit is contained in:
Ethan Roseman 2022-02-08 13:33:05 -05:00 committed by GitHub
parent 650d52d16a
commit 3a578399fb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
120 changed files with 1726 additions and 2672 deletions

View File

@ -218,10 +218,10 @@ typedef struct PlayerData {
/* 0x001 */ s8 hammerLevel; /* 0x001 */ s8 hammerLevel;
/* 0x002 */ s8 curHP; /* 0x002 */ s8 curHP;
/* 0x003 */ s8 curMaxHP; /* 0x003 */ s8 curMaxHP;
/* 0x004 */ u8 hardMaxHP; /* 0x004 */ s8 hardMaxHP;
/* 0x005 */ s8 curFP; /* 0x005 */ s8 curFP;
/* 0x006 */ s8 curMaxFP; /* 0x006 */ s8 curMaxFP;
/* 0x007 */ u8 hardMaxFP; /* 0x007 */ s8 hardMaxFP;
/* 0x008 */ s8 maxBP; /* 0x008 */ s8 maxBP;
/* 0x009 */ s8 level; /* 0x009 */ s8 level;
/* 0x00A */ s8 hasActionCommands; /* 0x00A */ s8 hasActionCommands;
@ -854,7 +854,7 @@ typedef struct BattleStatus {
/* 0x000 */ s32 flags1; /* 0x000 */ s32 flags1;
/* 0x004 */ s32 flags2; /* 0x004 */ s32 flags2;
/* 0x008 */ s32 varTable[16]; /* 0x008 */ s32 varTable[16];
/* 0x048 */ u8 currentSubmenu; /* 0x048 */ s8 currentSubmenu;
/* 0x049 */ char unk_49[3]; /* 0x049 */ char unk_49[3];
/* 0x04C */ s8 unk_4C[16]; /* 0x04C */ s8 unk_4C[16];
/* 0x05C */ s8 unk_5C[16]; /* 0x05C */ s8 unk_5C[16];
@ -862,8 +862,8 @@ typedef struct BattleStatus {
/* 0x070 */ s16 menuDisableFlags; /* 1 = jump, 2 = hammer, 4 = items */ /* 0x070 */ s16 menuDisableFlags; /* 1 = jump, 2 = hammer, 4 = items */
/* 0x072 */ char unk_72[2]; /* 0x072 */ char unk_72[2];
/* 0x074 */ s32 unk_74; /* 0x074 */ s32 unk_74;
/* 0x078 */ u8 totalStarPoints; /* 0x078 */ s8 totalStarPoints;
/* 0x079 */ u8 pendingStarPoints; /* how many to add */ /* 0x079 */ s8 pendingStarPoints; /* how many to add */
/* 0x07A */ u8 incrementStarPointDelay; /* related to star points, set to 0x28 when they are dropped */ /* 0x07A */ u8 incrementStarPointDelay; /* related to star points, set to 0x28 when they are dropped */
/* 0x07B */ u8 damageTaken; /* 0x07B */ u8 damageTaken;
/* 0x07C */ s8 changePartnerAllowed; /* 0x07C */ s8 changePartnerAllowed;
@ -1866,7 +1866,7 @@ typedef struct Actor {
/* 0x207 */ s8 extraCoinBonus; /* 0x207 */ s8 extraCoinBonus;
/* 0x208 */ s8 unk_208; /* 0x208 */ s8 unk_208;
/* 0x209 */ char unk_209[3]; /* 0x209 */ char unk_209[3];
/* 0x20C */ struct s32* statusTable; /* 0x20C */ s32* statusTable;
/* 0x210 */ s8 debuff; /* 0x210 */ s8 debuff;
/* 0x211 */ s8 debuffDuration; /* 0x211 */ s8 debuffDuration;
/* 0x212 */ s8 staticStatus; /* 0B = yes */ /* 0x212 */ s8 staticStatus; /* 0B = yes */
@ -2350,7 +2350,7 @@ typedef struct SaveMetadata {
typedef struct SpriteShadingLightSource { typedef struct SpriteShadingLightSource {
/* 0x00 */ s8 flags; /* 0x00 */ s8 flags;
/* 0x01 */ s8 rgb[3]; /* 0x01 */ Color_RGB8 rgb;
/* 0x04 */ Vec3f pos; /* 0x04 */ Vec3f pos;
/* 0x10 */ f32 falloff; /* 0x10 */ f32 falloff;
/* 0x14 */ s8 unk_14; /* 0x14 */ s8 unk_14;
@ -2361,7 +2361,7 @@ typedef struct SpriteShadingProfile {
/* 0x00 */ s16 flags; /* 0x00 */ s16 flags;
/* 0x02 */ char unk_02[0x2]; /* 0x02 */ char unk_02[0x2];
/* 0x04 */ SpriteShadingLightSource sources[7]; /* 0x04 */ SpriteShadingLightSource sources[7];
/* 0xAC */ s8 ambientColor[3]; /* 0xAC */ Color_RGB8 ambientColor;
/* 0xAF */ s8 ambientPower; // ? /* 0xAF */ s8 ambientPower; // ?
} SpriteShadingProfile; // size = 0xB0 } SpriteShadingProfile; // size = 0xB0

View File

@ -659,7 +659,7 @@ EffectInstance* fx_lens_flare(s32, f32, f32, f32, s32);
EffectInstance* fx_got_item_outline(s32, f32, f32, f32, f32, s32*); EffectInstance* fx_got_item_outline(s32, f32, f32, f32, f32, s32*);
EffectInstance* fx_spiky_white_aura(s32, f32, f32, f32, s32); EffectInstance* fx_spiky_white_aura(s32, f32, f32, f32, s32);
void fx_smoke_impact(s32, f32, f32, f32, f32, s32, f32, s32); void fx_smoke_impact(s32, f32, f32, f32, f32, s32, f32, s32);
EffectInstance* fx_damage_indicator(s32, f32, f32, f32, f32, f32, s32, s32*); EffectInstance* fx_damage_indicator(s32, f32, f32, f32, f32, f32, s32, EffectInstance**);
EffectInstance* fx_purple_ring(s32, f32, f32, f32, f32, f32, f32, f32); EffectInstance* fx_purple_ring(s32, f32, f32, f32, f32, f32, f32, f32);
EffectInstance* fx_flame(s32, f32, f32, f32, f32, EffectInstance**); EffectInstance* fx_flame(s32, f32, f32, f32, f32, EffectInstance**);
EffectInstance* fx_stars_burst(s32, f32, f32, f32, f32, f32, s32); EffectInstance* fx_stars_burst(s32, f32, f32, f32, f32, f32, s32);
@ -694,7 +694,7 @@ void fx_3D(s32, f32, f32, f32, f32, f32, f32, s32, s32*);
EffectInstance* fx_blast(s32, f32, f32, f32, f32, s32); EffectInstance* fx_blast(s32, f32, f32, f32, f32, s32);
EffectInstance* fx_fire_flower(s32, f32, f32, f32, s32); EffectInstance* fx_fire_flower(s32, f32, f32, f32, s32);
EffectInstance* fx_recover(s32, f32, f32, f32, s32); EffectInstance* fx_recover(s32, f32, f32, f32, s32);
EffectInstance* fx_disable_x(s32, f32, f32, f32, s32); struct HudElement* fx_disable_x(s32, f32, f32, f32, s32);
EffectInstance* fx_bombette_breaking(s32, s32, s32, f32, s32, s32); EffectInstance* fx_bombette_breaking(s32, s32, s32, f32, s32, s32);
EffectInstance* fx_firework(s32, f32, f32, f32, f32, s32); EffectInstance* fx_firework(s32, f32, f32, f32, f32, s32);
EffectInstance* fx_confetti(s32, f32, f32, f32, f32, s32); EffectInstance* fx_confetti(s32, f32, f32, f32, f32, s32);

View File

@ -507,6 +507,7 @@ enum SoundIDs {
SOUND_MENU_CHANGE_TAB = 0x000000C8, SOUND_MENU_CHANGE_TAB = 0x000000C8,
SOUND_MENU_NEXT = 0x000000C9, SOUND_MENU_NEXT = 0x000000C9,
SOUND_MENU_BACK = 0x000000CA, SOUND_MENU_BACK = 0x000000CA,
SOUND_D4 = 0x000000D4,
SOUND_HIT_PLAYER_NORMAL = 0x000000E1, SOUND_HIT_PLAYER_NORMAL = 0x000000E1,
SOUND_HIT_PLAYER_FIRE = 0x000000E2, SOUND_HIT_PLAYER_FIRE = 0x000000E2,
SOUND_HIT_PLAYER_ICE = 0x000000E3, SOUND_HIT_PLAYER_ICE = 0x000000E3,
@ -542,6 +543,7 @@ enum SoundIDs {
SOUND_METAL_GATE_CLOSE = 0x000001CA, SOUND_METAL_GATE_CLOSE = 0x000001CA,
SOUND_1CB = 0x000001CB, SOUND_1CB = 0x000001CB,
SOUND_1CC = 0x000001CC, SOUND_1CC = 0x000001CC,
SOUND_215 = 0x00000215,
SOUND_MENU_ERROR = 0x0000021D, SOUND_MENU_ERROR = 0x0000021D,
SOUND_231 = 0x00000231, SOUND_231 = 0x00000231,
SOUND_246 = 0x00000246, SOUND_246 = 0x00000246,
@ -597,6 +599,7 @@ enum SoundIDs {
SOUND_MOLE_THROW = 0x000003E8, SOUND_MOLE_THROW = 0x000003E8,
SOUND_3F3 = 0x000003F3, SOUND_3F3 = 0x000003F3,
SOUND_THROW = 0x000003FA, SOUND_THROW = 0x000003FA,
SOUND_749 = 0x00000749,
SOUND_759 = 0x00000759, SOUND_759 = 0x00000759,
SOUND_2003 = 0x00002003, SOUND_2003 = 0x00002003,
SOUND_200D = 0x0000200D, SOUND_200D = 0x0000200D,
@ -2366,6 +2369,7 @@ enum BattleStatusFlags1 {
}; };
enum BattleStatusFlags2 { enum BattleStatusFlags2 {
BS_FLAGS2_1 = 0x00000001,
BS_FLAGS2_2 = 0x00000002, BS_FLAGS2_2 = 0x00000002,
BS_FLAGS2_4 = 0x00000004, BS_FLAGS2_4 = 0x00000004,
BS_FLAGS2_8 = 0x00000008, BS_FLAGS2_8 = 0x00000008,
@ -2390,9 +2394,13 @@ enum BattleStates2 {
BATTLE_STATES2_UNK_5 = 0x00000005, BATTLE_STATES2_UNK_5 = 0x00000005,
BATTLE_STATES2_UNK_6 = 0x00000006, BATTLE_STATES2_UNK_6 = 0x00000006,
BATTLE_STATES2_UNK_7 = 0x00000007, BATTLE_STATES2_UNK_7 = 0x00000007,
BATTLE_STATES2_UNK_8 = 0x00000008,
BATTLE_STATES2_UNK_9 = 0x00000009,
BATTLE_STATES2_PLAYER_DEFEATED = 0x0000000A, BATTLE_STATES2_PLAYER_DEFEATED = 0x0000000A,
BATTLE_STATES2_UNK_B = 0x0000000B, BATTLE_STATES2_UNK_B = 0x0000000B,
BATTLE_STATES2_UNK_C = 0x0000000C, BATTLE_STATES2_UNK_C = 0x0000000C,
BATTLE_STATES2_UNK_F = 0x0000000F,
BATTLE_STATES2_UNK_10 = 0x00000010,
BATTLE_STATES2_UNK_14 = 0x00000014, BATTLE_STATES2_UNK_14 = 0x00000014,
BATTLE_STATES2_UNK_15 = 0x00000015, BATTLE_STATES2_UNK_15 = 0x00000015,
BATTLE_STATES2_UNK_16 = 0x00000016, BATTLE_STATES2_UNK_16 = 0x00000016,

View File

@ -104,6 +104,8 @@ void func_80257DA4(void*);
void func_80254C50(Actor*); void func_80254C50(Actor*);
void func_80258E14(void*); void func_80258E14(void*);
void func_80254610(Actor*);
f32 func_800E34D8(void); f32 func_800E34D8(void);
void func_800E4AD8(s32 arg0); void func_800E4AD8(s32 arg0);
f32 player_check_collision_below(f32, s32* colliderID); f32 player_check_collision_below(f32, s32* colliderID);
@ -207,6 +209,7 @@ Trigger* get_trigger_by_id(s32 triggerID);
Actor* get_actor(s32 actorID); Actor* get_actor(s32 actorID);
ActorPart* get_actor_part(Actor* actor, s32 partIndex); ActorPart* get_actor_part(Actor* actor, s32 partIndex);
s32 add_coins(s32 amt); s32 add_coins(s32 amt);
s32 is_partner_ability_active(s32);
s32 phys_can_player_interact(void); s32 phys_can_player_interact(void);
@ -329,12 +332,13 @@ void btl_state_update_22(void);
void btl_state_draw_22(void); void btl_state_draw_22(void);
void btl_state_update_celebration(void); void btl_state_update_celebration(void);
void btl_draw_upgrade_windows(void); void btl_draw_upgrade_windows(s32);
void btl_state_draw_celebration(void); void btl_state_draw_celebration(void);
void func_8024F7C8(void); void func_8024F7C8(void);
void func_80266978(void); void func_80266978(void);
void func_80266B14(void); void func_80266B14(void);
s32 func_8024E584(void);
void func_8024EE48(void); void func_8024EE48(void);
void func_8024EEA8(void); void func_8024EEA8(void);
void func_80255FD8(void); void func_80255FD8(void);
@ -512,6 +516,8 @@ void func_80138D88(s32, s32, s32, s32, f32);
void func_8013A4D0(void); void func_8013A4D0(void);
void btl_cam_set_target_pos(f32, f32, f32); void btl_cam_set_target_pos(f32, f32, f32);
void btl_cam_unfreeze(void);
void deduct_current_move_fp(void); void deduct_current_move_fp(void);
void load_partner_actor(void); void load_partner_actor(void);
void dispatch_event_partner(s32); void dispatch_event_partner(s32);
@ -643,9 +649,11 @@ void sfx_play_sound_with_params(s32 arg0, u8 arg1, u8 arg2, s16 arg3);
s32 func_8004A784(Npc* npc, f32 arg1, f32* arg2, f32* arg3, f32* arg4, f32* arg5); s32 func_8004A784(Npc* npc, f32 arg1, f32* arg2, f32* arg3, f32* arg4, f32* arg5);
void base_UnkNpcAIFunc1(Evt* script, NpcAISettings* aiSettings, EnemyTerritoryThing* territory); void base_UnkNpcAIFunc1(Evt* script, NpcAISettings* aiSettings, EnemyTerritoryThing* territory);
void UnkNpcAIFunc1(Evt* script, NpcAISettings* aiSettings, EnemyTerritoryThing* territory); void UnkNpcAIFunc1(Evt* script, NpcAISettings* aiSettings, EnemyTerritoryThing* territory);
void func_80266AF8(Actor*);
s32 func_80263230(Actor*, Actor*);
void func_80266EA8(ActorPart*, s32); void func_80266EA8(ActorPart*, s32);
void func_80266E40(Actor*); void func_80266E40(Actor*);
void func_80267018(Actor* actor, s32 arg1);
void remove_player_buffs(s32); void remove_player_buffs(s32);
s32 is_actor_hp_bar_visible(Actor*); s32 is_actor_hp_bar_visible(Actor*);
@ -710,15 +718,22 @@ void btl_cam_target_actor(s32);
void btl_cam_set_zoom(s16); void btl_cam_set_zoom(s16);
void btl_cam_move(s16); void btl_cam_move(s16);
void func_8024E60C(void); void func_8024E60C(void);
void dispatch_event_actor(Actor*, s32); void dispatch_event_actor(Actor*, s32);
s32 dispatch_damage_event_actor_1(Actor* actor, s32 damageAmount, s32 event);
void btl_show_variable_battle_message(s32, s32, s32); void btl_show_variable_battle_message(s32, s32, s32);
s32 btl_is_popup_displayed(void); s32 btl_is_popup_displayed(void);
void func_8024E3D8(s32); void func_8024E3D8(s32);
s32 inflict_status(Actor*, s32, s32); s32 inflict_status(Actor*, s32, s32);
s32 try_inflict_status(Actor*, s32, s32); s32 try_inflict_status(Actor*, s32, s32);
s32 inflict_status_set_duration(Actor* actor, s32 statusTypeKey, s32 statusDurationKey, s32 duration);
void mdl_set_all_fog_mode(s32); void mdl_set_all_fog_mode(s32);
void load_model_animator_tree(s32, StaticAnimatorNode**); void load_model_animator_tree(s32, StaticAnimatorNode**);
s32 inflict_partner_ko(Actor* target, s32 statusTypeKey, s32 duration);
s32 get_defense(Actor* actor, s32* defenseTable, s32 elementFlags);
void func_8024EDC0(void); void func_8024EDC0(void);
void update_effects(void); void update_effects(void);
@ -754,9 +769,14 @@ void func_8024EFE0(f32 x, f32 y, f32 z, s32, s32, s32);
void func_802664DC(f32 x, f32 y, f32 z, s32 attack, s32 a); void func_802664DC(f32 x, f32 y, f32 z, s32 attack, s32 a);
s32 dispatch_damage_event_partner(s32 damageAmount, s32 event, s32 stopMotion); s32 dispatch_damage_event_partner(s32 damageAmount, s32 event, s32 stopMotion);
s32 calc_partner_test_enemy(void); s32 calc_partner_test_enemy(void);
void disable_actor_blur(Actor*);
void reset_actor_blur(Actor*); void reset_actor_blur(Actor*);
void enable_actor_blur(Actor*);
void func_80251474(Actor*);
s32 func_8025C8A0(s32, ActorPart*); s32 func_8025C8A0(s32, ActorPart*);
void func_8025CD28(s32, ActorPart*); void func_8025CD28(s32, ActorPart*);
void func_8025CEC8(ActorPart*);
void _remove_part_decoration(ActorPart* part, s32 decorationIndex);
void func_8025D158(ActorPart*, s32); void func_8025D158(ActorPart*, s32);
void func_8025D290(ActorPart*, s32); void func_8025D290(ActorPart*, s32);
void func_8025D3C4(ActorPart*, s32); void func_8025D3C4(ActorPart*, s32);
@ -799,8 +819,13 @@ void update_encounters_conversation(void);
void update_encounters_post_battle(void); void update_encounters_post_battle(void);
void reset_background_settings(void); void reset_background_settings(void);
void func_80138188(void); void func_80138188(void);
void func_80266970(Actor*);
void func_80266ADC(Actor*);
void func_80266AF8(Actor*);
void func_80266E14(ActorPart*);
void func_80268770(s32, s32, s32); void func_80268770(s32, s32, s32);
void func_80268C9C(void); void func_80268C9C(void);
s32 check_block_input(s32 buttonMask);
void func_802B6CF0_E2B3A0(void); void func_802B6CF0_E2B3A0(void);
void func_80269160(void); void func_80269160(void);
void func_800E24F8(void); void func_800E24F8(void);
@ -820,6 +845,7 @@ void draw_encounters_neutral(void);
void show_first_strike_message(void); void show_first_strike_message(void);
void entity_upgrade_block_hide_content(s32); void entity_upgrade_block_hide_content(s32);
s32 lookup_defense(s32*, s32); s32 lookup_defense(s32*, s32);
s32 lookup_status_chance(s32*, s32);
void peach_check_for_parasol_input(void); void peach_check_for_parasol_input(void);
void peach_sync_disguise_npc(void); void peach_sync_disguise_npc(void);
s32 check_conversation_trigger(void); s32 check_conversation_trigger(void);

View File

@ -150,9 +150,9 @@ extern s32 D_800A0964;
extern s8 D_800A0B94; extern s8 D_800A0B94;
extern s16 D_800A0BB8; extern s16 D_800A0BB8;
extern SpriteShadingProfile* D_801512B0;
extern SpriteShadingProfile* D_80151328; extern SpriteShadingProfile* D_80151328;
extern Window gWindows[64]; extern Window gWindows[64];
extern s32 D_802A3838; extern s32 D_802A3838;

View File

@ -38,9 +38,6 @@ if [[ "$uname" == "Darwin" ]]; then
echo "Installing extra" echo "Installing extra"
python3 -m pip install -U -r requirements_extra.txt || exit 1 python3 -m pip install -U -r requirements_extra.txt || exit 1
fi fi
echo "Done"
exit
fi fi
# Debian and derivatives (apt) # Debian and derivatives (apt)
@ -59,8 +56,6 @@ if cat /etc/os-release | grep -E 'ID=debian|ID_LIKE=(.*)debian' &> /dev/null; th
${SUDO} apt install -y clang-tidy astyle doxygen || exit 1 ${SUDO} apt install -y clang-tidy astyle doxygen || exit 1
python3 -m pip install -U -r requirements_extra.txt || exit 1 python3 -m pip install -U -r requirements_extra.txt || exit 1
fi fi
echo "Done"
fi fi
# Arch Linux and derivatives (pacman) # Arch Linux and derivatives (pacman)
@ -101,8 +96,6 @@ if cat /etc/os-release | grep -E 'ID=arch|ID_LIKE=arch' &> /dev/null; then
${SUDO} pacman -S --noconfirm --needed clang astyle doxygen || exit 1 ${SUDO} pacman -S --noconfirm --needed clang astyle doxygen || exit 1
python3 -m pip install -U -r requirements_extra.txt || exit 1 python3 -m pip install -U -r requirements_extra.txt || exit 1
fi fi
echo "Done"
fi fi
# openSUSE (zypper) # openSUSE (zypper)
@ -137,8 +130,6 @@ if cat /etc/os-release | grep ID=opensuse &> /dev/null; then
${SUDO} zypper -n install clang astyle doxygen || exit 1 ${SUDO} zypper -n install clang astyle doxygen || exit 1
python3 -m pip install -U -r requirements_extra.txt || exit 1 python3 -m pip install -U -r requirements_extra.txt || exit 1
fi fi
echo "Done"
fi fi
# Alpine Linux (apk) # Alpine Linux (apk)
@ -194,12 +185,10 @@ if cat /etc/os-release | grep ID=alpine &> /dev/null; then
${SUDO} apk add --no-cache clang-extra-tools astyle doxygen || exit 1 ${SUDO} apk add --no-cache clang-extra-tools astyle doxygen || exit 1
python3 -m pip install -U -r requirements_extra.txt || exit 1 python3 -m pip install -U -r requirements_extra.txt || exit 1
fi fi
echo "Done"
fi fi
if [ "$supported" = false ]; then if [ "$supported" != true ]; then
echo "The following distros (and their derivatives) are supported by install.sh:" echo "The following distros (and their derivatives) are supported by install.sh:"
echo "- Debian/Ubuntu (apt)" echo "- Debian/Ubuntu (apt)"
echo "- Arch Linux (pacman)" echo "- Arch Linux (pacman)"

View File

@ -5,7 +5,7 @@
s32 calc_item_check_hit(void) { s32 calc_item_check_hit(void) {
BattleStatus* battleStatus = &gBattleStatus; BattleStatus* battleStatus = &gBattleStatus;
ActorMovement* walk = &battleStatus->playerActor->state; ActorState* state = &battleStatus->playerActor->state;
s32 actorID = battleStatus->currentTargetID; s32 actorID = battleStatus->currentTargetID;
s8 currentTargetPartS8; s8 currentTargetPartS8;
u32 currentTargetPart; u32 currentTargetPart;
@ -26,11 +26,11 @@ s32 calc_item_check_hit(void) {
return HIT_RESULT_MISS; return HIT_RESULT_MISS;
} }
if (actor->stoneStatus == 0xC) { if (actor->stoneStatus == 0xC) {
sfx_play_sound_at_position(0x10C, 0, walk->goalPos.x, walk->goalPos.y, walk->goalPos.z); sfx_play_sound_at_position(0x10C, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
return HIT_RESULT_IMMUNE; return HIT_RESULT_IMMUNE;
} }
if ((battleStatus->currentAttackElement & DAMAGE_TYPE_JUMP) && (actorPart->eventFlags & ACTOR_EVENT_FLAG_SPIKY_TOP)) { if ((battleStatus->currentAttackElement & DAMAGE_TYPE_JUMP) && (actorPart->eventFlags & ACTOR_EVENT_FLAG_SPIKY_TOP)) {
sfx_play_sound_at_position(0xE9, 0, walk->goalPos.x, walk->goalPos.y, walk->goalPos.z); sfx_play_sound_at_position(0xE9, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
return HIT_RESULT_LANDED_ON_SPIKE; return HIT_RESULT_LANDED_ON_SPIKE;
} }
} else { } else {
@ -40,146 +40,158 @@ s32 calc_item_check_hit(void) {
return HIT_RESULT_HIT; return HIT_RESULT_HIT;
} }
// Almost matching besides the parts that are marked as "TODO"
#ifdef NON_MATCHING
s32 calc_item_damage_enemy(void) { s32 calc_item_damage_enemy(void) {
BattleStatus* battleStatus = &gBattleStatus; BattleStatus* battleStatus = &gBattleStatus;
Actor* playerActor = battleStatus->playerActor; Actor* player = battleStatus->playerActor;
s32 currentTargetID = battleStatus->currentTargetID; s32 currentTargetID = battleStatus->currentTargetID;
Actor* partnerActor = battleStatus->partnerActor; Actor* partner = battleStatus->partnerActor;
s32 currentTargetPartID = battleStatus->currentTargetPart; s32 currentTargetPartID = battleStatus->currentTargetPart;
Actor* targetActor; s32 sp18;
ActorPart* targetActorPart; s32 sp1C = FALSE;
ActorState* actorState; s32 actorClass;
Evt* attackScript; s32 isFireDamage = FALSE;
s32 sp1C = 0; s32 isElectricDamage = FALSE;
s32 isFireDamage = 0; s32 isIceDamage = FALSE;
s32 isElectricDamage = 0; Actor* target;
s32 isIceDamage = 0; ActorPart* targetPart;
s8 wasStatusInflicted = FALSE; Evt* script;
s32 currentHP;
s32 baseStatusChance;
s32 attackDamage; s32 attackDamage;
s32 targetActorDefense; s32 temp;
s32 targetDefense;
ActorState* state;
s32 dispatchEvent; s32 dispatchEvent;
u32 sp18; s32 wasStatusInflicted;
s32 phi_a0_2; s32 ret;
s32 phi_fp;
battleStatus->wasStatusInflicted = FALSE; battleStatus->wasStatusInflicted = FALSE;
battleStatus->lastAttackDamage = 0; battleStatus->lastAttackDamage = 0;
battleStatus->attackerActorID = playerActor->actorID; battleStatus->attackerActorID = player->actorID;
battleStatus->currentTargetID2 = battleStatus->currentTargetID; battleStatus->currentTargetID2 = battleStatus->currentTargetID;
battleStatus->currentTargetPart2 = battleStatus->currentTargetPart; battleStatus->currentTargetPart2 = battleStatus->currentTargetPart;
target = get_actor(currentTargetID);
targetActor = get_actor(currentTargetID); wasStatusInflicted = FALSE;
if (targetActor == NULL) {
if (target == NULL) {
return 0; return 0;
} }
targetActorPart = get_actor_part(targetActor, currentTargetPartID); targetPart = get_actor_part(target, currentTargetPartID);
currentTargetID &= ACTOR_CLASS_MASK; if (targetPart == NULL) {
if (targetActorPart == NULL) {
PANIC(); PANIC();
}
targetActor->lastDamageTaken = 0;
if (gBattleStatus.flags1 & BS_FLAGS1_80000) {
actorState = &playerActor->state;
} else {
actorState = &partnerActor->state;
} }
phi_a0_2 = 0;
target->lastDamageTaken = 0;
actorClass = currentTargetID & ACTOR_CLASS_MASK;
if (!(gBattleStatus.flags1 & BS_FLAGS1_80000)) {
state = &player->state;
} else {
state = &partner->state;
}
if (battleStatus->currentAttackElement & DAMAGE_TYPE_FIRE) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_FIRE) {
fx_ring_blast(0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z + 5.0f, 1.0f, 0x18); fx_ring_blast(0, state->goalPos.x, state->goalPos.y, state->goalPos.z + 5.0f, 1.0f, 0x18);
isFireDamage = TRUE; isFireDamage = TRUE;
} }
if (battleStatus->currentAttackElement & DAMAGE_TYPE_ELECTRIC) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_ELECTRIC) {
func_80251474(targetActor); func_80251474(target);
isElectricDamage = TRUE; isElectricDamage = TRUE;
} }
if (battleStatus->currentAttackElement & DAMAGE_TYPE_WATER) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_WATER) {
fx_water_splash(0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z + 5.0f, 1.0f, 0x18); fx_water_splash(0, state->goalPos.x, state->goalPos.y, state->goalPos.z + 5.0f, 1.0f, 0x18);
} }
if (battleStatus->currentAttackElement & DAMAGE_TYPE_ICE) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_ICE) {
fx_big_snowflakes(0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z + 5.0f); fx_big_snowflakes(0, state->goalPos.x, state->goalPos.y, state->goalPos.z + 5.0f);
isIceDamage = TRUE; isIceDamage = TRUE;
} }
if ((battleStatus->currentAttackElement & DAMAGE_TYPE_REMOVE_BUFFS) == 0) {
if (targetActorPart->eventFlags & ACTOR_EVENT_FLAG_ILLUSORY) { if (!(battleStatus->currentAttackElement & DAMAGE_TYPE_REMOVE_BUFFS)) {
return 6; if ((targetPart->eventFlags & ACTOR_EVENT_FLAG_ILLUSORY) ||
} ((target->transStatus == STATUS_E) || ((targetPart->eventFlags & ACTOR_EVENT_FLAG_800) && !(battleStatus->currentAttackElement & DAMAGE_TYPE_QUAKE))))
if (targetActor->transStatus == STATUS_E || targetActorPart->eventFlags & ACTOR_EVENT_FLAG_800 && !(battleStatus->currentAttackElement & DAMAGE_TYPE_QUAKE)) { {
return 6; return 6;
} }
} }
if (targetActor->stoneStatus == STATUS_STONE) {
sfx_play_sound_at_position(SOUND_IMMUNE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); if (target->stoneStatus == STATUS_STONE) {
func_8024EFE0(actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, 0, 1, 1); sfx_play_sound_at_position(SOUND_IMMUNE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
show_damage_popup(actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, 0, 0); func_8024EFE0(state->goalPos.x, state->goalPos.y, state->goalPos.z, 0, 1, 1);
show_damage_popup(state->goalPos.x, state->goalPos.y, state->goalPos.z, 0, 0);
if (gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200)) { if (gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200)) {
return 1; return 1;
} else { } else {
return 0; return 0;
} }
} }
sp18 = (targetActorPart->partFlags3 & battleStatus->currentAttackElement) != 0; // TODO 3a8
if (targetActorPart->eventFlags & (ACTOR_EVENT_FLAG_ENCHANTED | ACTOR_EVENT_FLAG_80000)) { if (targetPart->partFlags3 & battleStatus->currentAttackElement) {
sp18 = TRUE;
} else {
sp18 = FALSE;
}
if (targetPart->eventFlags & (ACTOR_EVENT_FLAG_ENCHANTED | ACTOR_EVENT_FLAG_80000)) {
battleStatus->currentAttackElement &= ~DAMAGE_TYPE_IGNORE_DEFENSE; battleStatus->currentAttackElement &= ~DAMAGE_TYPE_IGNORE_DEFENSE;
} }
targetActorDefense = get_defense(targetActor, targetActorPart->defenseTable, battleStatus->currentAttackElement);
temp = get_defense(target, targetPart->defenseTable, battleStatus->currentAttackElement);
if (!(battleStatus->currentAttackElement & DAMAGE_TYPE_IGNORE_DEFENSE)) { if (!(battleStatus->currentAttackElement & DAMAGE_TYPE_IGNORE_DEFENSE)) {
targetActorDefense += targetActor->defenseBoost; temp += target->defenseBoost;
} }
attackDamage = battleStatus->currentAttackDamage; attackDamage = battleStatus->currentAttackDamage;
if (attackDamage > 99) { if (attackDamage > 99) {
attackDamage = 99; attackDamage = 99;
} }
if (attackDamage <= 0) { if (attackDamage <= 0) {
targetActorDefense = 0; temp = 0;
} }
attackDamage -= targetActorDefense;
targetActor->hpChangeCounter = 0; attackDamage -= temp;
if (attackDamage <= 0) { // TODO 434 target->hpChangeCounter = 0;
targetActor->hpChangeCounter = 0;
if (attackDamage <= 0) {
target->hpChangeCounter = 0;
ret = 2;
if (!(battleStatus->currentAttackElement & DAMAGE_TYPE_STATUS_ALWAYS_HITS)) { if (!(battleStatus->currentAttackElement & DAMAGE_TYPE_STATUS_ALWAYS_HITS)) {
phi_fp = 2;
dispatchEvent = EVENT_UNKNOWN_TRIGGER; dispatchEvent = EVENT_UNKNOWN_TRIGGER;
sfx_play_sound_at_position(SOUND_IMMUNE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_IMMUNE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} else {
battleStatus->lastAttackDamage = 0; battleStatus->lastAttackDamage = 0;
} else {
dispatchEvent = EVENT_UNKNOWN_TRIGGER; dispatchEvent = EVENT_UNKNOWN_TRIGGER;
battleStatus->lastAttackDamage = 0;
} }
} else { } else {
targetActor->damageCounter += attackDamage; target->damageCounter += attackDamage;
targetActor->hpChangeCounter -= attackDamage; target->hpChangeCounter -= attackDamage;
battleStatus->lastAttackDamage = 0; battleStatus->lastAttackDamage = 0;
dispatchEvent = EVENT_HIT_COMBO; dispatchEvent = EVENT_HIT_COMBO;
phi_fp = 0; ret = 0;
if (!(targetActorPart->flags & ACTOR_PART_FLAG_2000) && sp18 == 0 && !(targetActorPart->targetFlags & ACTOR_PART_FLAG_4)) { if (!(targetPart->flags & ACTOR_PART_FLAG_2000) && !sp18 && !(targetPart->targetFlags & ACTOR_PART_FLAG_4)) {
targetActor->currentHP -= attackDamage; target->currentHP -= attackDamage;
if (targetActor->currentHP <= 0) { if (target->currentHP <= 0) {
targetActor->currentHP = 0; target->currentHP = 0;
dispatchEvent = EVENT_DEATH; dispatchEvent = EVENT_DEATH;
} }
} }
battleStatus->lastAttackDamage += attackDamage; battleStatus->lastAttackDamage += attackDamage;
targetActor->lastDamageTaken = battleStatus->lastAttackDamage; target->lastDamageTaken = battleStatus->lastAttackDamage;
targetActor->hpChangeCounter = 0; target->hpChangeCounter = 0;
} }
if (targetActorPart->flags & ACTOR_PART_FLAG_2000) {
dispatch_event_actor(targetActor, dispatchEvent); if (targetPart->flags & ACTOR_PART_FLAG_2000) {
func_8024EFE0(actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, 0, 1, 3); dispatch_event_actor(target, dispatchEvent);
sfx_play_sound_at_position(SOUND_IMMUNE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); func_8024EFE0(state->goalPos.x, state->goalPos.y, state->goalPos.z, 0, 1, 3);
sfx_play_sound_at_position(SOUND_IMMUNE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
return 2; return 2;
} }
if (battleStatus->currentAttackElement & DAMAGE_TYPE_2000) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_2000) {
battleStatus->lastAttackDamage = 0; battleStatus->lastAttackDamage = 0;
dispatchEvent = EVENT_DEATH; dispatchEvent = EVENT_DEATH;
phi_fp = 0; ret = 0;
} }
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) { if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (dispatchEvent == EVENT_HIT_COMBO) { if (dispatchEvent == EVENT_HIT_COMBO) {
dispatchEvent = EVENT_HIT; dispatchEvent = EVENT_HIT;
@ -187,302 +199,330 @@ s32 calc_item_damage_enemy(void) {
if (dispatchEvent == EVENT_UNKNOWN_TRIGGER) { if (dispatchEvent == EVENT_UNKNOWN_TRIGGER) {
dispatchEvent = EVENT_IMMUNE; dispatchEvent = EVENT_IMMUNE;
} }
if (target->currentHP <= 0 && dispatchEvent == EVENT_IMMUNE) {
if (targetActor->currentHP <= 0) { dispatchEvent = EVENT_DEATH;
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_DEATH;
}
} }
} else if (dispatchEvent == EVENT_DEATH) { } else if (dispatchEvent == EVENT_DEATH) {
dispatchEvent = EVENT_HIT_COMBO; dispatchEvent = EVENT_HIT_COMBO;
} }
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) { if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (!(battleStatus->currentAttackElement & DAMAGE_TYPE_REMOVE_BUFFS)) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_REMOVE_BUFFS) {
goto block_80; dispatchEvent = EVENT_IMMUNE;
if (targetPart->eventFlags & ACTOR_EVENT_FLAG_ENCHANTED) {
dispatchEvent = EVENT_STAR_BEAM;
wasStatusInflicted = TRUE;
}
if (targetPart->eventFlags & ACTOR_EVENT_FLAG_400000) {
dispatchEvent = EVENT_STAR_BEAM;
wasStatusInflicted = TRUE;
}
if (targetPart->eventFlags & ACTOR_EVENT_FLAG_80000) {
dispatchEvent = EVENT_1D;
}
ret = 0;
} }
dispatchEvent = EVENT_IMMUNE;
if (targetActorPart->eventFlags & ACTOR_EVENT_FLAG_ENCHANTED) {
dispatchEvent = EVENT_STAR_BEAM;
wasStatusInflicted = TRUE;
}
if (targetActorPart->eventFlags & ACTOR_EVENT_FLAG_400000) {
dispatchEvent = EVENT_STAR_BEAM;
wasStatusInflicted = TRUE;
}
if (targetActorPart->eventFlags & ACTOR_EVENT_FLAG_80000) {
dispatchEvent = EVENT_1D;
}
phi_fp = 0;
} }
if (battleStatus->currentAttackElement & DAMAGE_TYPE_REMOVE_BUFFS
&& gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE if (battleStatus->currentAttackElement & DAMAGE_TYPE_REMOVE_BUFFS) {
&& targetActor->attackBoost <= 0 if (gBattleStatus.flags1 & 0x20) {
&& targetActor->defenseBoost <= 0 if ((target->attackBoost > 0 || target->defenseBoost > 0) ||
&& targetActor->staticStatus == STATUS_END ((target->staticStatus == 0 && target->transStatus != 0) || target->staticStatus != 0))
&& targetActor->transStatus == STATUS_END) { {
targetActor->attackBoost = 0; target->attackBoost = 0;
targetActor->defenseBoost = 0; target->defenseBoost = 0;
targetActor->isGlowing = FALSE; target->isGlowing = FALSE;
dispatchEvent = EVENT_HIT; // TODO 660 dispatchEvent = EVENT_HIT;
if (targetActor->staticStatus != STATUS_END) { if (target->staticStatus != 0) {
targetActor->staticStatus = STATUS_END; target->staticStatus = 0;
targetActor->staticDuration = 0; target->staticDuration = 0;
remove_status_static(targetActor->hudElementDataIndex); remove_status_static(target->hudElementDataIndex);
}
if (target->transStatus != 0) {
target->transStatus = 0;
target->transDuration = 0;
remove_status_transparent(target->hudElementDataIndex);
}
wasStatusInflicted = TRUE;
ret = 0;
}
} }
if (targetActor->transStatus != STATUS_END) { }
targetActor->transStatus = STATUS_END;
targetActor->transDuration = 0;
remove_status_transparent(targetActor->hudElementDataIndex);
}
wasStatusInflicted = TRUE;
phi_fp = 0;
}
block_80:
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) { if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & DAMAGE_TYPE_PEACH_BEAM) { if (battleStatus->currentAttackElement & DAMAGE_TYPE_PEACH_BEAM) {
dispatchEvent = EVENT_IMMUNE; dispatchEvent = EVENT_IMMUNE;
if (targetActorPart->eventFlags & ACTOR_EVENT_FLAG_ENCHANTED) { if (targetPart->eventFlags & ACTOR_EVENT_FLAG_ENCHANTED) {
dispatchEvent = EVENT_14; dispatchEvent = EVENT_14;
wasStatusInflicted = TRUE; wasStatusInflicted = TRUE;
} }
if (targetActorPart->eventFlags & ACTOR_EVENT_FLAG_80000) { if (targetPart->eventFlags & ACTOR_EVENT_FLAG_80000) {
dispatchEvent = EVENT_14; dispatchEvent = EVENT_14;
wasStatusInflicted = TRUE; wasStatusInflicted = TRUE;
} }
} }
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & DAMAGE_TYPE_SPIN_SMASH) {
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_SPIN_SMASH_HIT;
}
if (dispatchEvent == EVENT_DEATH) {
dispatchEvent = EVENT_SPIN_SMASH_DEATH;
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & (DAMAGE_TYPE_JUMP | DAMAGE_TYPE_POW) && targetActorPart->eventFlags & ACTOR_EVENT_FLAG_GROUNDABLE) {
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & DAMAGE_TYPE_POW && targetActorPart->eventFlags & ACTOR_EVENT_FLAG_800000) {
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & (DAMAGE_TYPE_JUMP | DAMAGE_TYPE_POW | DAMAGE_TYPE_QUAKE) && targetActorPart->eventFlags & ACTOR_EVENT_FLAG_FLIPABLE) {
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_FLIP_TRIGGER;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_FLIP_TRIGGER;
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & DAMAGE_TYPE_FIRE) {
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_BURN_HIT;
}
if (dispatchEvent == EVENT_DEATH) {
dispatchEvent = EVENT_BURN_DEATH;
}
isFireDamage = 1;
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE
&& battleStatus->lastAttackDamage >= 0
&& dispatchEvent != EVENT_DEATH
&& dispatchEvent != EVENT_SPIN_SMASH_DEATH
&& dispatchEvent != EVENT_EXPLODE_TRIGGER) {
if (battleStatus->currentAttackStatus & STATUS_FLAG_SHRINK && try_inflict_status(targetActor, STATUS_SHRINK, STATUS_SHRINK_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_POISON && try_inflict_status(targetActor, STATUS_POISON, STATUS_POISON_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_STONE && try_inflict_status(targetActor, STATUS_STONE, STATUS_STONE_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_SLEEP && try_inflict_status(targetActor, STATUS_SLEEP, STATUS_SLEEP_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_STOP && try_inflict_status(targetActor, STATUS_STOP, STATUS_STOP_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_STATIC && try_inflict_status(targetActor, STATUS_STATIC, STATUS_STATIC_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_FEAR && try_inflict_status(targetActor, STATUS_FEAR, STATUS_FEAR_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_PARALYZE && try_inflict_status(targetActor, STATUS_PARALYZE, STATUS_PARALYZE_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (battleStatus->currentAttackStatus & STATUS_FLAG_DIZZY && try_inflict_status(targetActor, STATUS_DIZZY, STATUS_DIZZY_TURN_MOD)) {
wasStatusInflicted = TRUE;
}
if (wasStatusInflicted != FALSE) {
if (dispatchEvent == EVENT_UNKNOWN_TRIGGER) {
dispatchEvent = EVENT_HIT_COMBO;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_HIT;
}
}
}
}
}
}
}
}
}
baseStatusChance = (battleStatus->statusChance * targetActor->actorBlueprint->baseStatusChance) / 100; // TODO a70
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE && battleStatus->currentAttackElement & DAMAGE_TYPE_FEAR) {
//dispatchEvent = EVENT_IMMUNE;
if (rand_int(99) < baseStatusChance) {
dispatchEvent = EVENT_IMMUNE;
phi_fp = 2;
if (targetActor->debuff - 3 >= 6) {
phi_fp = 2;
if (!(targetActor->flags & ACTOR_FLAG_400)) {
sp1C = 1;
gBattleStatus.flags1 |= (BS_FLAGS1_1 | BS_FLAGS1_8 | BS_FLAGS1_10 | BS_FLAGS1_SP_EVT_ACTIVE | BS_FLAGS1_40);
sfx_play_sound_at_position(SOUND_UNKNOWN_231, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z);
wasStatusInflicted = TRUE;
dispatchEvent = EVENT_SCARE_AWAY;
phi_fp = 0;
}
}
} else {
phi_fp = 2;
}
}
battleStatus->wasStatusInflicted = wasStatusInflicted; // TODO b8c
if (sp1C != 0 && (gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200) || gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200) && gBattleStatus.flags1 & BS_FLAGS1_80 && battleStatus->lastAttackDamage > 0) && (sfx_play_sound_at_position(0x231, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z), battleStatus->lastAttackDamage > 0) || battleStatus->currentAttackElement & DAMAGE_TYPE_STATUS_ALWAYS_HITS && sp1C != 0) {
if (!(gBattleStatus.flags1 & BS_FLAGS1_40)) {
phi_a0_2 = 3;
}
func_802667F0(phi_a0_2, targetActor, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z);
} }
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) { if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
func_80266970(targetActor); if (battleStatus->currentAttackElement & DAMAGE_TYPE_SPIN_SMASH) {
} if (dispatchEvent == EVENT_HIT) {
dispatch_event_actor(targetActor, dispatchEvent); dispatchEvent = EVENT_SPIN_SMASH_HIT;
if (currentTargetID == 0x100) { }
if (battleStatus->lastAttackDamage > 0 && gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) { if (dispatchEvent == EVENT_DEATH) {
inflict_status(targetActor, 13, battleStatus->lastAttackDamage); dispatchEvent = EVENT_SPIN_SMASH_DEATH;
}
} }
} }
if (!(targetActor->flags & ACTOR_FLAG_NO_DMG_POPUP)) {
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if ((battleStatus->currentAttackElement & (DAMAGE_TYPE_JUMP | DAMAGE_TYPE_POW)) &&
(targetPart->eventFlags & ACTOR_EVENT_FLAG_GROUNDABLE))
{
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if ((battleStatus->currentAttackElement & DAMAGE_TYPE_POW) &&
(targetPart->eventFlags & ACTOR_EVENT_FLAG_800000))
{
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_FALL_TRIGGER;
}
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if ((battleStatus->currentAttackElement & (DAMAGE_TYPE_JUMP | DAMAGE_TYPE_POW | DAMAGE_TYPE_QUAKE)) &&
(targetPart->eventFlags & ACTOR_EVENT_FLAG_FLIPABLE))
{
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_FLIP_TRIGGER;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_FLIP_TRIGGER;
}
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
if (battleStatus->currentAttackElement & DAMAGE_TYPE_FIRE) {
if (dispatchEvent == EVENT_HIT) {
dispatchEvent = EVENT_BURN_HIT;
}
if (dispatchEvent == EVENT_DEATH) {
dispatchEvent = EVENT_BURN_DEATH;
}
isFireDamage = TRUE;
}
}
if ((gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) &&
battleStatus->lastAttackDamage >= 0 &&
dispatchEvent != EVENT_DEATH &&
dispatchEvent != EVENT_SPIN_SMASH_DEATH &&
dispatchEvent != EVENT_EXPLODE_TRIGGER)
{
// Using this macro because it's nicer to look at, and it also is necessary to wrap the first 5 of these in a
// do-while-0 OR to wrap each one individually. It's more likely that it's a macro instead, and much cleaner
#define INFLICT_STATUS(STATUS_TYPE) \
do { \
if ((battleStatus->currentAttackStatus & STATUS_FLAG_##STATUS_TYPE) && \
try_inflict_status(target, STATUS_##STATUS_TYPE, STATUS_##STATUS_TYPE##_TURN_MOD)) { \
wasStatusInflicted = TRUE; \
} \
} while (0);
INFLICT_STATUS(SHRINK);
INFLICT_STATUS(POISON);
INFLICT_STATUS(STONE);
INFLICT_STATUS(SLEEP);
INFLICT_STATUS(STOP);
INFLICT_STATUS(STATIC);
INFLICT_STATUS(FEAR);
INFLICT_STATUS(PARALYZE);
INFLICT_STATUS(DIZZY);
#undef INFLICT_STATUS
if (wasStatusInflicted) {
if (dispatchEvent == EVENT_UNKNOWN_TRIGGER) {
dispatchEvent = EVENT_HIT_COMBO;
}
if (dispatchEvent == EVENT_IMMUNE) {
dispatchEvent = EVENT_HIT;
}
}
}
temp = target->actorBlueprint->baseStatusChance;
temp = (battleStatus->statusChance * temp) / 100;
if ((gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) && (battleStatus->currentAttackElement & DAMAGE_TYPE_FEAR)) {
if (rand_int(99) < temp &&
!(target->debuff == STATUS_FEAR ||
target->debuff == STATUS_DIZZY ||
target->debuff == STATUS_PARALYZE ||
target->debuff == STATUS_SLEEP ||
target->debuff == STATUS_FROZEN ||
target->debuff == STATUS_STOP) &&
!(target->flags & ACTOR_FLAG_400))
{
dispatchEvent = EVENT_SCARE_AWAY;
ret = 0;
sp1C = TRUE;
gBattleStatus.flags1 |= 0x39;
sfx_play_sound_at_position(SOUND_231, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
wasStatusInflicted = TRUE;
gBattleStatus.flags1 |= 0x40;
} else {
dispatchEvent = EVENT_IMMUNE;
ret = 2;
}
}
battleStatus->wasStatusInflicted = wasStatusInflicted;
if (
(sp1C && (gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200))) ||
((gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200)) && !(gBattleStatus.flags1 & BS_FLAGS1_80))
) {
if (battleStatus->lastAttackDamage > 0) {
sfx_play_sound_at_position(SOUND_231, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
}
if (battleStatus->lastAttackDamage > 0 || (battleStatus->currentAttackElement & DAMAGE_TYPE_STATUS_ALWAYS_HITS) && sp1C) {
if (gBattleStatus.flags1 & BS_FLAGS1_40) {
func_802667F0(0, target, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} else {
func_802667F0(3, target, state->goalPos.x, state->goalPos.y, state->goalPos.z);
}
}
}
if (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE) {
func_80266970(target);
}
dispatch_event_actor(target, dispatchEvent);
if (actorClass == ACTOR_PARTNER) {
if ((battleStatus->lastAttackDamage > 0) && (gBattleStatus.flags1 & BS_FLAGS1_SP_EVT_ACTIVE)) {
inflict_status(target, STATUS_DAZE, battleStatus->lastAttackDamage);
}
}
if (!(target->flags & ACTOR_FLAG_NO_DMG_POPUP)) {
if (battleStatus->lastAttackDamage == 0) { if (battleStatus->lastAttackDamage == 0) {
if (sp1C == 0 && !wasStatusInflicted) { if (!sp1C && !wasStatusInflicted) {
func_8024EFE0(actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, 0, 1, 3); func_8024EFE0(state->goalPos.x, state->goalPos.y, state->goalPos.z, 0, 1, 3);
} }
} else if (sp18 == 0) { } else if (!sp18) {
if (battleStatus->currentAttackElement & (DAMAGE_TYPE_SMASH | DAMAGE_TYPE_NO_OTHER_DAMAGE_POPUPS)) { if (battleStatus->currentAttackElement & (DAMAGE_TYPE_SMASH | DAMAGE_TYPE_NO_OTHER_DAMAGE_POPUPS)) {
show_damage_popup(actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, battleStatus->lastAttackDamage, 0); show_damage_popup(state->goalPos.x, state->goalPos.y, state->goalPos.z, battleStatus->lastAttackDamage, 0);
} else { } else {
func_802664DC(actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, battleStatus->lastAttackDamage, 0); func_802664DC(state->goalPos.x, state->goalPos.y, state->goalPos.z, battleStatus->lastAttackDamage, 0);
} }
if (!(targetActorPart->targetFlags & 4)) { if (!(targetPart->targetFlags & 4)) {
func_802666E4(targetActor, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z, battleStatus->lastAttackDamage); func_802666E4(target, state->goalPos.x, state->goalPos.y, state->goalPos.z, battleStatus->lastAttackDamage);
} }
} }
} }
if (battleStatus->lastAttackDamage > 0) {
if (sp18 == 0) { if (battleStatus->lastAttackDamage > 0 && !sp18) {
func_80267018(targetActor, 1); func_80267018(target, 1);
if (isFireDamage) { if (isFireDamage) {
sfx_play_sound_at_position(SOUND_HIT_FIRE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_HIT_FIRE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} else if (isElectricDamage) { } else if (isElectricDamage) {
sfx_play_sound_at_position(SOUND_HIT_SHOCK, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_HIT_SHOCK, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} else if (isIceDamage) { } else if (isIceDamage) {
sfx_play_sound_at_position(SOUND_HIT_ICE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_HIT_ICE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} else { } else {
sfx_play_sound_at_position(SOUND_HIT_NORMAL, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_HIT_NORMAL, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
}
} }
} }
if (battleStatus->lastAttackDamage <= 0 && wasStatusInflicted && targetActorPart->flags & ACTOR_FLAG_2000) {
sfx_play_sound_at_position(SOUND_IMMUNE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); if ((battleStatus->lastAttackDamage <= 0 && !wasStatusInflicted) || (targetPart->flags & ACTOR_FLAG_2000)) {
sfx_play_sound_at_position(SOUND_IMMUNE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_SLEEP && wasStatusInflicted) {
attackScript = start_script(DoSleepHit, 10, 0); if ((battleStatus->currentAttackStatus & STATUS_FLAG_SLEEP) && wasStatusInflicted) {
attackScript->varTable[0] = actorState->goalPos.x; script = start_script(DoSleepHit, 0xA, 0);
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[0] = state->goalPos.x;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[1] = state->goalPos.y;
sfx_play_sound_at_position(SOUND_INFLICT_SLEEP, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); script->varTable[2] = state->goalPos.z;
sfx_play_sound_at_position(SOUND_INFLICT_SLEEP, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_DIZZY && wasStatusInflicted) { if ((battleStatus->currentAttackStatus & STATUS_FLAG_DIZZY) && wasStatusInflicted) {
attackScript = start_script(DoDizzyHit, 10, 0); script = start_script(DoDizzyHit, 0xA, 0);
attackScript->varTable[0] = actorState->goalPos.x; script->varTable[0] = state->goalPos.x;
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[1] = state->goalPos.y;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[2] = state->goalPos.z;
sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_PARALYZE && wasStatusInflicted) { if ((battleStatus->currentAttackStatus & STATUS_FLAG_PARALYZE) && wasStatusInflicted) {
attackScript = start_script(DoParalyzeHit, 10, 0); script = start_script(DoParalyzeHit, 0xA, 0);
attackScript->varTable[0] = actorState->goalPos.x; script->varTable[0] = state->goalPos.x;
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[1] = state->goalPos.y;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[2] = state->goalPos.z;
sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_POISON && wasStatusInflicted) { if ((battleStatus->currentAttackStatus & STATUS_FLAG_POISON) && wasStatusInflicted) {
attackScript = start_script(DoPoisonHit, 10, 0); script = start_script(DoPoisonHit, 0xA, 0);
attackScript->varTable[0] = actorState->goalPos.x; script->varTable[0] = state->goalPos.x;
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[1] = state->goalPos.y;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[2] = state->goalPos.z;
sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_STOP && wasStatusInflicted) { if ((battleStatus->currentAttackStatus & STATUS_FLAG_STOP) && wasStatusInflicted) {
attackScript = start_script(DoStopHit, 10, 0); script = start_script(DoStopHit, 0xA, 0);
attackScript->varTable[0] = actorState->goalPos.x; script->varTable[0] = state->goalPos.x;
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[1] = state->goalPos.y;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[2] = state->goalPos.z;
sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_FROZEN && wasStatusInflicted) { if ((battleStatus->currentAttackStatus & STATUS_FLAG_FROZEN) && wasStatusInflicted) {
attackScript = start_script(DoFreezeHit, 10, 0); script = start_script(DoFreezeHit, 0xA, 0);
attackScript->varTable[0] = actorState->goalPos.x; script->varTable[0] = state->goalPos.x;
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[1] = state->goalPos.y;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[2] = state->goalPos.z;
attackScript->varTable[3] = targetActor; script->varTable[3] = target;
sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackStatus & STATUS_FLAG_SHRINK && wasStatusInflicted) { if ((battleStatus->currentAttackStatus & STATUS_FLAG_SHRINK) && wasStatusInflicted) {
attackScript = start_script(DoShrinkHit, 10, 0); script = start_script(DoShrinkHit, 0xA, 0);
attackScript->varTable[0] = actorState->goalPos.x; script->varTable[0] = state->goalPos.x;
attackScript->varTable[1] = actorState->goalPos.y; script->varTable[1] = state->goalPos.y;
attackScript->varTable[2] = actorState->goalPos.z; script->varTable[2] = state->goalPos.z;
attackScript->varTable[3] = targetActor; script->varTable[3] = target;
sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_INFLICT_STATUS, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
if (battleStatus->currentAttackElement & DAMAGE_TYPE_SMASH && targetActor->actorType == 0x93) { if ((battleStatus->currentAttackElement & DAMAGE_TYPE_SMASH) && (target->actorType == ACTOR_TYPE_GOOMNUT_TREE)) {
sfx_play_sound_at_position(SOUND_SMASH_GOOMNUT_TREE, 0, actorState->goalPos.x, actorState->goalPos.y, actorState->goalPos.z); sfx_play_sound_at_position(SOUND_SMASH_GOOMNUT_TREE, 0, state->goalPos.x, state->goalPos.y, state->goalPos.z);
} }
func_80266ADC(targetActor); func_80266ADC(target);
if (gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200)) { if (gBattleStatus.flags1 & (BS_FLAGS1_40 | BS_FLAGS1_200)) {
if (phi_fp == 0) { if (ret == 0) {
phi_fp = 1; ret = 1;
} }
if (phi_fp == 2) { if (ret == 2) {
phi_fp = 3; ret = 3;
} }
} }
return phi_fp;
return ret;
} }
#else
INCLUDE_ASM(s32, "17FEB0", calc_item_damage_enemy);
#endif
ApiStatus ItemDamageEnemy(Evt* script, s32 isInitialCall) { ApiStatus ItemDamageEnemy(Evt* script, s32 isInitialCall) {
BattleStatus* battleStatus = &gBattleStatus; BattleStatus* battleStatus = &gBattleStatus;

File diff suppressed because it is too large Load Diff

View File

@ -8,9 +8,9 @@
#include "sprite.h" #include "sprite.h"
typedef struct PartnerDMAData { typedef struct PartnerDMAData {
/* 0x00 */ s32 dmaStart; /* 0x00 */ u32 dmaStart;
/* 0x04 */ s32 dmaEnd; /* 0x04 */ u32 dmaEnd;
/* 0x08 */ s32 dmaDest; /* 0x08 */ void* dmaDest;
/* 0x0C */ ActorBlueprint* ActorBlueprint; /* 0x0C */ ActorBlueprint* ActorBlueprint;
/* 0x10 */ s32 y; /* 0x10 */ s32 y;
} PartnerDMAData; // size = 0x14 } PartnerDMAData; // size = 0x14
@ -1197,8 +1197,8 @@ s32 func_80263064(Actor* actor0, Actor* actor1, s32 unused) {
return ret; return ret;
} }
void func_80263230(Actor* arg0, Actor* arg1) { s32 func_80263230(Actor* arg0, Actor* arg1) {
func_80263064(arg0, arg1, 0); return func_80263064(arg0, arg1, 0);
} }
void func_8026324C(Actor* arg0, Actor* arg1) { void func_8026324C(Actor* arg0, Actor* arg1) {
@ -2857,7 +2857,7 @@ s32 inflict_partner_ko(Actor* target, s32 statusTypeKey, s32 duration) {
if (statusTypeKey == STATUS_DAZE) { if (statusTypeKey == STATUS_DAZE) {
if (statusTypeKey != target->koStatus) { if (statusTypeKey != target->koStatus) {
inflict_status(target, STATUS_DAZE, duration); inflict_status(target, STATUS_DAZE, duration);
sfx_play_sound(0x2107); sfx_play_sound(SOUND_2107);
} else { } else {
target->koDuration += duration; target->koDuration += duration;
if (target->koDuration > 9) { if (target->koDuration > 9) {
@ -3127,8 +3127,7 @@ void func_80266B14(void) {
} }
} }
// dumb label // TODO dumb label required to match, clean up
#ifdef NON_MATCHING
s32 try_inflict_status(Actor* actor, s32 statusTypeKey, s32 statusKey) { s32 try_inflict_status(Actor* actor, s32 statusTypeKey, s32 statusKey) {
BattleStatus* battleStatus = &gBattleStatus; BattleStatus* battleStatus = &gBattleStatus;
s32 phi_s0; s32 phi_s0;
@ -3163,7 +3162,6 @@ s32 try_inflict_status(Actor* actor, s32 statusTypeKey, s32 statusKey) {
duration = 3; duration = 3;
} }
// TODO remove this label (required to match)
meow: meow:
if (duration > 0) { if (duration > 0) {
if (battleStatus->currentAttackStatus < 0) { if (battleStatus->currentAttackStatus < 0) {
@ -3179,12 +3177,9 @@ meow:
} }
return duration; return duration;
} }
#else
INCLUDE_ASM(s32, "190B20", try_inflict_status);
#endif
s32 inflict_status_set_duration(Actor* actor, s32 statusTypeKey, s32 statusDurationKey, s32 duration) { s32 inflict_status_set_duration(Actor* actor, s32 statusTypeKey, s32 statusDurationKey, s32 duration) {
s32 var0 = duration; s32 var0 = duration; // TODO required to match, look into
s32 statusDuration = 0; s32 statusDuration = 0;
if (actor->statusTable == NULL || lookup_status_chance(actor->statusTable, statusTypeKey) > 0) { if (actor->statusTable == NULL || lookup_status_chance(actor->statusTable, statusTypeKey) > 0) {
@ -3690,7 +3685,7 @@ void start_rumble_type(u32 arg0) {
case 9: case 9:
case 10: case 10:
case 11: case 11:
D_802939C0 = start_script(D_80293AC4, 0xA, 0x20)->id; D_802939C0 = start_script(&D_80293AC4, 0xA, 0x20)->id;
break; break;
} }
} }

View File

@ -3,13 +3,10 @@
#include "script_api/battle.h" #include "script_api/battle.h"
#include "effects.h" #include "effects.h"
#include "hud_element.h" #include "hud_element.h"
#include "sprite.h"
s32 D_802946E0[] = { 100, 100, 100, 110, 130, 130, 130, 130, 130, 130, 130, 130, 130, 130, 130 }; s32 D_802946E0[] = { 100, 100, 100, 110, 130, 130, 130, 130, 130, 130, 130, 130, 130, 130, 130 };
s32 dispatch_damage_event_actor_1(Actor* actor, s32 damageAmount, s32 event);
s32 func_80263230(Actor*, Actor*);
void func_80267018(Actor* actor, s32 arg1);
s32 has_enchanted_part(Actor* actor) { s32 has_enchanted_part(Actor* actor) {
ActorPart* partIt = actor->partsTable; ActorPart* partIt = actor->partsTable;
s32 ret = FALSE; s32 ret = FALSE;
@ -820,7 +817,7 @@ s32 dispatch_damage_event_actor(Actor* actor, s32 damageAmount, s32 originalEven
if (actor->currentHP <= 0) { if (actor->currentHP <= 0) {
battleStatus->lastAttackDamage += actor->currentHP; battleStatus->lastAttackDamage += actor->currentHP;
actor->currentHP = 0; actor->currentHP = 0;
dispatchEvent = EVENT_DEATH; dispatchEvent = EVENT_DEATH;
} }
battleStatus->lastAttackDamage += temp_v1; battleStatus->lastAttackDamage += temp_v1;
@ -870,6 +867,7 @@ s32 dispatch_damage_event_actor(Actor* actor, s32 damageAmount, s32 originalEven
return 0; return 0;
} }
#else #else
s32 dispatch_damage_event_actor(Actor* actor, s32 damageAmount, s32 originalEvent, s32 stopMotion);
INCLUDE_ASM(s32, "1A5830", dispatch_damage_event_actor); INCLUDE_ASM(s32, "1A5830", dispatch_damage_event_actor);
#endif #endif
@ -1095,11 +1093,11 @@ s32 LandJumpPart(Evt* script, s32 isInitialCall) {
script->functionTemp[0] = 1; script->functionTemp[0] = 1;
} }
part = script->functionTemp[2]; part = (ActorPart*)script->functionTemp[2];
movement = part->movement; movement = part->movement;
movement->unk_00.y += movement->unk_2C; movement->unk_00.y += movement->unk_2C;
movement->unk_2C -= movement->jumpScale; movement->unk_2C -= movement->jumpScale;
add_xz_vec3f_copy1(movement, movement->moveSpeed, movement->unk_30); add_xz_vec3f_copy1(&movement->unk_00, movement->moveSpeed, movement->unk_30);
part->absolutePosition.x = movement->unk_00.x; part->absolutePosition.x = movement->unk_00.x;
part->absolutePosition.y = movement->unk_00.y; part->absolutePosition.y = movement->unk_00.y;
part->absolutePosition.z = movement->unk_00.z; part->absolutePosition.z = movement->unk_00.z;

View File

@ -1122,7 +1122,7 @@ INCLUDE_ASM(s32, "80850_len_3060", is_ability_active);
#endif #endif
s32 is_partner_ability_active(void) { s32 is_partner_ability_active(s32 ability) {
return 0; return 0;
} }

View File

@ -75,7 +75,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_80220C14)), .partCount = ARRAY_COUNT(N(partsTable_80220C14)),
.partsData = N(partsTable_80220C14), .partsData = N(partsTable_80220C14),
.script = N(init_80220CAC), .script = &N(init_80220CAC),
.statusTable = N(statusTable_80220B68), .statusTable = N(statusTable_80220B68),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 30, .airLiftChance = 30,

View File

@ -144,7 +144,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021B460)), .partCount = ARRAY_COUNT(N(partsTable_8021B460)),
.partsData = N(partsTable_8021B460), .partsData = N(partsTable_8021B460),
.script = N(init_8021B564), .script = &N(init_8021B564),
.statusTable = N(statusTable_8021B3B4), .statusTable = N(statusTable_8021B3B4),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -66,7 +66,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_80218828)), .partCount = ARRAY_COUNT(N(partsTable_80218828)),
.partsData = N(partsTable_80218828), .partsData = N(partsTable_80218828),
.script = N(init_802188C0), .script = &N(init_802188C0),
.statusTable = N(statusTable_8021877C), .statusTable = N(statusTable_8021877C),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -81,7 +81,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 10, .maxHP = 10,
.partCount = ARRAY_COUNT(N(partsTable_80225D4C)), .partCount = ARRAY_COUNT(N(partsTable_80225D4C)),
.partsData = N(partsTable_80225D4C), .partsData = N(partsTable_80225D4C),
.script = N(init_80225D98), .script = &N(init_80225D98),
.statusTable = N(statusTable_80225CA0), .statusTable = N(statusTable_80225CA0),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -111,7 +111,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 50, .maxHP = 50,
.partCount = ARRAY_COUNT(N(partsTable_80223D30)), .partCount = ARRAY_COUNT(N(partsTable_80223D30)),
.partsData = N(partsTable_80223D30), .partsData = N(partsTable_80223D30),
.script = N(init_80223DA0), .script = &N(init_80223DA0),
.statusTable = N(statusTable_80223C84), .statusTable = N(statusTable_80223C84),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -76,7 +76,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 8, .maxHP = 8,
.partCount = ARRAY_COUNT(N(partsTable_80218104)), .partCount = ARRAY_COUNT(N(partsTable_80218104)),
.partsData = N(partsTable_80218104), .partsData = N(partsTable_80218104),
.script = N(init_80218150), .script = &N(init_80218150),
.statusTable = N(statusTable_80218058), .statusTable = N(statusTable_80218058),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 60, .airLiftChance = 60,

View File

@ -82,7 +82,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 10, .maxHP = 10,
.partCount = ARRAY_COUNT(N(partsTable_80218D24)), .partCount = ARRAY_COUNT(N(partsTable_80218D24)),
.partsData = N(partsTable_80218D24), .partsData = N(partsTable_80218D24),
.script = N(init_80218D70), .script = &N(init_80218D70),
.statusTable = N(statusTable_80218C78), .statusTable = N(statusTable_80218C78),
.escapeChance = 15, .escapeChance = 15,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -118,7 +118,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 10, .maxHP = 10,
.partCount = ARRAY_COUNT(N(partsTable_8021AD80)), .partCount = ARRAY_COUNT(N(partsTable_8021AD80)),
.partsData = N(partsTable_8021AD80), .partsData = N(partsTable_8021AD80),
.script = N(init_8021AEB4), .script = &N(init_8021AEB4),
.statusTable = N(statusTable_8021ACD4), .statusTable = N(statusTable_8021ACD4),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 80, .airLiftChance = 80,

View File

@ -73,7 +73,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_80219114)), .partCount = ARRAY_COUNT(N(partsTable_80219114)),
.partsData = N(partsTable_80219114), .partsData = N(partsTable_80219114),
.script = N(init_80219160), .script = &N(init_80219160),
.statusTable = N(statusTable_80219068), .statusTable = N(statusTable_80219068),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -136,7 +136,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 8, .maxHP = 8,
.partCount = ARRAY_COUNT(N(partsTable_8021D5F0)), .partCount = ARRAY_COUNT(N(partsTable_8021D5F0)),
.partsData = N(partsTable_8021D5F0), .partsData = N(partsTable_8021D5F0),
.script = N(init_8021E100), .script = &N(init_8021E100),
.statusTable = N(statusTable_8021D498), .statusTable = N(statusTable_8021D498),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,
@ -161,7 +161,7 @@ ActorBlueprint N(flying) = {
.maxHP = 8, .maxHP = 8,
.partCount = ARRAY_COUNT(N(partsTable_8021D614)), .partCount = ARRAY_COUNT(N(partsTable_8021D614)),
.partsData = N(partsTable_8021D614), .partsData = N(partsTable_8021D614),
.script = N(init_8021E2C0), .script = &N(init_8021E2C0),
.statusTable = N(statusTable_8021D544), .statusTable = N(statusTable_8021D544),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,
@ -1304,7 +1304,7 @@ ActorBlueprint N(clone) = {
.maxHP = 11, .maxHP = 11,
.partCount = ARRAY_COUNT(N(partsTable_80221624)), .partCount = ARRAY_COUNT(N(partsTable_80221624)),
.partsData = N(partsTable_80221624), .partsData = N(partsTable_80221624),
.script = N(init_8022143C), .script = &N(init_8022143C),
.statusTable = N(statusTable_802214CC), .statusTable = N(statusTable_802214CC),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 0, .airLiftChance = 0,
@ -1327,7 +1327,7 @@ ActorBlueprint N(flying_clone) = {
.maxHP = 11, .maxHP = 11,
.partCount = ARRAY_COUNT(N(partsTable_80221648)), .partCount = ARRAY_COUNT(N(partsTable_80221648)),
.partsData = N(partsTable_80221648), .partsData = N(partsTable_80221648),
.script = N(init_80221478), .script = &N(init_80221478),
.statusTable = N(statusTable_80221578), .statusTable = N(statusTable_80221578),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -74,7 +74,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 3, .maxHP = 3,
.partCount = ARRAY_COUNT(N(partsTable_8021E594)), .partCount = ARRAY_COUNT(N(partsTable_8021E594)),
.partsData = N(partsTable_8021E594), .partsData = N(partsTable_8021E594),
.script = N(init_8021E6BC), .script = &N(init_8021E6BC),
.statusTable = N(statusTable_8021E4E8), .statusTable = N(statusTable_8021E4E8),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 75, .airLiftChance = 75,

View File

@ -131,7 +131,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_80218CC8)), .partCount = ARRAY_COUNT(N(partsTable_80218CC8)),
.partsData = N(partsTable_80218CC8), .partsData = N(partsTable_80218CC8),
.script = N(init_80218EC4), .script = &N(init_80218EC4),
.statusTable = N(statusTable_80218C1C), .statusTable = N(statusTable_80218C1C),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -221,7 +221,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_80221604)), .partCount = ARRAY_COUNT(N(partsTable_80221604)),
.partsData = N(partsTable_80221604), .partsData = N(partsTable_80221604),
.script = N(init_80221ABC), .script = &N(init_80221ABC),
.statusTable = N(statusTable_80221558), .statusTable = N(statusTable_80221558),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 25, .airLiftChance = 25,

View File

@ -64,7 +64,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_8021C568)), .partCount = ARRAY_COUNT(N(partsTable_8021C568)),
.partsData = N(partsTable_8021C568), .partsData = N(partsTable_8021C568),
.script = N(init_8021C64C), .script = &N(init_8021C64C),
.statusTable = N(statusTable_8021C4BC), .statusTable = N(statusTable_8021C4BC),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 100, .airLiftChance = 100,

View File

@ -232,7 +232,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_80218D34)), .partCount = ARRAY_COUNT(N(partsTable_80218D34)),
.partsData = N(partsTable_80218D34), .partsData = N(partsTable_80218D34),
.script = N(init_80218EC4), .script = &N(init_80218EC4),
.statusTable = N(statusTable_80218C88), .statusTable = N(statusTable_80218C88),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -204,7 +204,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 30, .maxHP = 30,
.partCount = ARRAY_COUNT(N(partsTable_8021BAD4)), .partCount = ARRAY_COUNT(N(partsTable_8021BAD4)),
.partsData = N(partsTable_8021BAD4), .partsData = N(partsTable_8021BAD4),
.script = N(init_8021BC1C), .script = &N(init_8021BC1C),
.statusTable = N(statusTable_8021BA28), .statusTable = N(statusTable_8021BA28),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -141,7 +141,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 40, .maxHP = 40,
.partCount = ARRAY_COUNT(N(partsTable_8021B708)), .partCount = ARRAY_COUNT(N(partsTable_8021B708)),
.partsData = N(partsTable_8021B708), .partsData = N(partsTable_8021B708),
.script = N(init_8021B7E4), .script = &N(init_8021B7E4),
.statusTable = N(statusTable_8021B65C), .statusTable = N(statusTable_8021B65C),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -72,7 +72,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable_802187EC)), .partCount = ARRAY_COUNT(N(partsTable_802187EC)),
.partsData = N(partsTable_802187EC), .partsData = N(partsTable_802187EC),
.script = N(init_802188D0), .script = &N(init_802188D0),
.statusTable = N(statusTable_80218740), .statusTable = N(statusTable_80218740),
.escapeChance = 80, .escapeChance = 80,
.airLiftChance = 40, .airLiftChance = 40,

View File

@ -88,7 +88,7 @@ ActorBlueprint N(1) = {
.maxHP = 3, .maxHP = 3,
.partCount = ARRAY_COUNT(N(partsTable_8021A508)), .partCount = ARRAY_COUNT(N(partsTable_8021A508)),
.partsData = N(partsTable_8021A508), .partsData = N(partsTable_8021A508),
.script = N(init_8021A7B0), .script = &N(init_8021A7B0),
.statusTable = N(statusTable_8021A45C), .statusTable = N(statusTable_8021A45C),
.escapeChance = 80, .escapeChance = 80,
.airLiftChance = 70, .airLiftChance = 70,
@ -162,7 +162,7 @@ ActorBlueprint N(2) = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_8021A60C)), .partCount = ARRAY_COUNT(N(partsTable_8021A60C)),
.partsData = N(partsTable_8021A60C), .partsData = N(partsTable_8021A60C),
.script = N(init_8021A630), .script = &N(init_8021A630),
.statusTable = NULL, .statusTable = NULL,
.escapeChance = 80, .escapeChance = 80,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -77,7 +77,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_8021FD54)), .partCount = ARRAY_COUNT(N(partsTable_8021FD54)),
.partsData = N(partsTable_8021FD54), .partsData = N(partsTable_8021FD54),
.script = N(init_8021FDA0), .script = &N(init_8021FDA0),
.statusTable = N(statusTable_8021FCA8), .statusTable = N(statusTable_8021FCA8),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -114,7 +114,7 @@ ActorBlueprint N(whacka) = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_80220A04)), .partCount = ARRAY_COUNT(N(partsTable_80220A04)),
.partsData = N(partsTable_80220A04), .partsData = N(partsTable_80220A04),
.script = N(init_80220A50), .script = &N(init_80220A50),
.statusTable = N(statusTable_80220958), .statusTable = N(statusTable_80220958),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -109,7 +109,7 @@ ActorBlueprint N(whacka) = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_80221720)), .partCount = ARRAY_COUNT(N(partsTable_80221720)),
.partsData = N(partsTable_80221720), .partsData = N(partsTable_80221720),
.script = N(init_8022176C), .script = &N(init_8022176C),
.statusTable = N(statusTable_80221674), .statusTable = N(statusTable_80221674),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -77,7 +77,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 8, .maxHP = 8,
.partCount = ARRAY_COUNT(N(partsTable_8021DA4C)), .partCount = ARRAY_COUNT(N(partsTable_8021DA4C)),
.partsData = N(partsTable_8021DA4C), .partsData = N(partsTable_8021DA4C),
.script = N(init_8021DA98), .script = &N(init_8021DA98),
.statusTable = N(statusTable_8021D9A0), .statusTable = N(statusTable_8021D9A0),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 20, .airLiftChance = 20,

View File

@ -67,7 +67,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021EA90)), .partCount = ARRAY_COUNT(N(partsTable_8021EA90)),
.partsData = N(partsTable_8021EA90), .partsData = N(partsTable_8021EA90),
.script = N(init_8021EB28), .script = &N(init_8021EB28),
.statusTable = N(statusTable_8021E9E4), .statusTable = N(statusTable_8021E9E4),
.escapeChance = 30, .escapeChance = 30,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -76,7 +76,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 8, .maxHP = 8,
.partCount = ARRAY_COUNT(N(partsTable_8022193C)), .partCount = ARRAY_COUNT(N(partsTable_8022193C)),
.partsData = N(partsTable_8022193C), .partsData = N(partsTable_8022193C),
.script = N(init_80221988), .script = &N(init_80221988),
.statusTable = N(statusTable_80221890), .statusTable = N(statusTable_80221890),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -178,7 +178,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_802187F0)), .partCount = ARRAY_COUNT(N(partsTable_802187F0)),
.partsData = N(partsTable_802187F0), .partsData = N(partsTable_802187F0),
.script = N(init_80218980), .script = &N(init_80218980),
.statusTable = N(statusTable_80218698), .statusTable = N(statusTable_80218698),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -106,7 +106,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_80218B00)), .partCount = ARRAY_COUNT(N(partsTable_80218B00)),
.partsData = N(partsTable_80218B00), .partsData = N(partsTable_80218B00),
.script = N(init_80218B70), .script = &N(init_80218B70),
.statusTable = N(statusTable_80218A54), .statusTable = N(statusTable_80218A54),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 6, .maxHP = 6,
.partCount = ARRAY_COUNT(N(partsTable_80219968)), .partCount = ARRAY_COUNT(N(partsTable_80219968)),
.partsData = N(partsTable_80219968), .partsData = N(partsTable_80219968),
.script = N(init_8021B268), .script = &N(init_8021B268),
.statusTable = N(statusTable_802198BC), .statusTable = N(statusTable_802198BC),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -63,7 +63,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 6, .maxHP = 6,
.partCount = ARRAY_COUNT(N(partsTable_8021D4B8)), .partCount = ARRAY_COUNT(N(partsTable_8021D4B8)),
.partsData = N(partsTable_8021D4B8), .partsData = N(partsTable_8021D4B8),
.script = N(init_8021EDB8), .script = &N(init_8021EDB8),
.statusTable = N(statusTable_8021D40C), .statusTable = N(statusTable_8021D40C),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -128,7 +128,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 10, .maxHP = 10,
.partCount = ARRAY_COUNT(N(partsTable_802209C8)), .partCount = ARRAY_COUNT(N(partsTable_802209C8)),
.partsData = N(partsTable_802209C8), .partsData = N(partsTable_802209C8),
.script = N(init_80220A38), .script = &N(init_80220A38),
.statusTable = N(statusTable_8022091C), .statusTable = N(statusTable_8022091C),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -118,7 +118,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 255, .maxHP = 255,
.partCount = ARRAY_COUNT(N(partsTable_8022339C)), .partCount = ARRAY_COUNT(N(partsTable_8022339C)),
.partsData = N(partsTable_8022339C), .partsData = N(partsTable_8022339C),
.script = N(init_80223488), .script = &N(init_80223488),
.statusTable = N(statusTable_802232F0), .statusTable = N(statusTable_802232F0),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021B778)), .partCount = ARRAY_COUNT(N(partsTable_8021B778)),
.partsData = N(partsTable_8021B778), .partsData = N(partsTable_8021B778),
.script = N(init_8021D078), .script = &N(init_8021D078),
.statusTable = N(statusTable_8021B6CC), .statusTable = N(statusTable_8021B6CC),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -63,7 +63,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021EEB8)), .partCount = ARRAY_COUNT(N(partsTable_8021EEB8)),
.partsData = N(partsTable_8021EEB8), .partsData = N(partsTable_8021EEB8),
.script = N(init_802207B8), .script = &N(init_802207B8),
.statusTable = N(statusTable_8021EE0C), .statusTable = N(statusTable_8021EE0C),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -88,7 +88,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 15, .maxHP = 15,
.partCount = ARRAY_COUNT(N(partsTable_802244C4)), .partCount = ARRAY_COUNT(N(partsTable_802244C4)),
.partsData = N(partsTable_802244C4), .partsData = N(partsTable_802244C4),
.script = N(init_80224A94), .script = &N(init_80224A94),
.statusTable = N(statusTable_80224418), .statusTable = N(statusTable_80224418),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -184,7 +184,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 60, .maxHP = 60,
.partCount = ARRAY_COUNT(N(partsTable_8022C640)), .partCount = ARRAY_COUNT(N(partsTable_8022C640)),
.partsData = N(partsTable_8022C640), .partsData = N(partsTable_8022C640),
.script = N(init_8022CF80), .script = &N(init_8022CF80),
.statusTable = N(statusTable_8022C43C), .statusTable = N(statusTable_8022C43C),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -71,7 +71,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_80222AE4)), .partCount = ARRAY_COUNT(N(partsTable_80222AE4)),
.partsData = N(partsTable_80222AE4), .partsData = N(partsTable_80222AE4),
.script = N(init_80223180), .script = &N(init_80223180),
.statusTable = N(statusTable_80222A38), .statusTable = N(statusTable_80222A38),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -115,7 +115,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 50, .maxHP = 50,
.partCount = ARRAY_COUNT(N(partsTable_8022A6E0)), .partCount = ARRAY_COUNT(N(partsTable_8022A6E0)),
.partsData = N(partsTable_8022A6E0), .partsData = N(partsTable_8022A6E0),
.script = N(init_8022ACE4), .script = &N(init_8022ACE4),
.statusTable = N(statusTable_8022A634), .statusTable = N(statusTable_8022A634),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -101,7 +101,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 40, .maxHP = 40,
.partCount = ARRAY_COUNT(N(partsTable_80225F0C)), .partCount = ARRAY_COUNT(N(partsTable_80225F0C)),
.partsData = N(partsTable_80225F0C), .partsData = N(partsTable_80225F0C),
.script = N(init_80226510), .script = &N(init_80226510),
.statusTable = N(statusTable_80225E60), .statusTable = N(statusTable_80225E60),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -133,7 +133,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable)), .partCount = ARRAY_COUNT(N(partsTable)),
.partsData = N(partsTable), .partsData = N(partsTable),
.script = N(init_8021F450), .script = &N(init_8021F450),
.statusTable = N(statusTable_8021C274), .statusTable = N(statusTable_8021C274),
.escapeChance = 90, .escapeChance = 90,
.airLiftChance = 100, .airLiftChance = 100,

View File

@ -63,7 +63,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable_8021A448)), .partCount = ARRAY_COUNT(N(partsTable_8021A448)),
.partsData = N(partsTable_8021A448), .partsData = N(partsTable_8021A448),
.script = N(init_8021BEBC), .script = &N(init_8021BEBC),
.statusTable = N(statusTable_8021A39C), .statusTable = N(statusTable_8021A39C),
.escapeChance = 90, .escapeChance = 90,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -95,7 +95,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 40, .maxHP = 40,
.partCount = ARRAY_COUNT(N(partsTable_80228014)), .partCount = ARRAY_COUNT(N(partsTable_80228014)),
.partsData = N(partsTable_80228014), .partsData = N(partsTable_80228014),
.script = N(init_80228618), .script = &N(init_80228618),
.statusTable = N(statusTable_80227F68), .statusTable = N(statusTable_80227F68),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -121,7 +121,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 9, .maxHP = 9,
.partCount = ARRAY_COUNT(N(partsTable_80218EE8)), .partCount = ARRAY_COUNT(N(partsTable_80218EE8)),
.partsData = N(partsTable_80218EE8), .partsData = N(partsTable_80218EE8),
.script = N(init_8021901C), .script = &N(init_8021901C),
.statusTable = N(statusTable_80218E3C), .statusTable = N(statusTable_80218E3C),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -138,7 +138,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 11, .maxHP = 11,
.partCount = ARRAY_COUNT(N(partsTable_80220FD0)), .partCount = ARRAY_COUNT(N(partsTable_80220FD0)),
.partsData = N(partsTable_80220FD0), .partsData = N(partsTable_80220FD0),
.script = N(init_80223298), .script = &N(init_80223298),
.statusTable = N(statusTable_80220E78), .statusTable = N(statusTable_80220E78),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 80, .airLiftChance = 80,
@ -161,7 +161,7 @@ ActorBlueprint N(flying) = {
.maxHP = 11, .maxHP = 11,
.partCount = ARRAY_COUNT(N(partsTable_80220FF4)), .partCount = ARRAY_COUNT(N(partsTable_80220FF4)),
.partsData = N(partsTable_80220FF4), .partsData = N(partsTable_80220FF4),
.script = N(init_8022333C), .script = &N(init_8022333C),
.statusTable = N(statusTable_80220F24), .statusTable = N(statusTable_80220F24),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -68,7 +68,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 15, .maxHP = 15,
.partCount = ARRAY_COUNT(N(partsTable_80219E24)), .partCount = ARRAY_COUNT(N(partsTable_80219E24)),
.partsData = N(partsTable_80219E24), .partsData = N(partsTable_80219E24),
.script = N(init_8021CCDC), .script = &N(init_8021CCDC),
.statusTable = N(statusTable_80219D78), .statusTable = N(statusTable_80219D78),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -90,7 +90,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_8021D47C)), .partCount = ARRAY_COUNT(N(partsTable_8021D47C)),
.partsData = N(partsTable_8021D47C), .partsData = N(partsTable_8021D47C),
.script = N(init_8021D4C8), .script = &N(init_8021D4C8),
.statusTable = N(statusTable_8021D3D0), .statusTable = N(statusTable_8021D3D0),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -519,7 +519,7 @@ ActorBlueprint N(goombario) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_8021EA50)), .partCount = ARRAY_COUNT(N(partsTable_8021EA50)),
.partsData = N(partsTable_8021EA50), .partsData = N(partsTable_8021EA50),
.script = N(init_Goombario), .script = &N(init_Goombario),
.statusTable = N(statusTable_8021E9A4), .statusTable = N(statusTable_8021E9A4),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -1097,7 +1097,7 @@ ActorBlueprint N(kooper) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_8022069C)), .partCount = ARRAY_COUNT(N(partsTable_8022069C)),
.partsData = N(partsTable_8022069C), .partsData = N(partsTable_8022069C),
.script = N(init_Kooper), .script = &N(init_Kooper),
.statusTable = N(statusTable_802205F0), .statusTable = N(statusTable_802205F0),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -1609,7 +1609,7 @@ ActorBlueprint N(bombette) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_80222394)), .partCount = ARRAY_COUNT(N(partsTable_80222394)),
.partsData = N(partsTable_80222394), .partsData = N(partsTable_80222394),
.script = N(init_LeeBombette), .script = &N(init_LeeBombette),
.statusTable = N(statusTable_802222E8), .statusTable = N(statusTable_802222E8),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -1975,7 +1975,7 @@ ActorBlueprint N(parakerry) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_8022348C)), .partCount = ARRAY_COUNT(N(partsTable_8022348C)),
.partsData = N(partsTable_8022348C), .partsData = N(partsTable_8022348C),
.script = N(init_Parakarry), .script = &N(init_Parakarry),
.statusTable = N(statusTable_802233E0), .statusTable = N(statusTable_802233E0),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -2337,7 +2337,7 @@ ActorBlueprint N(bow) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_80224514)), .partCount = ARRAY_COUNT(N(partsTable_80224514)),
.partsData = N(partsTable_80224514), .partsData = N(partsTable_80224514),
.script = N(init_Bow), .script = &N(init_Bow),
.statusTable = N(statusTable_80224468), .statusTable = N(statusTable_80224468),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -2789,7 +2789,7 @@ ActorBlueprint N(watt) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_80225A80)), .partCount = ARRAY_COUNT(N(partsTable_80225A80)),
.partsData = N(partsTable_80225A80), .partsData = N(partsTable_80225A80),
.script = N(init_Watt), .script = &N(init_Watt),
.statusTable = N(statusTable_802259D4), .statusTable = N(statusTable_802259D4),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -3173,7 +3173,7 @@ ActorBlueprint N(sushie) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_80226A80)), .partCount = ARRAY_COUNT(N(partsTable_80226A80)),
.partsData = N(partsTable_80226A80), .partsData = N(partsTable_80226A80),
.script = N(init_Sushie), .script = &N(init_Sushie),
.statusTable = N(statusTable_802269D4), .statusTable = N(statusTable_802269D4),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,
@ -3665,7 +3665,7 @@ ActorBlueprint N(lakilester) = {
.maxHP = 20, .maxHP = 20,
.partCount = ARRAY_COUNT(N(partsTable_8022851C)), .partCount = ARRAY_COUNT(N(partsTable_8022851C)),
.partsData = N(partsTable_8022851C), .partsData = N(partsTable_8022851C),
.script = N(init_Lakilester), .script = &N(init_Lakilester),
.statusTable = N(statusTable_80228470), .statusTable = N(statusTable_80228470),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -73,7 +73,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 50, .maxHP = 50,
.partCount = ARRAY_COUNT(N(partsTable_8022A364)), .partCount = ARRAY_COUNT(N(partsTable_8022A364)),
.partsData = N(partsTable_8022A364), .partsData = N(partsTable_8022A364),
.script = N(init_8022A3B0), .script = &N(init_8022A3B0),
.statusTable = N(statusTable_8022A2B8), .statusTable = N(statusTable_8022A2B8),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -86,7 +86,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 75, .maxHP = 75,
.partCount = ARRAY_COUNT(N(partsTable_8022B790)), .partCount = ARRAY_COUNT(N(partsTable_8022B790)),
.partsData = N(partsTable_8022B790), .partsData = N(partsTable_8022B790),
.script = N(init_8022B7DC), .script = &N(init_8022B7DC),
.statusTable = N(statusTable_8022B6E4), .statusTable = N(statusTable_8022B6E4),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -98,7 +98,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_8022DAF0)), .partCount = ARRAY_COUNT(N(partsTable_8022DAF0)),
.partsData = N(partsTable_8022DAF0), .partsData = N(partsTable_8022DAF0),
.script = N(init_8022DB60), .script = &N(init_8022DB60),
.statusTable = N(statusTable_8022DA44), .statusTable = N(statusTable_8022DA44),
.escapeChance = 100, .escapeChance = 100,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -141,7 +141,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 3, .maxHP = 3,
.partCount = ARRAY_COUNT(N(partsTable_8021A924)), .partCount = ARRAY_COUNT(N(partsTable_8021A924)),
.partsData = N(partsTable_8021A924), .partsData = N(partsTable_8021A924),
.script = N(init_8021AA24), .script = &N(init_8021AA24),
.statusTable = N(statusTable_8021A878), .statusTable = N(statusTable_8021A878),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 6, .maxHP = 6,
.partCount = ARRAY_COUNT(N(partsTable_80218478)), .partCount = ARRAY_COUNT(N(partsTable_80218478)),
.partsData = N(partsTable_80218478), .partsData = N(partsTable_80218478),
.script = N(init_80218510), .script = &N(init_80218510),
.statusTable = N(statusTable_802183CC), .statusTable = N(statusTable_802183CC),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -86,7 +86,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_8021D44C)), .partCount = ARRAY_COUNT(N(partsTable_8021D44C)),
.partsData = N(partsTable_8021D44C), .partsData = N(partsTable_8021D44C),
.script = N(init_8021D498), .script = &N(init_8021D498),
.statusTable = N(statusTable_8021D3A0), .statusTable = N(statusTable_8021D3A0),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 20, .airLiftChance = 20,

View File

@ -61,7 +61,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 3, .maxHP = 3,
.partCount = ARRAY_COUNT(N(partsTable_80222108)), .partCount = ARRAY_COUNT(N(partsTable_80222108)),
.partsData = N(partsTable_80222108), .partsData = N(partsTable_80222108),
.script = N(init_802221A0), .script = &N(init_802221A0),
.statusTable = N(statusTable_8022205C), .statusTable = N(statusTable_8022205C),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -198,7 +198,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 70, .maxHP = 70,
.partCount = ARRAY_COUNT(N(partsTable_80227AB4)), .partCount = ARRAY_COUNT(N(partsTable_80227AB4)),
.partsData = N(partsTable_80227AB4), .partsData = N(partsTable_80227AB4),
.script = N(init_80227C20), .script = &N(init_80227C20),
.statusTable = N(statusTable_80227A08), .statusTable = N(statusTable_80227A08),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -64,7 +64,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 50, .maxHP = 50,
.partCount = ARRAY_COUNT(N(partsTable_802219C8)), .partCount = ARRAY_COUNT(N(partsTable_802219C8)),
.partsData = N(partsTable_802219C8), .partsData = N(partsTable_802219C8),
.script = N(init_80221A60), .script = &N(init_80221A60),
.statusTable = N(statusTable_8022191C), .statusTable = N(statusTable_8022191C),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021ADD0)), .partCount = ARRAY_COUNT(N(partsTable_8021ADD0)),
.partsData = N(partsTable_8021ADD0), .partsData = N(partsTable_8021ADD0),
.script = N(init_8021AE68), .script = &N(init_8021AE68),
.statusTable = N(statusTable_8021AD24), .statusTable = N(statusTable_8021AD24),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021FED0)), .partCount = ARRAY_COUNT(N(partsTable_8021FED0)),
.partsData = N(partsTable_8021FED0), .partsData = N(partsTable_8021FED0),
.script = N(init_8021FF68), .script = &N(init_8021FF68),
.statusTable = N(statusTable_8021FE24), .statusTable = N(statusTable_8021FE24),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -87,7 +87,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_80224AEC)), .partCount = ARRAY_COUNT(N(partsTable_80224AEC)),
.partsData = N(partsTable_80224AEC), .partsData = N(partsTable_80224AEC),
.script = N(init_80224B38), .script = &N(init_80224B38),
.statusTable = N(statusTable_80224A40), .statusTable = N(statusTable_80224A40),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021E3D0)), .partCount = ARRAY_COUNT(N(partsTable_8021E3D0)),
.partsData = N(partsTable_8021E3D0), .partsData = N(partsTable_8021E3D0),
.script = N(init_8021E468), .script = &N(init_8021E468),
.statusTable = N(statusTable_8021E324), .statusTable = N(statusTable_8021E324),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -83,7 +83,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8022CC34)), .partCount = ARRAY_COUNT(N(partsTable_8022CC34)),
.partsData = N(partsTable_8022CC34), .partsData = N(partsTable_8022CC34),
.script = N(init_8022CC80), .script = &N(init_8022CC80),
.statusTable = N(statusTable_8022CB88), .statusTable = N(statusTable_8022CB88),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_802192D0)), .partCount = ARRAY_COUNT(N(partsTable_802192D0)),
.partsData = N(partsTable_802192D0), .partsData = N(partsTable_802192D0),
.script = N(init_80219368), .script = &N(init_80219368),
.statusTable = N(statusTable_80219224), .statusTable = N(statusTable_80219224),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -223,7 +223,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8022977C)), .partCount = ARRAY_COUNT(N(partsTable_8022977C)),
.partsData = N(partsTable_8022977C), .partsData = N(partsTable_8022977C),
.script = N(init_8022987C), .script = &N(init_8022987C),
.statusTable = N(statusTable_80229624), .statusTable = N(statusTable_80229624),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -109,7 +109,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_80227564)), .partCount = ARRAY_COUNT(N(partsTable_80227564)),
.partsData = N(partsTable_80227564), .partsData = N(partsTable_80227564),
.script = N(init_802275D4), .script = &N(init_802275D4),
.statusTable = N(statusTable_802274B8), .statusTable = N(statusTable_802274B8),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -65,7 +65,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021C8D0)), .partCount = ARRAY_COUNT(N(partsTable_8021C8D0)),
.partsData = N(partsTable_8021C8D0), .partsData = N(partsTable_8021C8D0),
.script = N(init_8021C968), .script = &N(init_8021C968),
.statusTable = N(statusTable_8021C824), .statusTable = N(statusTable_8021C824),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 85, .airLiftChance = 85,

View File

@ -130,7 +130,7 @@ ActorBlueprint N(slot_machine_stop) = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_8022DFEC)), .partCount = ARRAY_COUNT(N(partsTable_8022DFEC)),
.partsData = N(partsTable_8022DFEC), .partsData = N(partsTable_8022DFEC),
.script = N(init_8022E060), .script = &N(init_8022E060),
.statusTable = N(statusTable_8022DF40), .statusTable = N(statusTable_8022DF40),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,
@ -153,7 +153,7 @@ ActorBlueprint N(slot_machine_start) = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_8022DFEC)), .partCount = ARRAY_COUNT(N(partsTable_8022DFEC)),
.partsData = N(partsTable_8022DFEC), .partsData = N(partsTable_8022DFEC),
.script = N(init_8022E060), .script = &N(init_8022E060),
.statusTable = N(statusTable_8022DF40), .statusTable = N(statusTable_8022DF40),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -125,7 +125,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_8021D66C)), .partCount = ARRAY_COUNT(N(partsTable_8021D66C)),
.partsData = N(partsTable_8021D66C), .partsData = N(partsTable_8021D66C),
.script = N(init_8021D750), .script = &N(init_8021D750),
.statusTable = N(statusTable_8021D5C0), .statusTable = N(statusTable_8021D5C0),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 90, .airLiftChance = 90,
@ -148,7 +148,7 @@ ActorBlueprint N(2) = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_8021D6B4)), .partCount = ARRAY_COUNT(N(partsTable_8021D6B4)),
.partsData = N(partsTable_8021D6B4), .partsData = N(partsTable_8021D6B4),
.script = N(init_8021D7C4), .script = &N(init_8021D7C4),
.statusTable = N(statusTable_8021D5C0), .statusTable = N(statusTable_8021D5C0),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -133,7 +133,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_80218338)), .partCount = ARRAY_COUNT(N(partsTable_80218338)),
.partsData = N(partsTable_80218338), .partsData = N(partsTable_80218338),
.script = N(init_80218534), .script = &N(init_80218534),
.statusTable = N(statusTable_8021828C), .statusTable = N(statusTable_8021828C),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -75,7 +75,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_80219DD8)), .partCount = ARRAY_COUNT(N(partsTable_80219DD8)),
.partsData = N(partsTable_80219DD8), .partsData = N(partsTable_80219DD8),
.script = N(init_80219E6C), .script = &N(init_80219E6C),
.statusTable = N(statusTable_80219D2C), .statusTable = N(statusTable_80219D2C),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 20, .airLiftChance = 20,

View File

@ -111,7 +111,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 3, .maxHP = 3,
.partCount = ARRAY_COUNT(N(partsTable_8021A70C)), .partCount = ARRAY_COUNT(N(partsTable_8021A70C)),
.partsData = N(partsTable_8021A70C), .partsData = N(partsTable_8021A70C),
.script = N(init_8021A758), .script = &N(init_8021A758),
.statusTable = N(statusTable_8021A5B4), .statusTable = N(statusTable_8021A5B4),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -61,7 +61,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable_80219018)), .partCount = ARRAY_COUNT(N(partsTable_80219018)),
.partsData = N(partsTable_80219018), .partsData = N(partsTable_80219018),
.script = N(init_80219088), .script = &N(init_80219088),
.statusTable = N(statusTable_80218F6C), .statusTable = N(statusTable_80218F6C),
.escapeChance = 50, .escapeChance = 50,
.airLiftChance = 100, .airLiftChance = 100,

View File

@ -70,7 +70,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_8022B564)), .partCount = ARRAY_COUNT(N(partsTable_8022B564)),
.partsData = N(partsTable_8022B564), .partsData = N(partsTable_8022B564),
.script = N(init_8022DC2C), .script = &N(init_8022DC2C),
.statusTable = N(statusTable_8022B4B8), .statusTable = N(statusTable_8022B4B8),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -218,7 +218,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 10, .maxHP = 10,
.partCount = ARRAY_COUNT(N(partsTable_8021A748)), .partCount = ARRAY_COUNT(N(partsTable_8021A748)),
.partsData = N(partsTable_8021A748), .partsData = N(partsTable_8021A748),
.script = N(init_8021A968), .script = &N(init_8021A968),
.statusTable = N(statusTable_8021A690), .statusTable = N(statusTable_8021A690),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -70,7 +70,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_80225624)), .partCount = ARRAY_COUNT(N(partsTable_80225624)),
.partsData = N(partsTable_80225624), .partsData = N(partsTable_80225624),
.script = N(init_80227CEC), .script = &N(init_80227CEC),
.statusTable = N(statusTable_80225578), .statusTable = N(statusTable_80225578),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -70,7 +70,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_802285C4)), .partCount = ARRAY_COUNT(N(partsTable_802285C4)),
.partsData = N(partsTable_802285C4), .partsData = N(partsTable_802285C4),
.script = N(init_8022AC8C), .script = &N(init_8022AC8C),
.statusTable = N(statusTable_80228518), .statusTable = N(statusTable_80228518),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -70,7 +70,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 5, .maxHP = 5,
.partCount = ARRAY_COUNT(N(partsTable_8022E504)), .partCount = ARRAY_COUNT(N(partsTable_8022E504)),
.partsData = N(partsTable_8022E504), .partsData = N(partsTable_8022E504),
.script = N(init_80230BCC), .script = &N(init_80230BCC),
.statusTable = N(statusTable_8022E458), .statusTable = N(statusTable_8022E458),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -71,7 +71,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_80218344)), .partCount = ARRAY_COUNT(N(partsTable_80218344)),
.partsData = N(partsTable_80218344), .partsData = N(partsTable_80218344),
.script = N(init_80218390), .script = &N(init_80218390),
.statusTable = N(statusTable_80218298), .statusTable = N(statusTable_80218298),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -239,7 +239,7 @@ typedef struct ActorBlueprint {
/* 0x08 */ s16 partCount; /* 0x08 */ s16 partCount;
/* 0x0A */ char unk_0A[2]; /* 0x0A */ char unk_0A[2];
/* 0x0C */ struct ActorPartBlueprint* partsData; /* 0x0C */ struct ActorPartBlueprint* partsData;
/* 0x10 */ Bytecode* script; /* 0x10 */ EvtScript* script;
/* 0x14 */ s32* statusTable; /* 0x14 */ s32* statusTable;
/* 0x18 */ u8 escapeChance; /* 0x18 */ u8 escapeChance;
/* 0x19 */ u8 airLiftChance; /* 0x19 */ u8 airLiftChance;

View File

@ -58,7 +58,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable_80219808)), .partCount = ARRAY_COUNT(N(partsTable_80219808)),
.partsData = N(partsTable_80219808), .partsData = N(partsTable_80219808),
.script = N(init_802198EC), .script = &N(init_802198EC),
.statusTable = N(statusTable_8021975C), .statusTable = N(statusTable_8021975C),
.escapeChance = 90, .escapeChance = 90,
.airLiftChance = 100, .airLiftChance = 100,

View File

@ -68,7 +68,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_8021CA44)), .partCount = ARRAY_COUNT(N(partsTable_8021CA44)),
.partsData = N(partsTable_8021CA44), .partsData = N(partsTable_8021CA44),
.script = N(init_8021CB74), .script = &N(init_8021CB74),
.statusTable = N(statusTable_8021C998), .statusTable = N(statusTable_8021C998),
.escapeChance = 70, .escapeChance = 70,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -80,7 +80,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 7, .maxHP = 7,
.partCount = ARRAY_COUNT(N(partsTable_8021F99C)), .partCount = ARRAY_COUNT(N(partsTable_8021F99C)),
.partsData = N(partsTable_8021F99C), .partsData = N(partsTable_8021F99C),
.script = N(init_8021F9E8), .script = &N(init_8021F9E8),
.statusTable = N(statusTable_8021F8F0), .statusTable = N(statusTable_8021F8F0),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 90, .airLiftChance = 90,

View File

@ -129,7 +129,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable_8021B280)), .partCount = ARRAY_COUNT(N(partsTable_8021B280)),
.partsData = N(partsTable_8021B280), .partsData = N(partsTable_8021B280),
.script = N(init_8021B3E8), .script = &N(init_8021B3E8),
.statusTable = N(statusTable_8021B1D4), .statusTable = N(statusTable_8021B1D4),
.escapeChance = 90, .escapeChance = 90,
.airLiftChance = 100, .airLiftChance = 100,

View File

@ -126,7 +126,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_8021EC6C)), .partCount = ARRAY_COUNT(N(partsTable_8021EC6C)),
.partsData = N(partsTable_8021EC6C), .partsData = N(partsTable_8021EC6C),
.script = N(init_8021EE0C), .script = &N(init_8021EE0C),
.statusTable = N(statusTable_8021EBC0), .statusTable = N(statusTable_8021EBC0),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -77,7 +77,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 12, .maxHP = 12,
.partCount = ARRAY_COUNT(N(partsTable_8021B1AC)), .partCount = ARRAY_COUNT(N(partsTable_8021B1AC)),
.partsData = N(partsTable_8021B1AC), .partsData = N(partsTable_8021B1AC),
.script = N(init_8021B1F8), .script = &N(init_8021B1F8),
.statusTable = N(statusTable_8021B100), .statusTable = N(statusTable_8021B100),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 20, .airLiftChance = 20,

View File

@ -71,7 +71,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 4, .maxHP = 4,
.partCount = ARRAY_COUNT(N(partsTable_8021C984)), .partCount = ARRAY_COUNT(N(partsTable_8021C984)),
.partsData = N(partsTable_8021C984), .partsData = N(partsTable_8021C984),
.script = N(init_8021CAAC), .script = &N(init_8021CAAC),
.statusTable = N(statusTable_8021C8D8), .statusTable = N(statusTable_8021C8D8),
.escapeChance = 60, .escapeChance = 60,
.airLiftChance = 70, .airLiftChance = 70,

View File

@ -59,7 +59,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 2, .maxHP = 2,
.partCount = ARRAY_COUNT(N(partsTable_8021E468)), .partCount = ARRAY_COUNT(N(partsTable_8021E468)),
.partsData = N(partsTable_8021E468), .partsData = N(partsTable_8021E468),
.script = N(init_8021E54C), .script = &N(init_8021E54C),
.statusTable = N(statusTable_8021E3BC), .statusTable = N(statusTable_8021E3BC),
.escapeChance = 90, .escapeChance = 90,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -135,7 +135,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 11, .maxHP = 11,
.partCount = ARRAY_COUNT(N(partsTable_80223C90)), .partCount = ARRAY_COUNT(N(partsTable_80223C90)),
.partsData = N(partsTable_80223C90), .partsData = N(partsTable_80223C90),
.script = N(init_80225F58), .script = &N(init_80225F58),
.statusTable = N(statusTable_80223B38), .statusTable = N(statusTable_80223B38),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 80, .airLiftChance = 80,
@ -158,7 +158,7 @@ ActorBlueprint N(flying) = {
.maxHP = 11, .maxHP = 11,
.partCount = ARRAY_COUNT(N(partsTable_80223CB4)), .partCount = ARRAY_COUNT(N(partsTable_80223CB4)),
.partsData = N(partsTable_80223CB4), .partsData = N(partsTable_80223CB4),
.script = N(init_80225FBC), .script = &N(init_80225FBC),
.statusTable = N(statusTable_80223BE4), .statusTable = N(statusTable_80223BE4),
.escapeChance = 40, .escapeChance = 40,
.airLiftChance = 95, .airLiftChance = 95,

View File

@ -69,7 +69,7 @@ ApiStatus func_80238000_6FAD10(Evt* script, s32 isInitialCall) {
ApiStatus func_80238244_6FAF54(Evt* script, s32 isInitialCall) { ApiStatus func_80238244_6FAF54(Evt* script, s32 isInitialCall) {
BattleStatus* battleStatus = &gBattleStatus; BattleStatus* battleStatus = &gBattleStatus;
Actor* partnerActor = battleStatus->partnerActor; Actor* partnerActor = battleStatus->partnerActor;
ActorMovement* partnerActorMovement = &partnerActor->state; ActorState* partnerActorMovement = &partnerActor->state;
if (isInitialCall) { if (isInitialCall) {
partnerActor->state.currentPos.x = partnerActor->currentPos.x; partnerActor->state.currentPos.x = partnerActor->currentPos.x;
@ -306,7 +306,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_80238734)), .partCount = ARRAY_COUNT(N(partsTable_80238734)),
.partsData = N(partsTable_80238734), .partsData = N(partsTable_80238734),
.script = N(init_80238780), .script = &N(init_80238780),
.statusTable = N(statusTable_80238688), .statusTable = N(statusTable_80238688),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -301,7 +301,7 @@ ActorBlueprint N(goombario) = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_802392A4)), .partCount = ARRAY_COUNT(N(partsTable_802392A4)),
.partsData = N(partsTable_802392A4), .partsData = N(partsTable_802392A4),
.script = N(init_802392F0), .script = &N(init_802392F0),
.statusTable = N(statusTable_802391F8), .statusTable = N(statusTable_802391F8),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

View File

@ -64,7 +64,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_802380C4)), .partCount = ARRAY_COUNT(N(partsTable_802380C4)),
.partsData = N(partsTable_802380C4), .partsData = N(partsTable_802380C4),
.script = N(init_80238110), .script = &N(init_80238110),
.statusTable = N(statusTable_80238018), .statusTable = N(statusTable_80238018),
.spinSmashReq = 4, .spinSmashReq = 4,
.powerBounceChance = 80, .powerBounceChance = 80,

View File

@ -28,7 +28,7 @@ extern EvtScript N(8023C754);
ApiStatus func_80238000_6F5E80(Evt* script, s32 isInitialCall) { ApiStatus func_80238000_6F5E80(Evt* script, s32 isInitialCall) {
BattleStatus* battleStatus = &gBattleStatus; BattleStatus* battleStatus = &gBattleStatus;
Actor* partnerActor = battleStatus->partnerActor; Actor* partnerActor = battleStatus->partnerActor;
ActorMovement* partnerActorMovement = &partnerActor->state; ActorState* partnerActorMovement = &partnerActor->state;
if (isInitialCall) { if (isInitialCall) {
partnerActor->state.currentPos.x = partnerActor->currentPos.x; partnerActor->state.currentPos.x = partnerActor->currentPos.x;
@ -191,7 +191,7 @@ ActorBlueprint NAMESPACE = {
.maxHP = 99, .maxHP = 99,
.partCount = ARRAY_COUNT(N(partsTable_80238524)), .partCount = ARRAY_COUNT(N(partsTable_80238524)),
.partsData = N(partsTable_80238524), .partsData = N(partsTable_80238524),
.script = N(init_80238570), .script = &N(init_80238570),
.statusTable = N(statusTable_80238478), .statusTable = N(statusTable_80238478),
.escapeChance = 0, .escapeChance = 0,
.airLiftChance = 0, .airLiftChance = 0,

Some files were not shown because too many files have changed in this diff Show More