summaryrefslogtreecommitdiff
path: root/src/fldeff_strength.c
diff options
context:
space:
mode:
authorMarcus Huderle <huderlem@gmail.com>2018-03-15 06:35:40 -0700
committerGitHub <noreply@github.com>2018-03-15 06:35:40 -0700
commita4988e4a997ae17ff686b8c8b9d62cd9df3c18aa (patch)
tree8ad23a98fef7efaf4a4ca01d3cf440b39e9009c4 /src/fldeff_strength.c
parent8ef4e1785212901e77bf10a90138c9f69fcb0d8b (diff)
parent48eee3aa1efff48045b890796a5e7e795604a679 (diff)
Merge pull request #574 from camthesaxman/reorganize
remove subdirectories
Diffstat (limited to 'src/fldeff_strength.c')
-rw-r--r--src/fldeff_strength.c99
1 files changed, 99 insertions, 0 deletions
diff --git a/src/fldeff_strength.c b/src/fldeff_strength.c
new file mode 100644
index 000000000..9f9cd4013
--- /dev/null
+++ b/src/fldeff_strength.c
@@ -0,0 +1,99 @@
+#include "global.h"
+#include "constants/map_objects.h"
+#include "braille_puzzles.h"
+#include "field_effect.h"
+#include "party_menu.h"
+#include "pokemon.h"
+#include "pokemon_menu.h"
+#include "rom6.h"
+#include "script.h"
+#include "task.h"
+#include "text.h"
+
+static void sub_811AA18(void);
+static void sub_811AA38(void);
+static void sub_811AA9C(void);
+
+extern u8 gLastFieldPokeMenuOpened;
+extern u16 gSpecialVar_Result;
+extern void (*gFieldCallback)(void);
+extern void (*gUnknown_03005CE4)(void);
+
+extern u8 S_UseStrength[];
+
+#if DEBUG
+void debug_sub_8130318(void)
+{
+ if (ShouldDoBrailleStrengthEffect())
+ {
+ gLastFieldPokeMenuOpened = 0;
+ gSpecialVar_Result = 0;
+ sub_811AA38();
+ }
+ else if (npc_before_player_of_type(MAP_OBJ_GFX_PUSHABLE_BOULDER) == TRUE)
+ {
+ gLastFieldPokeMenuOpened = 0;
+ gSpecialVar_Result = 0;
+ sub_811AA18();
+ }
+ else
+ {
+ ScriptContext2_Disable();
+ }
+}
+#endif
+
+bool8 SetUpFieldMove_Strength(void)
+{
+ if (ShouldDoBrailleStrengthEffect())
+ {
+ gSpecialVar_Result = gLastFieldPokeMenuOpened;
+ gFieldCallback = FieldCallback_Teleport;
+ gUnknown_03005CE4 = sub_811AA38;
+ }
+ else
+ {
+ if (npc_before_player_of_type(87) != TRUE)
+ return 0;
+ gSpecialVar_Result = gLastFieldPokeMenuOpened;
+ gFieldCallback = FieldCallback_Teleport;
+ gUnknown_03005CE4 = sub_811AA18;
+ }
+
+ return TRUE;
+}
+
+static void sub_811AA18(void)
+{
+ gFieldEffectArguments[0] = gLastFieldPokeMenuOpened;
+ ScriptContext1_SetupScript(S_UseStrength);
+}
+
+static void sub_811AA38(void)
+{
+ gFieldEffectArguments[0] = gLastFieldPokeMenuOpened;
+ FieldEffectStart(FLDEFF_USE_STRENGTH);
+}
+
+bool8 FldEff_UseStrength(void)
+{
+ u8 taskId = oei_task_add();
+
+ gTasks[taskId].data[8] = (u32)sub_811AA9C >> 16;
+ gTasks[taskId].data[9] = (u32)sub_811AA9C;
+ GetMonNickname(&gPlayerParty[gFieldEffectArguments[0]], gStringVar1);
+ return FALSE;
+}
+
+static void sub_811AA9C(void)
+{
+ if (ShouldDoBrailleStrengthEffect())
+ {
+ DoBrailleStrengthEffect();
+ }
+ else
+ {
+ FieldEffectActiveListRemove(40);
+ EnableBothScriptContexts();
+ }
+}