summaryrefslogtreecommitdiff
path: root/src/settings_gui.cpp
diff options
context:
space:
mode:
authorfrosch <frosch@openttd.org>2012-11-08 11:20:32 +0000
committerfrosch <frosch@openttd.org>2012-11-08 11:20:32 +0000
commitdc930b6689f383e9b30bfe83b4639dbfade5fe27 (patch)
tree68ff4d8a67dd755d912a32567843c3943cdbc73d /src/settings_gui.cpp
parent69a62452beab943a4f95d0aead7207d3f9de0a44 (diff)
downloadopenttd-dc930b6689f383e9b30bfe83b4639dbfade5fe27.tar.xz
(svn r24672) -Add [FS#5356]: Remember the basic/advanced/expert filter selection.
Diffstat (limited to 'src/settings_gui.cpp')
-rw-r--r--src/settings_gui.cpp19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/settings_gui.cpp b/src/settings_gui.cpp
index 33ca7a109..62c834e64 100644
--- a/src/settings_gui.cpp
+++ b/src/settings_gui.cpp
@@ -1977,7 +1977,7 @@ struct GameSettingsWindow : QueryStringBaseWindow {
Scrollbar *vscroll;
- GameSettingsWindow(const WindowDesc *desc) : QueryStringBaseWindow(50), cur_restriction_mode(RM_BASIC)
+ GameSettingsWindow(const WindowDesc *desc) : QueryStringBaseWindow(50), cur_restriction_mode((RestrictionMode)_settings_client.gui.settings_restriction_mode)
{
static bool first_time = true;
@@ -2337,13 +2337,18 @@ struct GameSettingsWindow : QueryStringBaseWindow {
{
if (widget == WID_GS_RESTRICT_DROPDOWN) {
this->cur_restriction_mode = (RestrictionMode)index;
- if (!this->manually_changed_folding &&
- (this->cur_restriction_mode == RM_CHANGED_AGAINST_DEFAULT ||
+ if (this->cur_restriction_mode == RM_CHANGED_AGAINST_DEFAULT ||
this->cur_restriction_mode == RM_CHANGED_AGAINST_DEFAULT_WO_LOCAL ||
- this->cur_restriction_mode == RM_CHANGED_AGAINST_NEW)) {
- /* Expand all when selecting 'changes'. Update the filter state first, in case it becomes less restrictive in some cases. */
- _settings_main_page.UpdateFilterState(string_filter, false, this->cur_restriction_mode);
- _settings_main_page.UnFoldAll();
+ this->cur_restriction_mode == RM_CHANGED_AGAINST_NEW) {
+
+ if (!this->manually_changed_folding) {
+ /* Expand all when selecting 'changes'. Update the filter state first, in case it becomes less restrictive in some cases. */
+ _settings_main_page.UpdateFilterState(string_filter, false, this->cur_restriction_mode);
+ _settings_main_page.UnFoldAll();
+ }
+ } else {
+ /* Non-'changes' filter. Save as default. */
+ _settings_client.gui.settings_restriction_mode = this->cur_restriction_mode;
}
this->InvalidateData();
return;