openlp/openlp/core/utils/languagemanager.py

146 lines
6.1 KiB
Python
Raw Normal View History

2010-04-16 22:06:28 +00:00
# -*- coding: utf-8 -*-
2012-12-29 09:35:24 +00:00
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
2010-04-16 22:06:28 +00:00
###############################################################################
# OpenLP - Open Source Lyrics Projection #
# --------------------------------------------------------------------------- #
2015-01-18 13:39:21 +00:00
# Copyright (c) 2008-2015 OpenLP Developers #
2010-04-16 22:06:28 +00:00
# --------------------------------------------------------------------------- #
# This program is free software; you can redistribute it and/or modify it #
# under the terms of the GNU General Public License as published by the Free #
# Software Foundation; version 2 of the License. #
# #
# This program is distributed in the hope that it will be useful, but WITHOUT #
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or #
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for #
# more details. #
# #
# You should have received a copy of the GNU General Public License along #
# with this program; if not, write to the Free Software Foundation, Inc., 59 #
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
###############################################################################
2010-06-29 07:07:03 +00:00
"""
2013-02-02 20:18:34 +00:00
The :mod:`languagemanager` module provides all the translation settings and language file loading for OpenLP.
2010-06-29 07:07:03 +00:00
"""
2010-04-16 22:06:28 +00:00
import logging
2012-05-19 15:10:05 +00:00
import re
import sys
2010-04-16 22:06:28 +00:00
from PyQt4 import QtCore, QtGui
2010-06-09 17:09:32 +00:00
from openlp.core.common import AppLocation, Settings, translate, is_win, is_macosx
2010-04-19 19:12:34 +00:00
log = logging.getLogger(__name__)
2010-04-16 22:06:28 +00:00
2013-02-02 20:18:34 +00:00
2010-04-16 22:06:28 +00:00
class LanguageManager(object):
"""
2010-06-08 15:38:09 +00:00
Helper for Language selection
2010-04-16 22:06:28 +00:00
"""
__qm_list__ = {}
auto_language = False
2010-04-16 22:06:28 +00:00
@staticmethod
2010-04-19 19:12:34 +00:00
def get_translator(language):
2010-06-29 07:07:03 +00:00
"""
Set up a translator to use in this instance of OpenLP
2014-03-17 19:05:55 +00:00
:param language: The language to load into the translator
2010-06-29 07:07:03 +00:00
"""
if LanguageManager.auto_language:
2010-04-16 22:06:28 +00:00
language = QtCore.QLocale.system().name()
lang_path = AppLocation.get_directory(AppLocation.LanguageDir)
2010-06-29 07:07:03 +00:00
app_translator = QtCore.QTranslator()
2011-04-23 15:15:01 +00:00
app_translator.load(language, lang_path)
# A translator for buttons and other default strings provided by Qt.
if not is_win() and not is_macosx():
2012-12-29 09:35:24 +00:00
lang_path = QtCore.QLibraryInfo.location(QtCore.QLibraryInfo.TranslationsPath)
2011-04-23 15:40:07 +00:00
default_translator = QtCore.QTranslator()
2013-08-31 18:17:38 +00:00
default_translator.load('qt_%s' % language, lang_path)
2011-04-23 15:40:07 +00:00
return app_translator, default_translator
2010-04-16 22:06:28 +00:00
@staticmethod
2010-04-19 19:12:34 +00:00
def find_qm_files():
2010-06-29 07:07:03 +00:00
"""
Find all available language files in this OpenLP install
"""
log.debug('Translation files: %s', AppLocation.get_directory(AppLocation.LanguageDir))
2012-12-29 09:35:24 +00:00
trans_dir = QtCore.QDir(AppLocation.get_directory(AppLocation.LanguageDir))
2014-04-03 12:38:39 +00:00
file_names = trans_dir.entryList(['*.qm'], QtCore.QDir.Files, QtCore.QDir.Name)
# Remove qm files from the list which start with "qt_".
2013-08-31 18:17:38 +00:00
file_names = [file_ for file_ in file_names if not file_.startswith('qt_')]
return list(map(trans_dir.filePath, file_names))
2010-04-16 22:06:28 +00:00
@staticmethod
2010-06-29 07:07:03 +00:00
def language_name(qm_file):
"""
Load the language name from a language file
2014-03-17 19:05:55 +00:00
:param qm_file: The file to obtain the name from
2010-06-29 07:07:03 +00:00
"""
translator = QtCore.QTranslator()
2010-06-29 07:07:03 +00:00
translator.load(qm_file)
2012-12-29 09:35:24 +00:00
return translator.translate('OpenLP.MainWindow', 'English', 'Please add the name of your language here')
2010-04-16 22:06:28 +00:00
@staticmethod
2010-04-19 19:12:34 +00:00
def get_language():
2010-06-29 07:07:03 +00:00
"""
Retrieve a saved language to use from settings
"""
2013-08-31 18:17:38 +00:00
language = Settings().value('core/language')
2012-05-19 15:10:05 +00:00
language = str(language)
2013-08-31 18:17:38 +00:00
log.info('Language file: \'%s\' Loaded from conf file' % language)
2012-05-19 15:10:05 +00:00
if re.match(r'[[].*[]]', language):
LanguageManager.auto_language = True
2012-05-19 15:10:05 +00:00
language = re.sub(r'[\[\]]', '', language)
2010-04-16 22:06:28 +00:00
return language
@staticmethod
2011-02-27 09:53:47 +00:00
def set_language(action, message=True):
2010-06-29 07:07:03 +00:00
"""
Set the language to translate OpenLP into
2014-03-17 19:05:55 +00:00
:param action: The language menu option
:param message: Display the message option
2010-06-29 07:07:03 +00:00
"""
2013-08-31 18:17:38 +00:00
language = 'en'
if action:
2013-08-31 18:17:38 +00:00
action_name = str(action.objectName())
if action_name == 'autoLanguageItem':
LanguageManager.auto_language = True
else:
LanguageManager.auto_language = False
qm_list = LanguageManager.get_qm_list()
2013-08-31 18:17:38 +00:00
language = str(qm_list[action_name])
if LanguageManager.auto_language:
2013-08-31 18:17:38 +00:00
language = '[%s]' % language
Settings().setValue('core/language', language)
log.info('Language file: \'%s\' written to conf file' % language)
2011-02-27 09:53:47 +00:00
if message:
QtGui.QMessageBox.information(None,
2014-03-20 19:10:31 +00:00
translate('OpenLP.LanguageManager', 'Language'),
translate('OpenLP.LanguageManager', 'Please restart OpenLP to use your new '
'language setting.'))
2010-04-16 22:06:28 +00:00
@staticmethod
2010-04-19 19:12:34 +00:00
def init_qm_list():
2010-06-29 07:07:03 +00:00
"""
Initialise the list of available translations
"""
LanguageManager.__qm_list__ = {}
2010-06-29 07:07:03 +00:00
qm_files = LanguageManager.find_qm_files()
for counter, qmf in enumerate(qm_files):
reg_ex = QtCore.QRegExp("^.*i18n/(.*).qm")
if reg_ex.exactMatch(qmf):
2013-08-31 18:17:38 +00:00
name = '%s' % reg_ex.cap(1)
LanguageManager.__qm_list__['%#2i %s' % (counter + 1, LanguageManager.language_name(qmf))] = name
2010-04-16 22:06:28 +00:00
@staticmethod
2010-04-19 19:12:34 +00:00
def get_qm_list():
2010-06-29 07:07:03 +00:00
"""
Return the list of available translations
"""
if not LanguageManager.__qm_list__:
2010-04-19 19:12:34 +00:00
LanguageManager.init_qm_list()
return LanguageManager.__qm_list__