try to use locale.strxfrm

This commit is contained in:
Andreas Preikschat 2013-07-15 20:02:54 +02:00
parent 7bb5d6afbd
commit ad715fec29
2 changed files with 33 additions and 9 deletions

View File

@ -376,16 +376,21 @@ def format_time(text, local_time):
def get_locale_key(string): def get_locale_key(string):
""" """
Creates a key for case insensitive, locale aware string sorting. Creates a key for case insensitive, locale aware string sorting.
``string``
The corresponding string.
""" """
string = string.lower() string = string.lower()
# For Python 3 on platforms other than Windows ICU is not necessary. In those cases locale.strxfrm(str) can be used. # For Python 3 on platforms other than Windows ICU is not necessary. In those cases locale.strxfrm(str) can be used.
global ICU_COLLATOR if os.name == 'nt':
if ICU_COLLATOR is None: global ICU_COLLATOR
from languagemanager import LanguageManager if ICU_COLLATOR is None:
locale = LanguageManager.get_language() from .languagemanager import LanguageManager
icu_locale = icu.Locale(locale) language = LanguageManager.get_language()
ICU_COLLATOR = icu.Collator.createInstance(icu_locale) icu_locale = icu.Locale(language)
return ICU_COLLATOR.getSortKey(string) ICU_COLLATOR = icu.Collator.createInstance(icu_locale)
return ICU_COLLATOR.getSortKey(string)
return locale.strxfrm(string).encode()
def get_natural_key(string): def get_natural_key(string):

View File

@ -105,14 +105,33 @@ class TestUtils(TestCase):
# THEN: The file name should be cleaned. # THEN: The file name should be cleaned.
assert result == wanted_name, u'The file name should not contain any special characters.' assert result == wanted_name, u'The file name should not contain any special characters.'
def get_locale_key_test(self): def get_locale_key_windows_test(self):
""" """
Test the get_locale_key(string) function Test the get_locale_key(string) function
""" """
with patch(u'openlp.core.utils.languagemanager.LanguageManager.get_language') as mocked_get_language: with patch(u'openlp.core.utils.languagemanager.LanguageManager.get_language') as mocked_get_language, \
patch(u'openlp.core.utils.os') as mocked_os:
# GIVEN: The language is German # GIVEN: The language is German
# 0x00C3 (A with diaresis) should be sorted as "A". 0x00DF (sharp s) should be sorted as "ss". # 0x00C3 (A with diaresis) should be sorted as "A". 0x00DF (sharp s) should be sorted as "ss".
mocked_get_language.return_value = u'de' mocked_get_language.return_value = u'de'
mocked_os.name = u'nt'
unsorted_list = [u'Auszug', u'Aushang', u'\u00C4u\u00DFerung']
# WHEN: We sort the list and use get_locale_key() to generate the sorting keys
# THEN: We get a properly sorted list
test_passes = sorted(unsorted_list, key=get_locale_key) == [u'Aushang', u'\u00C4u\u00DFerung', u'Auszug']
assert test_passes, u'Strings should be sorted properly'
def get_locale_key_linux_test(self):
"""
Test the get_locale_key(string) function
"""
with patch(u'openlp.core.utils.languagemanager.LanguageManager.get_language') as mocked_get_language, \
patch(u'openlp.core.utils.os.name') as mocked_os:
# GIVEN: The language is German
# 0x00C3 (A with diaresis) should be sorted as "A". 0x00DF (sharp s) should be sorted as "ss".
mocked_get_language.return_value = u'de'
mocked_os.name = u'linux'
unsorted_list = [u'Auszug', u'Aushang', u'\u00C4u\u00DFerung'] unsorted_list = [u'Auszug', u'Aushang', u'\u00C4u\u00DFerung']
# WHEN: We sort the list and use get_locale_key() to generate the sorting keys # WHEN: We sort the list and use get_locale_key() to generate the sorting keys
# THEN: We get a properly sorted list # THEN: We get a properly sorted list