5 Documentation i18n module
12 def lang_file_name (p, langext, ext):
14 return p + '.' + langext + ext
18 def __init__ (self, code, name, webext=None, double_punct_char_sep='', html_filter=lambda s: s):
23 self.webext = self.code
26 self.double_punct_char_sep = double_punct_char_sep
27 self.html_filter = html_filter
29 def file_name (self, prefix, ext):
30 return lang_file_name (prefix, self.webext, ext)
33 # All language information needed for documentation i18n is defined
34 # here. For each 'Documentation/ab' directory containing docs
35 # translated in 'ab', there should be one entry in LANGUAGES.
37 site = LanguageDef ('en', 'English', webext='')
39 html_page_body = re.compile ('</?body>', re.M | re.I)
40 french_html_typo_rules = ((' :', ' :'),
45 def french_html_filter (page):
46 parts = html_page_body.split (page)
47 for r in french_html_typo_rules:
48 parts[1] = parts[1].replace (r[0], r[1])
49 return parts[0] + '<body>' + parts[1] + '</body>' + parts[2]
51 fr = LanguageDef ('fr', 'français', double_punct_char_sep=' ', html_filter = french_html_filter)
52 es = LanguageDef ('es', 'español')
53 de = LanguageDef ('de', 'deutsch')
55 # Outdated or broken translations may be disabled
56 # (please run 'make web-clean' before doing that):
59 LANGUAGES = (site, fr, es, de)
61 if __name__ == '__main__':
62 print ' '.join ([l.code for l in LANGUAGES if l.enabled and l.code != 'en'])
73 if l.enabled and l.code != 'en':
74 t = gettext.translation('lilypond-doc',
75 os.environ['LYDOC_LOCALEDIR'],
77 translation[l.code] = t.gettext
79 if os.environ.has_key ('LYDOC_LOCALEDIR'):
80 sys.stderr.write ('langdefs.py: warning: lilypond-doc gettext domain not found.\n')
81 translation = dict ([(l.code, lambda x: x) for l in LANGUAGES])