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:
parent
90b48887ed
commit
15b085b326
1 changed files with 9 additions and 5 deletions
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue