def ui_l10n(input_files, output, base):
'''Generate pot file from lib/ui/*'''
output = open(output, 'w')
- Submenu = re.compile(r'^[^#]*Submenu\s+"([^"]*)"')
- Popupmenu = re.compile(r'^[^#]*PopupMenu\s+"[^"]+"\s+"([^"]*)"')
- IconPalette = re.compile(r'^[^#]*IconPalette\s+"[^"]+"\s+"([^"]*)"')
- Toolbar = re.compile(r'^[^#]*Toolbar\s+"[^"]+"\s+"([^"]*)"')
- Item = re.compile(r'[^#]*Item\s+"([^"]*)"')
- TableInsert = re.compile(r'[^#]*TableInsert\s+"([^"]*)"')
+ Submenu = re.compile(r'^[^#]*Submenu\s+"([^"]*)"', re.IGNORECASE)
+ Popupmenu = re.compile(r'^[^#]*PopupMenu\s+"[^"]+"\s+"([^"]*)"', re.IGNORECASE)
+ IconPalette = re.compile(r'^[^#]*IconPalette\s+"[^"]+"\s+"([^"]*)"', re.IGNORECASE)
+ Toolbar = re.compile(r'^[^#]*Toolbar\s+"[^"]+"\s+"([^"]*)"', re.IGNORECASE)
+ Item = re.compile(r'[^#]*Item\s+"([^"]*)"', re.IGNORECASE)
+ TableInsert = re.compile(r'[^#]*TableInsert\s+"([^"]*)"', re.IGNORECASE)
for src in input_files:
input = open(src)
for lineno, line in enumerate(input.readlines()):
def layouts_l10n(input_files, output, base, layouttranslations):
'''Generate pot file from lib/layouts/*.{layout,inc,module}'''
- out = open(output, 'w')
- Style = re.compile(r'^Style\s+(.*)', re.IGNORECASE)
- # include ???LabelString???, but exclude comment lines
- LabelString = re.compile(r'^[^#]*LabelString\S*\s+(.*)')
- GuiName = re.compile(r'\s*GuiName\s+(.*)')
- ListName = re.compile(r'\s*ListName\s+(.*)')
- CategoryName = re.compile(r'\s*Category\s+(.*)')
- NameRE = re.compile(r'DeclareLyXModule.*{(.*)}')
- InsetLayout = re.compile(r'^InsetLayout\s+\"?(.*)\"?')
- FlexCheck = re.compile(r'^Flex:(.*)')
- DescBegin = re.compile(r'#+\s*DescriptionBegin\s*$')
- DescEnd = re.compile(r'#+\s*DescriptionEnd\s*$')
- Category = re.compile(r'#Category: (.*)$')
- I18nPreamble = re.compile(r'\s*(Lang)|(Babel)Preamble\s*$')
- EndI18nPreamble = re.compile(r'\s*End(Lang)|(Babel)Preamble\s*$')
+ Style = re.compile(r'^\s*Style\s+(.*)\s*$', re.IGNORECASE)
+ # match LabelString, EndLabelString, LabelStringAppendix and maybe others but no comments
+ LabelString = re.compile(r'^[^#]*LabelString\S*\s+(.*)\s*$', re.IGNORECASE)
+ GuiName = re.compile(r'^\s*GuiName\s+(.*)\s*$', re.IGNORECASE)
+ ListName = re.compile(r'^\s*ListName\s+(.*)\s*$', re.IGNORECASE)
+ CategoryName = re.compile(r'^\s*Category\s+(.*)\s*$', re.IGNORECASE)
+ NameRE = re.compile(r'^\s*#\s*\\DeclareLyXModule.*{(.*)}$', re.IGNORECASE)
+ InsetLayout = re.compile(r'^InsetLayout\s+\"?(.*)\"?\s*$', re.IGNORECASE)
+ FlexCheck = re.compile(r'^Flex:(.*)', re.IGNORECASE)
+ DescBegin = re.compile(r'^\s*#DescriptionBegin\s*$', re.IGNORECASE)
+ DescEnd = re.compile(r'^\s*#\s*DescriptionEnd\s*$', re.IGNORECASE)
+ Category = re.compile(r'^\s*#\s*Category:\s+(.*)\s*$', re.IGNORECASE)
+ I18nPreamble = re.compile(r'^\s*((Lang)|(Babel))Preamble\s*$', re.IGNORECASE)
+ EndI18nPreamble = re.compile(r'^\s*End((Lang)|(Babel))Preamble\s*$', re.IGNORECASE)
I18nString = re.compile(r'_\(([^\)]+)\)')
- CounterFormat = re.compile(r'\s*PrettyFormat\s+"?(.*)"?')
- CiteFormat = re.compile(r'\s*CiteFormat')
- KeyVal = re.compile(r'^\s*_\w+\s+(.*)$')
- Float = re.compile(r'\s*Float')
- End = re.compile(r'\s*End')
- Comment = re.compile(r'\s*#')
-
+ CounterFormat = re.compile(r'^\s*PrettyFormat\s+"?(.*)"?\s*$', re.IGNORECASE)
+ CiteFormat = re.compile(r'^\s*CiteFormat', re.IGNORECASE)
+ KeyVal = re.compile(r'^\s*_\w+\s+(.*)\s*$')
+ Float = re.compile(r'^\s*Float\s*$', re.IGNORECASE)
+ UsesFloatPkg = re.compile(r'^\s*UsesFloatPkg\s+(.*)\s*$', re.IGNORECASE)
+ IsPredefined = re.compile(r'^\s*IsPredefined\s+(.*)\s*$', re.IGNORECASE)
+ End = re.compile(r'^\s*End', re.IGNORECASE)
+ Comment = re.compile(r'^(.*)#')
+ Translation = re.compile(r'^\s*Translation\s+(.*)\s*$', re.IGNORECASE)
+ KeyValPair = re.compile(r'\s*"(.*)"\s+"(.*)"')
+
+ oldlanguages = []
languages = []
keyset = set()
+ oldtrans = dict()
if layouttranslations:
linguas_file = os.path.join(base, 'po/LINGUAS')
for line in open(linguas_file).readlines():
- if Comment.search(line) == None:
+ res = Comment.search(line)
+ if res:
+ line = res.group(1)
+ if line.strip() != '':
languages.extend(line.split())
- # walon is not a known document language
- # FIXME: Do not hardcode, read from lib/languages!
- if 'wa' in languages:
- languages.remove('wa')
+ # read old translations if available
+ try:
+ input = open(output)
+ lang = ''
+ for line in input.readlines():
+ res = Comment.search(line)
+ if res:
+ line = res.group(1)
+ if line.strip() == '':
+ continue
+ res = Translation.search(line)
+ if res:
+ lang = res.group(1)
+ if lang not in languages:
+ oldlanguages.append(lang)
+ languages.append(lang)
+ oldtrans[lang] = dict()
+ continue
+ res = End.search(line)
+ if res:
+ lang = ''
+ continue
+ res = KeyValPair.search(line)
+ if res and lang != '':
+ key = res.group(1).decode('utf-8')
+ val = res.group(2).decode('utf-8')
+ key = key.replace('\\"', '"').replace('\\\\', '\\')
+ val = val.replace('\\"', '"').replace('\\\\', '\\')
+ oldtrans[lang][key] = val
+ keyset.add(key)
+ continue
+ print "Error: Unable to handle line:"
+ print line
+ except IOError:
+ print "Warning: Unable to open %s for reading." % output
+ print " Old translations will be lost."
+
+ # walon is not a known document language
+ # FIXME: Do not hardcode, read from lib/languages!
+ if 'wa' in languages:
+ languages.remove('wa')
+
+ out = open(output, 'w')
for src in input_files:
readingDescription = False
readingI18nPreamble = False
readingFloat = False
readingCiteFormats = False
+ isPredefined = False
+ usesFloatPkg = True
+ listname = ''
+ floatname = ''
descStartLine = -1
descLines = []
lineno = 0
if res != None:
string = res.group(1)
string = string.replace('_', ' ')
- if not layouttranslations:
- writeString(out, src, base, lineno, string)
+ # Style means something else inside a float definition
+ if not readingFloat:
+ if not layouttranslations:
+ writeString(out, src, base, lineno, string)
continue
res = LabelString.search(line)
if res != None:
if layouttranslations:
# gui name must only be added for floats
if readingFloat:
- keyset.add(string)
+ floatname = string
else:
writeString(out, src, base, lineno, string)
continue
if res != None:
string = res.group(1)
if layouttranslations:
- keyset.add(string.strip('"'))
+ listname = string.strip('"')
else:
writeString(out, src, base, lineno, string)
continue
if res != None:
readingFloat = True
continue
+ res = IsPredefined.search(line)
+ if res != None:
+ string = res.group(1).lower()
+ if string == 'true':
+ isPredefined = True
+ else:
+ isPredefined = False
+ continue
+ res = UsesFloatPkg.search(line)
+ if res != None:
+ string = res.group(1).lower()
+ if string == 'true':
+ usesFloatPkg = True
+ else:
+ usesFloatPkg = False
+ continue
res = CiteFormat.search(line)
if res != None:
readingCiteFormats = True
+ continue
res = End.search(line)
if res != None:
+ # If a float is predefined by the package and it does not need
+ # the float package then it uses the standard babel translations.
+ # This is even true for MarginFigure, MarginTable (both from
+ # tufte-book.layout) and Planotable, Plate (both from aguplus.inc).
+ if layouttranslations and readingFloat and usesFloatPkg and not isPredefined:
+ if floatname != '':
+ keyset.add(floatname)
+ if listname != '':
+ keyset.add(listname)
+ isPredefined = False
+ usesFloatPkg = True
+ listname = ''
+ floatname = ''
readingCiteFormats = False
readingFloat = False
+ continue
if readingCiteFormats:
res = KeyVal.search(line)
if res != None:
keys.append(key)
keys.sort()
+ ContextRe = re.compile(r'(.*)(\[\[.*\]\])')
+
print >> out, '''# This file has been automatically generated by po/lyx_pot.py.
-# PLEASE DO NOT MODIFY ANYTHING HERE! If you want to regenerate this file
-# from the translations, run `make ../lib/layouttranslations' in po.'''
+# PLEASE MODIFY ONLY THE LAGUAGES HAVING NO .po FILE! If you want to regenerate
+# this file from the translations, run `make ../lib/layouttranslations' in po.
+# Python polib library is needed for building the output file.
+#
+# This file should remain fixed during minor LyX releases.
+# For more comments see README.localization file.'''
for lang in languages:
print >> out, '\nTranslation %s' % lang
- poname = os.path.join(base, 'po/' + lang + '.po')
- po = polib.pofile(poname)
- # Iterate through po entries and not keys for speed reasons.
- # FIXME: The code is still too slow
- trans = dict()
- for entry in po:
- if not entry.translated():
- continue
- if entry.msgid in keys:
- key = entry.msgid.replace('\\', '\\\\').replace('"', '\\"')
- val = entry.msgstr.replace('\\', '\\\\').replace('"', '\\"')
- # some translators keep untranslated entries
- if val != key:
- trans[key] = val
+ if lang in oldtrans.keys():
+ trans = oldtrans[lang]
+ else:
+ trans = dict()
+ if not lang in oldlanguages:
+ poname = os.path.join(base, 'po/' + lang + '.po')
+ po = polib.pofile(poname)
+ # Iterate through po entries and not keys for speed reasons.
+ # FIXME: The code is still too slow
+ for entry in po:
+ if not entry.translated():
+ continue
+ if entry.msgid in keys:
+ key = entry.msgid
+ val = entry.msgstr
+ # some translators keep untranslated entries
+ if val != key:
+ trans[key] = val
for key in keys:
if key in trans.keys():
- val = trans[key]
+ val = trans[key].replace('\\', '\\\\').replace('"', '\\"')
+ key = key.replace('\\', '\\\\').replace('"', '\\"')
+ print >> out, '\t"%s" "%s"' % \
+ (key.encode('utf-8'), val.encode('utf-8'))
+ # also print untranslated entries to help translators
+ elif not lang in oldlanguages:
+ key = key.replace('\\', '\\\\').replace('"', '\\"')
+ res = ContextRe.search(key)
+ if res != None:
+ val = res.group(1)
+ else:
+ val = key
print >> out, '\t"%s" "%s"' % \
(key.encode('utf-8'), val.encode('utf-8'))
print >> out, 'End'
def languages_l10n(input_files, output, base):
'''Generate pot file from lib/languages'''
out = open(output, 'w')
- GuiName = re.compile(r'^[^#]*GuiName\s+(.*)')
+ GuiName = re.compile(r'^[^#]*GuiName\s+(.*)', re.IGNORECASE)
for src in input_files:
descStartLine = -1
def external_l10n(input_files, output, base):
'''Generate pot file from lib/external_templates'''
output = open(output, 'w')
- Template = re.compile(r'^Template\s+(.*)')
- GuiName = re.compile(r'\s*GuiName\s+(.*)')
- HelpTextStart = re.compile(r'\s*HelpText\s')
+ Template = re.compile(r'^Template\s+(.*)', re.IGNORECASE)
+ GuiName = re.compile(r'\s*GuiName\s+(.*)', re.IGNORECASE)
+ HelpTextStart = re.compile(r'\s*HelpText\s', re.IGNORECASE)
HelpTextSection = re.compile(r'\s*(\S.*)\s*$')
- HelpTextEnd = re.compile(r'\s*HelpTextEnd\s')
+ HelpTextEnd = re.compile(r'\s*HelpTextEnd\s', re.IGNORECASE)
i = -1
for src in input_files:
input = open(src)
def formats_l10n(input_files, output, base):
'''Generate pot file from configure.py'''
output = open(output, 'w')
- GuiName = re.compile(r'.*\Format\s+\S+\s+\S+\s+"([^"]*)"\s+(\S*)\s+.*')
- GuiName2 = re.compile(r'.*\Format\s+\S+\s+\S+\s+([^"]\S+)\s+(\S*)\s+.*')
+ GuiName = re.compile(r'.*\\Format\s+\S+\s+\S+\s+"([^"]*)"\s+(\S*)\s+.*', re.IGNORECASE)
+ GuiName2 = re.compile(r'.*\\Format\s+\S+\s+\S+\s+([^"]\S+)\s+(\S*)\s+.*', re.IGNORECASE)
input = open(input_files[0])
for lineno, line in enumerate(input.readlines()):
label = ""