]> git.donarmstrong.com Git - lilypond.git/blobdiff - scripts/build/create-weblinks-itexi.py
Web: enable Japanese website.
[lilypond.git] / scripts / build / create-weblinks-itexi.py
index 318bc10426c5b59b4c5fdc86750df595bcffc8a5..68e6ef95664945d700168c2a1f7488c75f63f598 100644 (file)
@@ -15,14 +15,11 @@ depth = "../"
 ### translation data -- shouldn't be here; see issue
 ### http://code.google.com/p/lilypond/issues/detail?id=1050
 
-# don't add your language to this list unless you have all the
-# items.
-# Hmm, is this a feature -- why not keep original english as a fallback?
-langs = ['', 'es', 'fr', 'nl']
+langs = ['', 'de', 'es', 'fr', 'hu', 'it', 'ja', 'nl']
 
 # Get/update node translations
 '''
-for i in es fr nl de hu ja it; do
+for i in de es fr hu it ja nl; do
     echo "'"$i"': {"
     (echo '--' ; grep -nH -B1 translationof Documentation/$i/web/* ) \
         | pytt '^--\n.*@(?:unnum|sub)[^ ]* (.*)\n.*@translationof (.*)\n' "'\2': '\1',\n" \
@@ -32,6 +29,32 @@ done
 '''
 
 translations = {
+    'de': {
+        'Source': 'Quellen',
+        'Learning': 'Einführung',
+        'Music glossary': 'Glossar',
+        'Essay': 'Aufsatz',
+        'Notation': 'Notation',
+        'Usage': 'Benutzung',
+        'Snippets': 'Schnipsel',
+        'Web': 'Web',
+        'Changes': 'Änderungen',
+
+        'Extending': 'Erweitern',
+        'Internals': 'Interna',
+        'Contributor': 'Beitragen',
+
+        ' (split HTML)': ' (geteiltes HTML)',
+        ' (big HTML)': ' (großes HTML)',
+
+        'Regression tests for ': 'Regressionstests für ',
+        'PDF of regtests for ': 'PDF der Regressionstests für ',
+        'MusicXML Regression tests for ': 'MusicXML Regressionstests für ',
+        'PDF of MusicXML regtests for ': 'PDF der MusicXML Regressionstests für ',
+
+        'Doc tarball for ': 'Dokumentation tar-gepackt für ',
+        ' (did not exist in 2.12)': ' (nicht existent in 2.12)',
+        },
     'es': {
         'Source': 'Código fuente',
 
@@ -85,50 +108,6 @@ translations = {
 
         'Doc tarball for ': 'Archive de la documentation pour ',
         ' (did not exist in 2.12)': ' (non disponible pour la version 2.12)',
-        },
-    'nl': {
-        'Source': 'Broncode',
-
-        'Learning': 'Beginnen',
-        'Music glossary': 'Terminologie',
-        'Essay': 'Essay',
-        'Notation': 'Notatie',
-        'Usage': 'Gebruik',
-        'Snippets': 'Snippers',
-        'Web': 'Web',
-        'Changes': 'Veranderingen',
-        'Extending': 'Uitbreidingen',
-        'Internals': 'Internals',
-        'Contributor': 'Contributor',
-
-# keep the spaces!
-        ' (split HTML)': ' (opgesplitste HTML)',
-        ' (big HTML)': ' (grote pagina HTML)',
-
-        'Regression tests for ': 'Regressietesten voor ',
-        'PDF of regtests for ': 'PDF van regressietesten voor ',
-        'MusicXML Regression tests for ': 'MusicXML regressietesten voor ',
-        'PDF of MusicXML regtests for ': 'MusicXML regressietesten voor ',
-
-        'Doc tarball for ': 'Tarball met documentation voor ',
-        ' (did not exist in 2.12)': ' (bestond nog niet in 2.12)',
-     },
-    'de': {
-        'Source': 'Quellen',
-        'Learning': 'Einführung',
-        'Music glossary': 'Glossar',
-        'Essay': 'Aufsatz',
-        'Notation': 'Notation',
-        'Usage': 'Benutzung',
-        'Snippets': 'Schnipsel',
-        'Web': 'Web',
-        'Changes': 'Änderungen',
-
-        #TODO
-        'Extending': 0,
-        'Internals': 'Interna',
-        'Contributor': 0,
-
         },
     'hu': {
         'Source': 'Forrás',
@@ -146,6 +125,16 @@ translations = {
         'Internals': 'Belső működés',
         'Contributor': 0,
 
+        ' (split HTML)': 0,
+        ' (big HTML)': 0,
+
+        'Regression tests for ': 0,
+        'PDF of regtests for ': 0,
+        'MusicXML Regression tests for ': 0,
+        'PDF of MusicXML regtests for ': 0,
+
+        'Doc tarball for ': 0,
+        ' (did not exist in 2.12)': 0,
         },
     'ja': {
         'Source': 'ソース',
@@ -159,11 +148,50 @@ translations = {
         'Changes': '変更点',
 
         #TODO
-        'Extending': 0,
+        'Extending': '拡張',
         'Internals': '内部リファレンス',
-        'Contributor': 0,
+        'Contributor': '貢献者向けガイド',
+
+# keep the spaces!
+        ' (split HTML)': ' (ページ毎に分割された HTML)',
+        ' (big HTML)': ' (1 つの大きな HTML)',
+
+        'Regression tests for ': '回帰テスト バージョン ',
+        'PDF of regtests for ': '回帰テスト (PDF 版) バージョン ',
+        'MusicXML Regression tests for ': 'MusicXML 回帰テスト バージョン ',
+        'PDF of MusicXML regtests for ': 'MusicXML 回帰テスト (PDF 版) バージョン ',
+
+        'Doc tarball for ': 'ドキュメント アーカイブ バージョン ',
+        ' (did not exist in 2.12)': ' (バージョン 2.12 には存在しません)',
 
         },
+    'nl': {
+        'Source': 'Broncode',
+
+        'Learning': 'Beginnen',
+        'Music glossary': 'Terminologie',
+        'Essay': 'Essay',
+        'Notation': 'Notatie',
+        'Usage': 'Gebruik',
+        'Snippets': 'Snippers',
+        'Web': 'Web',
+        'Changes': 'Veranderingen',
+        'Extending': 'Uitbreidingen',
+        'Internals': 'Internals',
+        'Contributor': 'Contributor',
+
+# keep the spaces!
+        ' (split HTML)': ' (opgesplitste HTML)',
+        ' (big HTML)': ' (grote pagina HTML)',
+
+        'Regression tests for ': 'Regressietesten voor ',
+        'PDF of regtests for ': 'PDF van regressietesten voor ',
+        'MusicXML Regression tests for ': 'MusicXML regressietesten voor ',
+        'PDF of MusicXML regtests for ': 'MusicXML regressietesten voor ',
+
+        'Doc tarball for ': 'Tarball met documentation voor ',
+        ' (did not exist in 2.12)': ' (bestond nog niet in 2.12)',
+     },
     }
 
 
@@ -212,10 +240,17 @@ for line in version_contents:
 
 VERSION = str(major)+'.'+str(minor)+'.'+str(patch)
 
+def _ (string, lang):
+    return translations.get (lang.split ('_')[0], {}).get (string, string)
+
+getTrans = _
+# let's not barf, but print a warning when something's missing
 def getTrans(text, lang):
-    if (lang != ''):
-        text = translations[lang][text]
-    return text
+    trans = _ (text, lang)
+    if not trans:
+        trans = text
+        sys.stderr.write ('create-weblinks-itexi: warning: [%(lang)s]: translation missing for: %(text)s\n' % locals ())
+    return trans
 
 def macroLang(name, lang):
     if (lang != ''):
@@ -309,6 +344,12 @@ def translateNameToUrl(manual, version):
         else:
             return ''
 
+def addLang(url, lang):
+    if lang:
+        base, ext = os.path.splitext(url)
+        return base + '.' + lang + ext
+    else:
+        return url
 
 def make_manual_links(name, version, lang):
     """Here is where all the macros manualStableLearningSplit,
@@ -342,27 +383,39 @@ def make_manual_links(name, version, lang):
                 "http://lilypond.org",
                 mshort+getTrans(" (did not exist in 2.12)",lang))
             continue
-        make_ver_link(macroLang("manual"+name+mshort+'Pdf',lang),
-                  url + '.pdf',
-                  getTrans(manual.capitalize(),lang) + '.pdf')
-        make_ver_link(macroLang("manual"+name+mshort+'Split',lang),
-                  url + '/index.html',
-                  getTrans(manual.capitalize(),lang) +
-                  getTrans(' (split HTML)',lang))
-        make_ver_link(macroLang("manual"+name+mshort+'Big',lang),
-                  url + '-big-page.html',
-                  getTrans(manual.capitalize(),lang) +
-                  getTrans(' (big HTML)',lang))
        # this is stupid and I shouldn't have bothered trying
        # to support the 2.12 docs and it will be deleted once
        # 2.14 is out and the website won't be visible to users
         # until 2.14 is out.  -gp
         if (url.endswith('.html')):
+            make_ver_link(macroLang("manual"+name+mshort+'Pdf',lang),
+                      addLang(url, lang),
+                      getTrans(manual.capitalize(),lang) + '.pdf')
+            make_ver_link(macroLang("manual"+name+mshort+'Split',lang),
+                      addLang(url, lang),
+                      getTrans(manual.capitalize(),lang) +
+                      getTrans(' (split HTML)',lang))
+            make_ver_link(macroLang("manual"+name+mshort+'Big',lang),
+                      addLang(url, lang),
+                      getTrans(manual.capitalize(),lang) +
+                      getTrans(' (big HTML)',lang))
             newurl = url
         else:
+            make_ver_link(macroLang("manual"+name+mshort+'Pdf',lang),
+                      # TODO: this is an even stupider way of doing it
+                      addLang(url+'.pdf', lang),
+                      getTrans(manual.capitalize(),lang) + '.pdf')
+            make_ver_link(macroLang("manual"+name+mshort+'Split',lang),
+                      addLang(url + '/index.html', lang),
+                      getTrans(manual.capitalize(),lang) +
+                      getTrans(' (split HTML)',lang))
+            make_ver_link(macroLang("manual"+name+mshort+'Big',lang),
+                      addLang(url + '-big-page.html', lang),
+                      getTrans(manual.capitalize(),lang) +
+                      getTrans(' (big HTML)',lang))
             newurl = url + '/index.html'
         make_ver_link(macroLang("manual"+name+mshort+'SplitNoName',lang),
-                  newurl,
+                  addLang(newurl, lang),
                   getTrans(manual.capitalize(),lang))
 
 def make_regtest_links(name, version, lang):
@@ -379,9 +432,21 @@ def make_regtest_links(name, version, lang):
     make_ver_link(macroLang("regtest"+name+"Xml", lang),
         url+"musicxml/collated-files.html",
         getTrans("MusicXML Regression tests for ", lang)+version)
+    make_ver_link(macroLang("regtest"+name+"Abc", lang),
+        url+"abc2ly/collated-files.html",
+        getTrans("abc2ly Regression tests for ", lang)+version)
+    make_ver_link(macroLang("regtest"+name+"LilypondBook", lang),
+        url+"lilypond-book/collated-files.html",
+        getTrans("lilypond-book Regression tests for ", lang)+version)
     make_ver_link(macroLang("regtest"+name+"XmlPdf", lang),
-         url+"musicxml/collated-files.html",
+         url+"musicxml/collated-files.pdf",
         getTrans("PDF of MusicXML regtests for ", lang)+version)
+    make_ver_link(macroLang("regtest"+name+"AbcPdf", lang),
+         url+"abc2ly/collated-files.pdf",
+        getTrans("PDF of abc2ly regtests for ", lang)+version)
+    make_ver_link(macroLang("regtest"+name+"LilypondBookPdf", lang),
+         url+"lilypond-book/collated-files.pdf",
+        getTrans("PDF of lilypond-book regtests for ", lang)+version)
 
 def make_doctarball_links(name, version, lang):
     url = depth + "download/binaries/documentation/lilypond-"