4 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 an 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', _('French'), double_punct_char_sep=' ', html_filter = french_html_filter)
52 es = LanguageDef ('es', _('Spanish') )
53 de = LanguageDef ('de', _('German') )
54 #nl = LanguageDef ('nl', 'Nederlands')
56 # Outdated or broken translations may be disabled
57 # (please run 'make web-clean' before doing that):
60 LANGUAGES = (site, fr, es, de)
62 if __name__ == '__main__':
63 print ' '.join ([l.code for l in LANGUAGES if l.enabled and l.code != 'en'])