diff options
author | marc <a01200356@itesm.mx> | 2016-12-13 20:55:56 -0600 |
---|---|---|
committer | marc <a01200356@itesm.mx> | 2016-12-13 20:59:31 -0600 |
commit | 93233c786a1970b11a2f42e5afb3e3a2d8814505 (patch) | |
tree | b88d444864ba85d587b53081f7e7ef02e7a78278 | |
parent | f62ce21f50b540315a708ebfbf36878ddec9d1c4 (diff) | |
download | searxng-93233c786a1970b11a2f42e5afb3e3a2d8814505.tar.gz searxng-93233c786a1970b11a2f42e5afb3e3a2d8814505.zip |
Refactor search language preference.
-rw-r--r-- | searx/preferences.py | 36 |
1 files changed, 22 insertions, 14 deletions
diff --git a/searx/preferences.py b/searx/preferences.py index b27cfb7f4..7dc0e3172 100644 --- a/searx/preferences.py +++ b/searx/preferences.py @@ -59,18 +59,7 @@ class EnumStringSetting(Setting): self._validate_selection(self.value) def parse(self, data): - if data not in self.choices and data != self.value: - # hack to give some backwards compatibility with old language cookies - data = str(data).replace('_', '-') - lang = data[:2] - if data in self.choices: - pass - elif lang in self.choices: - data = lang - elif data == 'ar-XA': - data = 'ar-SA' - else: - data = 'all' + self._validate_selection(data) self.value = data @@ -106,6 +95,25 @@ class MultipleChoiceSetting(EnumStringSetting): resp.set_cookie(name, ','.join(self.value), max_age=COOKIE_MAX_AGE) +class SearchLanguageSetting(EnumStringSetting): + """Available choices may change, so user's value may not be in choices anymore""" + + def parse(self, data): + if data not in self.choices and data != self.value: + # hack to give some backwards compatibility with old language cookies + data = str(data).replace('_', '-') + lang = data.split('-')[0] + if data in self.choices: + pass + elif lang in self.choices: + data = lang + elif data == 'ar-XA': + data = 'ar-SA' + else: + data = 'all' + self.value = data + + class MapSetting(Setting): """Setting of a value that has to be translated in order to be storable""" @@ -227,8 +235,8 @@ class Preferences(object): super(Preferences, self).__init__() self.key_value_settings = {'categories': MultipleChoiceSetting(['general'], choices=categories), - 'language': EnumStringSetting(settings['search']['language'], - choices=LANGUAGE_CODES), + 'language': SearchLanguageSetting(settings['search']['language'], + choices=LANGUAGE_CODES), 'locale': EnumStringSetting(settings['ui']['default_locale'], choices=settings['locales'].keys() + ['']), 'autocomplete': EnumStringSetting(settings['search']['autocomplete'], |