Skip to content

Commit

Permalink
Remove settings properly (#7676)
Browse files Browse the repository at this point in the history
  • Loading branch information
SmallJoker committed Sep 30, 2018
1 parent 18a8fbf commit a29bc8e
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 7 deletions.
7 changes: 1 addition & 6 deletions builtin/mainmenu/dlg_settings_advanced.lua
Expand Up @@ -977,12 +977,7 @@ local function handle_settings_buttons(this, fields, tabname, tabdata)
if fields["btn_restore"] then
local setting = settings[selected_setting]
if setting and setting.type ~= "category" then
if setting.type == "noise_params_2d"
or setting.type == "noise_params_3d" then
core.settings:set_np_group(setting.name, setting.default_table)
else
core.settings:set(setting.name, setting.default)
end
core.settings:remove(setting.name)
core.settings:write()
core.update_formspec(this:get_formspec())
end
Expand Down
12 changes: 11 additions & 1 deletion src/settings.cpp
Expand Up @@ -225,9 +225,13 @@ bool Settings::updateConfigObject(std::istream &is, std::ostream &os,
case SPE_KVPAIR:
it = m_settings.find(name);
if (it != m_settings.end() &&
(it->second.is_group || it->second.value != value)) {
(it->second.is_group || it->second.value != value)) {
printEntry(os, name, it->second, tab_depth);
was_modified = true;
} else if (it == m_settings.end()) {
// Remove by skipping
was_modified = true;
break;
} else {
os << line << "\n";
if (event == SPE_MULTILINE)
Expand All @@ -242,6 +246,10 @@ bool Settings::updateConfigObject(std::istream &is, std::ostream &os,
sanity_check(it->second.group != NULL);
was_modified |= it->second.group->updateConfigObject(is, os,
"}", tab_depth + 1);
} else if (it == m_settings.end()) {
// Remove by skipping
was_modified = true;
break;
} else {
printEntry(os, name, it->second, tab_depth);
was_modified = true;
Expand Down Expand Up @@ -901,6 +909,8 @@ bool Settings::remove(const std::string &name)
if (it != m_settings.end()) {
delete it->second.group;
m_settings.erase(it);

doCallbacks(name);
return true;
}

Expand Down

0 comments on commit a29bc8e

Please sign in to comment.