diff --git a/include/text_options_strings.h.in b/include/text_options_strings.h.in index 8c6732e4..85bd9123 100644 --- a/include/text_options_strings.h.in +++ b/include/text_options_strings.h.in @@ -85,6 +85,7 @@ #define TEXT_OPT_CHEAT7 _("EXIT COURSE AT ANY TIME") #define TEXT_OPT_CHEAT8 _("HUGE MARIO") #define TEXT_OPT_CHEAT9 _("TINY MARIO") +#define TEXT_OPT_FOREVER_SHELL _("FOREVER SHELL") #else // VERSION @@ -149,6 +150,7 @@ #define TEXT_OPT_CHEAT7 _("Exit course at any time") #define TEXT_OPT_CHEAT8 _("Huge Mario") #define TEXT_OPT_CHEAT9 _("Tiny Mario") +#define TEXT_OPT_FOREVER_SHELL _("Forever Shell") #endif // VERSION diff --git a/src/game/mario_actions_moving.c b/src/game/mario_actions_moving.c index 0ccbccf1..865366be 100644 --- a/src/game/mario_actions_moving.c +++ b/src/game/mario_actions_moving.c @@ -1235,11 +1235,11 @@ s32 act_riding_shell_ground(struct MarioState *m) { break; case GROUND_STEP_HIT_WALL: - mario_stop_riding_object(m); + if (!Cheats.EnableCheats || !Cheats.ForeverShell) { mario_stop_riding_object(m); } play_sound(m->flags & MARIO_METAL_CAP ? SOUND_ACTION_METAL_BONK : SOUND_ACTION_BONK, m->marioObj->header.gfx.cameraToObject); m->particleFlags |= PARTICLE_VERTICAL_STAR; - set_mario_action(m, ACT_BACKWARD_GROUND_KB, 0); + if (!Cheats.EnableCheats || !Cheats.ForeverShell) { set_mario_action(m, ACT_BACKWARD_GROUND_KB, 0); } break; } diff --git a/src/game/options_menu.c b/src/game/options_menu.c index 56ebdebe..a78eb47b 100644 --- a/src/game/options_menu.c +++ b/src/game/options_menu.c @@ -282,6 +282,7 @@ static struct Option optsCheats[] = { DEF_OPT_TOGGLE( optsCheatsStr[6], &Cheats.ExitAnywhere ), DEF_OPT_TOGGLE( optsCheatsStr[7], &Cheats.HugeMario ), DEF_OPT_TOGGLE( optsCheatsStr[8], &Cheats.TinyMario ), + DEF_OPT_TOGGLE( optsCheatsStr[9], &Cheats.ForeverShell ), }; diff --git a/src/pc/cheats.h b/src/pc/cheats.h index eaf71ab4..52323395 100644 --- a/src/pc/cheats.h +++ b/src/pc/cheats.h @@ -13,6 +13,7 @@ struct CheatList { bool ExitAnywhere; bool HugeMario; bool TinyMario; + bool ForeverShell; }; extern struct CheatList Cheats;