1
0
mirror of https://github.com/django/django.git synced 2025-10-25 06:36:07 +00:00

Added check when fetching and updating translations from Transifex

So as syntax errors in po files don't go unnoticed. Refs #20695.
This commit is contained in:
Claude Paroz
2013-07-03 16:03:11 +02:00
parent 8a679386c3
commit 63b2155919

View File

@@ -114,6 +114,9 @@ def lang_stats(resources=None, languages=None):
if p.returncode == 0: if p.returncode == 0:
# msgfmt output stats on stderr # msgfmt output stats on stderr
print("%s: %s" % (lang, errors.strip())) print("%s: %s" % (lang, errors.strip()))
else:
print("Errors happened when checking %s translation for %s:\n%s" % (
lang, name, errors))
def fetch(resources=None, languages=None): def fetch(resources=None, languages=None):
@@ -121,6 +124,7 @@ def fetch(resources=None, languages=None):
Fetch translations from Transifex, wrap long lines, generate mo files. Fetch translations from Transifex, wrap long lines, generate mo files.
""" """
locale_dirs = _get_locale_dirs() locale_dirs = _get_locale_dirs()
errors = []
for name, dir_ in locale_dirs: for name, dir_ in locale_dirs:
if resources and not name in resources: if resources and not name in resources:
@@ -140,8 +144,14 @@ def fetch(resources=None, languages=None):
po_path = '%(path)s/%(lang)s/LC_MESSAGES/django%(ext)s.po' % { po_path = '%(path)s/%(lang)s/LC_MESSAGES/django%(ext)s.po' % {
'path': dir_, 'lang': lang, 'ext': 'js' if name.endswith('-js') else ''} 'path': dir_, 'lang': lang, 'ext': 'js' if name.endswith('-js') else ''}
call('msgcat -o %s %s' % (po_path, po_path), shell=True) call('msgcat -o %s %s' % (po_path, po_path), shell=True)
mo_path = '%s.mo' % po_path[:-3] res = call('msgfmt -c -o %s.mo %s' % (po_path[:-3], po_path), shell=True)
call('msgfmt -o %s %s' % (mo_path, po_path), shell=True) if res != 0:
errors.append((name, lang))
if errors:
print("\nWARNING: Errors have occurred in following cases:")
for resource, lang in errors:
print("\tResource %s for language %s" % (resource, lang))
exit(1)
if __name__ == "__main__": if __name__ == "__main__":