summaryrefslogtreecommitdiff
path: root/src/fldeff_softboiled.c
diff options
context:
space:
mode:
authorSwastik Baranwal <swstkbaranwal@gmail.com>2019-06-23 18:47:35 +0530
committerGitHub <noreply@github.com>2019-06-23 18:47:35 +0530
commit99703c6ab831d34e6859d8a8f53ba8e73dc4d3d9 (patch)
tree3a712d3039d152616af58a45a13d82c40a87e58f /src/fldeff_softboiled.c
parent6d190f861e3559eec922cd760778c0cba6e08397 (diff)
parent9ee0c34758a63f8c00724b6fc984b4e96be2f7af (diff)
Merge pull request #5 from pret/master
Take files
Diffstat (limited to 'src/fldeff_softboiled.c')
-rw-r--r--src/fldeff_softboiled.c109
1 files changed, 109 insertions, 0 deletions
diff --git a/src/fldeff_softboiled.c b/src/fldeff_softboiled.c
new file mode 100644
index 000000000..50c715388
--- /dev/null
+++ b/src/fldeff_softboiled.c
@@ -0,0 +1,109 @@
+#include "global.h"
+#include "party_menu.h"
+#include "sound.h"
+#include "string_util.h"
+#include "menu.h"
+#include "constants/songs.h"
+
+void sub_80E57E8(u8 taskId);
+void sub_80E583C(u8 taskId);
+void sub_80E58A0(u8 taskId);
+void sub_80E5934(u8 taskId);
+
+extern const u8 gUnknown_84169F8[];
+extern const u8 gUnknown_8416F27[];
+
+bool8 hm_prepare_dive_probably(void)
+{
+ u16 maxHp = GetMonData(&gPlayerParty[GetCursorSelectionMonId()], MON_DATA_MAX_HP);
+ u16 curHp = GetMonData(&gPlayerParty[GetCursorSelectionMonId()], MON_DATA_HP);
+
+ if (curHp > maxHp / 5)
+ return TRUE;
+ else
+ return FALSE;
+}
+
+void sub_80E56DC(u8 taskId)
+{
+ gUnknown_203B0A0.unkB = 10;
+ gUnknown_203B0A0.unkA = gUnknown_203B0A0.unk9;
+ sub_811F818(GetCursorSelectionMonId(), 1);
+ sub_8121D0C(5);
+ gTasks[taskId].func = sub_811FB28;
+}
+
+void sub_80E5724(u8 taskId)
+{
+ u8 r8 = gUnknown_203B0A0.unk9;
+ u8 r5 = gUnknown_203B0A0.unkA;
+ u16 curHp;
+ s16 delta;
+
+ if (r5 > 6)
+ {
+ gUnknown_203B0A0.unkB = 0;
+ sub_8121D0C(0);
+ gTasks[taskId].func = sub_811FB28;
+ }
+ else
+ {
+ curHp = GetMonData(&gPlayerParty[r5], MON_DATA_HP);
+ if (curHp == 0 || r8 == r5 || GetMonData(&gPlayerParty[r5], MON_DATA_MAX_HP) == curHp)
+ {
+ sub_80E5934(taskId);
+ }
+ else
+ {
+ PlaySE(SE_KAIFUKU);
+ sub_8120760(taskId, r8, -1, GetMonData(&gPlayerParty[r8], MON_DATA_MAX_HP) / 5, sub_80E57E8);
+ }
+ }
+}
+
+void sub_80E57E8(u8 taskId)
+{
+ PlaySE(SE_KAIFUKU);
+ sub_8120760(taskId, gUnknown_203B0A0.unkA, 1, GetMonData(&gPlayerParty[gUnknown_203B0A0.unk9], MON_DATA_MAX_HP) / 5, sub_80E583C);
+}
+
+void sub_80E583C(u8 taskId)
+{
+ GetMonNickname(&gPlayerParty[gUnknown_203B0A0.unkA], gStringVar1);
+ StringExpandPlaceholders(gStringVar4, gUnknown_8416F27);
+ sub_81202F8(gStringVar4, 0);
+ schedule_bg_copy_tilemap_to_vram(2);
+ gTasks[taskId].func = sub_80E58A0;
+}
+
+void sub_80E58A0(u8 taskId)
+{
+ if (sub_8120370() != TRUE)
+ {
+ gUnknown_203B0A0.unkB = 0;
+ sub_811F818(gUnknown_203B0A0.unk9, 0);
+ gUnknown_203B0A0.unk9 = gUnknown_203B0A0.unkA;
+ sub_811F818(gUnknown_203B0A0.unkA, 1);
+ ClearMenuWindow(6, 0);
+ ClearWindowTilemap(6);
+ sub_8121D0C(0);
+ gTasks[taskId].func = sub_811FB28;
+ }
+}
+
+void sub_80E5900(u8 taskId)
+{
+ if (sub_8120370() != TRUE)
+ {
+ sub_8121D0C(5);
+ gTasks[taskId].func = sub_811FB28;
+ }
+}
+
+void sub_80E5934(u8 taskId)
+{
+ PlaySE(SE_SELECT);
+ sub_81202F8(gUnknown_84169F8, 0);
+ schedule_bg_copy_tilemap_to_vram(2);
+ gTasks[taskId].func = sub_80E5900;
+}