1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-05 16:39:44 +01:00

Fix duplicating ed_settings when opening editor menu second time

This fixes a bug where after loading in to the level editor, pressing
Esc and then switching your option to something other than the first
option, then pressing Esc again to close the menu, then pressing Esc
once more would not keep your menu option.

This is because the code that checks if Menu::ed_settings is already in
the stack doesn't account for if ed_settings is the current menu - the
current menu doesn't get put in to the stack.

In hindsight, maybe I could have designed the new menu system better so
the current menu IS on the stack, and/or should have used a
statically-allocated linked list for each menu name for the stack frames
(instead of an std::vector) and asserted if a menu that already existed
in the stack was created instead... that'll have to be done later,
though.
This commit is contained in:
Misa 2021-04-18 09:55:11 -07:00 committed by Ethan Lee
parent 90b48887ed
commit 15b085b326

View file

@ -4079,8 +4079,11 @@ void editorinput(void)
if (ed.settingsmod) if (ed.settingsmod)
{ {
bool edsettings_in_stack = false; bool edsettings_in_stack = game.currentmenuname == Menu::ed_settings;
for (size_t i = 0; i < game.menustack.size(); i++) if (!edsettings_in_stack)
{
size_t i;
for (i = 0; i < game.menustack.size(); ++i)
{ {
if (game.menustack[i].name == Menu::ed_settings) if (game.menustack[i].name == Menu::ed_settings)
{ {
@ -4088,6 +4091,7 @@ void editorinput(void)
break; break;
} }
} }
}
if (edsettings_in_stack) if (edsettings_in_stack)
{ {
game.returntomenu(Menu::ed_settings); game.returntomenu(Menu::ed_settings);