master #4

Merged
BRNSystems merged 3 commits from Mirrorlandia_minetest/minetest:master into master 2023-12-13 19:56:20 +01:00
2 changed files with 16 additions and 2 deletions
Showing only changes of commit 321bcf5c44 - Show all commits

@ -4124,6 +4124,7 @@ void Game::updateFrame(ProfilerGraph *graph, RunStats *stats, f32 dtime,
break; break;
if (formspec->getReferenceCount() == 1) { if (formspec->getReferenceCount() == 1) {
// See GUIFormSpecMenu::create what refcnt = 1 means
m_game_ui->deleteFormspec(); m_game_ui->deleteFormspec();
break; break;
} }

@ -138,11 +138,23 @@ void GUIFormSpecMenu::create(GUIFormSpecMenu *&cur_formspec, Client *client,
gui::IGUIEnvironment *guienv, JoystickController *joystick, IFormSource *fs_src, gui::IGUIEnvironment *guienv, JoystickController *joystick, IFormSource *fs_src,
TextDest *txt_dest, const std::string &formspecPrepend, ISoundManager *sound_manager) TextDest *txt_dest, const std::string &formspecPrepend, ISoundManager *sound_manager)
{ {
if (cur_formspec && cur_formspec->getReferenceCount() == 1) {
/*
Why reference count == 1? Reason:
1 on creation (see "drop()" remark below)
+1 for being a guiroot child
+1 when focused (CGUIEnvironment::setFocus)
Hence re-create the formspec when it's existing without any parent.
*/
cur_formspec->drop();
cur_formspec = nullptr;
}
if (cur_formspec == nullptr) { if (cur_formspec == nullptr) {
cur_formspec = new GUIFormSpecMenu(joystick, guiroot, -1, &g_menumgr, cur_formspec = new GUIFormSpecMenu(joystick, guiroot, -1, &g_menumgr,
client, guienv, client->getTextureSource(), sound_manager, fs_src, client, guienv, client->getTextureSource(), sound_manager, fs_src,
txt_dest, formspecPrepend); txt_dest, formspecPrepend);
cur_formspec->doPause = false;
/* /*
Caution: do not call (*cur_formspec)->drop() here -- Caution: do not call (*cur_formspec)->drop() here --
@ -151,12 +163,13 @@ void GUIFormSpecMenu::create(GUIFormSpecMenu *&cur_formspec, Client *client,
remaining reference (i.e. the menu was removed) remaining reference (i.e. the menu was removed)
and delete it in that case. and delete it in that case.
*/ */
} else { } else {
cur_formspec->setFormspecPrepend(formspecPrepend); cur_formspec->setFormspecPrepend(formspecPrepend);
cur_formspec->setFormSource(fs_src); cur_formspec->setFormSource(fs_src);
cur_formspec->setTextDest(txt_dest); cur_formspec->setTextDest(txt_dest);
} }
cur_formspec->doPause = false;
} }
void GUIFormSpecMenu::removeTooltip() void GUIFormSpecMenu::removeTooltip()