forked from openlp/openlp
Detect language folder in source directory
This commit is contained in:
parent
1cd9fff9bd
commit
e70a09c93e
@ -72,15 +72,15 @@ class AppLocation(object):
|
|||||||
:param dir_type: The directory type you want, for instance the data directory. Default *AppLocation.AppDir*
|
:param dir_type: The directory type you want, for instance the data directory. Default *AppLocation.AppDir*
|
||||||
"""
|
"""
|
||||||
if dir_type == AppLocation.AppDir:
|
if dir_type == AppLocation.AppDir:
|
||||||
return get_frozen_path(os.path.abspath(os.path.split(sys.argv[0])[0]), os.path.split(openlp.__file__)[0])
|
return get_frozen_path(os.path.abspath(os.path.dirname(sys.argv[0])), os.path.dirname(openlp.__file__))
|
||||||
elif dir_type == AppLocation.PluginsDir:
|
elif dir_type == AppLocation.PluginsDir:
|
||||||
app_path = os.path.abspath(os.path.split(sys.argv[0])[0])
|
app_path = os.path.abspath(os.path.dirname(sys.argv[0]))
|
||||||
return get_frozen_path(os.path.join(app_path, 'plugins'),
|
return get_frozen_path(os.path.join(app_path, 'plugins'),
|
||||||
os.path.join(os.path.split(openlp.__file__)[0], 'plugins'))
|
os.path.join(os.path.dirname(openlp.__file__), 'plugins'))
|
||||||
elif dir_type == AppLocation.VersionDir:
|
elif dir_type == AppLocation.VersionDir:
|
||||||
return get_frozen_path(os.path.abspath(os.path.split(sys.argv[0])[0]), os.path.split(openlp.__file__)[0])
|
return get_frozen_path(os.path.abspath(os.path.dirname(sys.argv[0])), os.path.dirname(openlp.__file__))
|
||||||
elif dir_type == AppLocation.LanguageDir:
|
elif dir_type == AppLocation.LanguageDir:
|
||||||
app_path = get_frozen_path(os.path.abspath(os.path.split(sys.argv[0])[0]), _get_os_dir_path(dir_type))
|
app_path = get_frozen_path(os.path.abspath(os.path.dirname(sys.argv[0])), _get_os_dir_path(dir_type))
|
||||||
return os.path.join(app_path, 'i18n')
|
return os.path.join(app_path, 'i18n')
|
||||||
elif dir_type == AppLocation.DataDir and AppLocation.BaseDir:
|
elif dir_type == AppLocation.DataDir and AppLocation.BaseDir:
|
||||||
return os.path.join(AppLocation.BaseDir, 'data')
|
return os.path.join(AppLocation.BaseDir, 'data')
|
||||||
@ -140,23 +140,26 @@ def _get_os_dir_path(dir_type):
|
|||||||
"""
|
"""
|
||||||
Return a path based on which OS and environment we are running in.
|
Return a path based on which OS and environment we are running in.
|
||||||
"""
|
"""
|
||||||
|
# If running from source, return the language directory from the source directory
|
||||||
|
if dir_type == AppLocation.LanguageDir:
|
||||||
|
directory = os.path.abspath(os.path.join(os.path.dirname(openlp.__file__), '..', 'resources'))
|
||||||
|
if os.path.exists(directory):
|
||||||
|
return directory
|
||||||
if sys.platform == 'win32':
|
if sys.platform == 'win32':
|
||||||
if dir_type == AppLocation.DataDir:
|
if dir_type == AppLocation.DataDir:
|
||||||
return os.path.join(str(os.getenv('APPDATA')), 'openlp', 'data')
|
return os.path.join(str(os.getenv('APPDATA')), 'openlp', 'data')
|
||||||
elif dir_type == AppLocation.LanguageDir:
|
elif dir_type == AppLocation.LanguageDir:
|
||||||
return os.path.split(openlp.__file__)[0]
|
return os.path.dirname(openlp.__file__)
|
||||||
return os.path.join(str(os.getenv('APPDATA')), 'openlp')
|
return os.path.join(str(os.getenv('APPDATA')), 'openlp')
|
||||||
elif sys.platform == 'darwin':
|
elif sys.platform == 'darwin':
|
||||||
if dir_type == AppLocation.DataDir:
|
if dir_type == AppLocation.DataDir:
|
||||||
return os.path.join(str(os.getenv('HOME')),
|
return os.path.join(str(os.getenv('HOME')), 'Library', 'Application Support', 'openlp', 'Data')
|
||||||
'Library', 'Application Support', 'openlp', 'Data')
|
|
||||||
elif dir_type == AppLocation.LanguageDir:
|
elif dir_type == AppLocation.LanguageDir:
|
||||||
return os.path.split(openlp.__file__)[0]
|
return os.path.dirname(openlp.__file__)
|
||||||
return os.path.join(str(os.getenv('HOME')), 'Library', 'Application Support', 'openlp')
|
return os.path.join(str(os.getenv('HOME')), 'Library', 'Application Support', 'openlp')
|
||||||
else:
|
else:
|
||||||
if dir_type == AppLocation.LanguageDir:
|
if dir_type == AppLocation.LanguageDir:
|
||||||
for prefix in ['/usr/local', '/usr']:
|
directory = os.path.join('/usr', 'local', 'share', 'openlp')
|
||||||
directory = os.path.join(prefix, 'share', 'openlp')
|
|
||||||
if os.path.exists(directory):
|
if os.path.exists(directory):
|
||||||
return directory
|
return directory
|
||||||
return os.path.join('/usr', 'share', 'openlp')
|
return os.path.join('/usr', 'share', 'openlp')
|
||||||
|
@ -71,8 +71,7 @@ class LanguageManager(object):
|
|||||||
"""
|
"""
|
||||||
Find all available language files in this OpenLP install
|
Find all available language files in this OpenLP install
|
||||||
"""
|
"""
|
||||||
log.debug('Translation files: %s', AppLocation.get_directory(
|
log.debug('Translation files: %s', AppLocation.get_directory(AppLocation.LanguageDir))
|
||||||
AppLocation.LanguageDir))
|
|
||||||
trans_dir = QtCore.QDir(AppLocation.get_directory(AppLocation.LanguageDir))
|
trans_dir = QtCore.QDir(AppLocation.get_directory(AppLocation.LanguageDir))
|
||||||
file_names = trans_dir.entryList(['*.qm'], QtCore.QDir.Files, QtCore.QDir.Name)
|
file_names = trans_dir.entryList(['*.qm'], QtCore.QDir.Files, QtCore.QDir.Name)
|
||||||
# Remove qm files from the list which start with "qt_".
|
# Remove qm files from the list which start with "qt_".
|
||||||
|
Loading…
Reference in New Issue
Block a user