From 95e5848d03b897e75511cfad971ff6842f1888e0 Mon Sep 17 00:00:00 2001 From: Benny Malengier Date: Thu, 5 Mar 2009 12:11:57 +0000 Subject: [PATCH] 2764: use pyenchant for testing installed spell check dictionaries svn: r12224 --- src/Spell.py | 34 ++++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/src/Spell.py b/src/Spell.py index ca8d49d43..58b07ee01 100644 --- a/src/Spell.py +++ b/src/Spell.py @@ -50,11 +50,19 @@ LOG = logging.getLogger(".Spell") #------------------------------------------------------------------------- import gtk +try: + import enchant + HAVE_ENCHANT = True +except ImportError: + HAVE_ENCHANT = False + try: import gtkspell HAVE_GTKSPELL = True except ImportError: HAVE_GTKSPELL = False + +if not HAVE_GTKSPELL: LOG.warn(_("Spelling checker is not installed")) #------------------------------------------------------------------------- @@ -166,8 +174,28 @@ class Spell: lang = locale.getlocale()[0] _installed_languages = {'off': _('None')} + + if HAVE_ENCHANT and HAVE_GTKSPELL: + #gtkspell depends on enchant but has no api to query the installed + #languages. Hence, we use enchant to do this if available. + for language in enchant.list_languages(): + try: + name = LANGUAGES[language] + except KeyError: + name = language + if name == language: + parts = name.split('_') + if len(parts) == 2: + try: + name = LANGUAGES[parts[0]] + name += ': ' + parts[1] + except KeyError: + pass + _installed_languages[language] = " ".join(name.split('_')) - if HAVE_GTKSPELL: + elif not HAVE_ENCHANT and HAVE_GTKSPELL: + #we try a hack to get the languages. We do this by trying all + #languages we know of. for lang_code, lang_name in LANGUAGES.items(): try: #work around gtkspell bug with tv @@ -175,6 +203,9 @@ class Spell: gtkspell.Spell(tv).set_language(lang_code) _installed_languages[lang_code] = lang_name except RuntimeError: + #FIXME: this does not work anymore since 10/2008!!! + #if pyenchant is installed we can avoid it, otherwise perhaps + # future gtkspell3 will offer a solution. pass def __init__(self, textview): @@ -209,7 +240,6 @@ class Spell: gtkspell_spell.detach() self._active_language = lang_code return - gtkspell_spell.set_language(lang_code) self._active_language = lang_code