5 Documentation i18n module
10 def lang_file_name (p, langext, ext):
12 return p + '.' + langext + ext
16 def __init__ (self, code, name, webext=None, double_punct_char_sep='', html_filter=lambda s: s):
21 self.webext = self.code
24 self.double_punct_char_sep = double_punct_char_sep
25 self.html_filter = html_filter
27 def file_name (self, prefix, ext):
28 return lang_file_name (prefix, self.webext, ext)
31 # All language information needed for documentation i18n is defined
32 # here. For each 'Documentation/ab' directory containing docs
33 # translated in 'ab', there should be one entry in LANGUAGES.
35 site = LanguageDef ('en', 'English', webext='')
37 html_page_body = re.compile ('</?body>', re.M | re.I)
38 french_html_typo_rules = ((' :', ' :'),
43 def french_html_filter (page):
44 parts = html_page_body.split (page)
45 for r in french_html_typo_rules:
46 parts[1] = parts[1].replace (r[0], r[1])
47 return parts[0] + '<body>' + parts[1] + '</body>' + parts[2]
49 fr = LanguageDef ('fr', 'français', double_punct_char_sep=' ', html_filter = french_html_filter)
50 es = LanguageDef ('es', 'español')
51 de = LanguageDef ('de', 'deutsch')
53 # Outdated or broken translations may be disabled
54 # (please run 'make web-clean' before doing that):
57 LANGUAGES = (site, fr, es, de)
59 if __name__ == '__main__':
60 print ' '.join ([l.code for l in LANGUAGES if l.enabled and l.code != 'en'])