#!@PYTHON@
+# -*- coding: utf-8 -*-
# create-version-itexi.py
""" when being called on lilypond.org, pass it the location of the
import os
import glob
-
-
-# FIXME: if the depth depends on the type of build, figure it
-# out automatically.
-### just like depth in our GNUmakefiles
-# these links are relative from /~graham/web/
-depth = "../../"
-# these links are relative from the v2.13 docs
-#depth = "../../../../"
-
+### translation data -- shouldn't be here; see issue
+### http://code.google.com/p/lilypond/issues/detail?id=1050
+
+import langdefs
+# GUB only has python 2.4 !!!
+# langs = [i.code if i.code != 'en' else '' for i in langdefs.WEB_LANGUAGES]
+langs = []
+for lang in langdefs.WEB_LANGUAGES:
+ if lang.code == 'en':
+ langs.append('')
+ else:
+ langs.append(lang.code)
+
+
+# these links are relative from /website/ on lilypond.org
+depth = "../"
+
+# Get/update node translations
+'''
+for i in cs de es fr hu it ja nl zh; do
+ echo "'"$i"': {"
+ (echo '--' ; grep -nH -B1 translationof Documentation/$i/web/* ) \
+ | pytt '^--\n.*@(?:unnum|sub)[^ ]* (.*)\n.*@translationof (.*)\n' "'\2': '\1',\n" \
+ | grep -E 'Source|Learning|Glossary|Essay|Notation|Usage|Snippets|Web|Changes|Extending|Internals|Contributor'
+ echo "},"
+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',
+
+ 'Learning': 'Aprendizaje',
+ 'Music glossary': 'Glosario',
+ 'Essay': 'Ensayo',
+ 'Notation': 'Notación',
+ 'Usage': 'Utilización',
+ 'Snippets': 'Fragmentos',
+ 'Web': 'Web',
+ 'Changes': 'Cambios',
+ 'Extending': 'Extensión',
+ 'Internals': 'Funcionamiento interno',
+ 'Contributor': 'Guía del colaborador',
+
+# keep the spaces!
+ ' (split HTML)': ' (HTML seccionado)',
+ ' (big HTML)': ' (HTML monolítico)',
+
+ 'Regression tests for ': 'Pruebas de regresión para ',
+ 'PDF of regtests for ': 'Pruebas en PDF para ',
+ 'MusicXML Regression tests for ': 'Pruebas de regresión de MusicXML para ',
+ 'PDF of MusicXML regtests for ': 'Pruebas de MusicXML en PDF para ',
+
+ 'Doc tarball for ': 'Tarball de la documentación para ',
+ ' (did not exist in 2.12)': ' (no existía en la versión 2.12)',
+ },
+ 'fr': {
+ 'Source': 'Sources',
+
+ 'Learning': 'Initiation',
+ 'Music glossary': 'Glossaire',
+ 'Essay': 'Essai',
+ 'Notation': 'Notation',
+ 'Usage': 'Utilisation',
+ 'Snippets': 'Morceaux choisis',
+ 'Web': 'Web',
+ 'Changes': 'Nouveautés',
+ 'Extending': 'Extension',
+ 'Internals': 'Propriétés internes',
+ 'Contributor': 'Guide du contributeur',
+
+# keep the spaces!
+ ' (split HTML)': ' (HTML multipages)',
+ ' (big HTML)': ' (HTML en page unique)',
+
+ 'Regression tests for ': 'Tests de régression pour ',
+ 'PDF of regtests for ': 'PDF des tests de régression pour ',
+ 'MusicXML Regression tests for ': 'Tests de régression de MusicXML pour ',
+ 'PDF of MusicXML regtests for ': 'PDF des tests de régression de MusicXML pour ',
+
+ 'Doc tarball for ': 'Archive de la documentation pour ',
+ ' (did not exist in 2.12)': ' (non disponible pour la version 2.12)',
+ },
+ 'hu': {
+ 'Source': 'Forrás',
+ 'Learning': 'Tankönyv',
+ 'Music glossary': 'Fogalomtár',
+ 'Essay': 'Esszé',
+ 'Notation': 'Kottaírás',
+ 'Usage': 'Használat',
+ 'Snippets': 'Kódrészletek',
+ 'Web': 'Web',
+ 'Changes': 'Változások',
+ 'Extending': 'Bővítés',
+ 'Internals': 'Belső működés',
+ 'Contributor': 'Közreműködés',
+
+ ' (split HTML)': ' (HTML oldalak)',
+ ' (big HTML)': ' (egy nagy HTML oldal)',
+
+ 'Regression tests for ': 'Regressziós tesztek - verzió: ',
+ 'PDF of regtests for ': 'PDF formátumban - verzió: ',
+ 'MusicXML Regression tests for ': 'MusicXML regressziós tesztek - verzió: ',
+ 'PDF of MusicXML regtests for ': 'PDF formátumban - verzió: ',
+
+ 'Doc tarball for ': 'Tömörített csomag - verzió: ',
+ ' (did not exist in 2.12)': ' (nem létezett a 2.12-es verzióban)',
+ },
+ 'ja': {
+ 'Source': 'ソース',
+ 'Learning': '学習',
+ 'Music glossary': '用語集',
+ 'Essay': 'エッセー',
+ 'Notation': '記譜法',
+ 'Usage': '使用方法',
+ 'Snippets': 'コード断片集',
+ 'Web': 'Web',
+ 'Changes': '変更点',
+
+ #TODO
+ 'Extending': '拡張',
+ 'Internals': '内部リファレンス',
+ '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)',
+ },
+ 'zh': {
+ 'Source': '源码',
+ 'Learning': '学习',
+ 'Music glossary': '音乐术语表',
+ 'Essay': '文章',
+ 'Notation': '记谱法',
+ 'Usage': '使用',
+ 'Snippets': '片断',
+ 'Web': 'Web',
+ 'Changes': '变化',
+
+ 'Extending': '扩展',
+ 'Internals': '内部机制',
+ 'Contributor': '贡献者',
+
+# keep the spaces!
+ ' (split HTML)': ' (分开的 HTML)',
+ ' (big HTML)': ' (大的 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 中不存在)',
+ },
+ }
+
+
+
+
+### actual program
VERSION_STABLE = ""
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):
+ 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 != ''):
+ return name + '-' + lang
+ return name
+
def make_macro(name, string):
print "@macro", name
print string
string += "}"
make_macro(name, string)
-def make_download_source(name, vstring, version):
+def make_download_source(name, vstring, version, lang):
string = "@uref{http://download.linuxaudio.org/lilypond/sources/"
string += vstring + "/"
string += "lilypond-" + version + ".tar.gz"
string += ", "
- string += "Source: lilypond-" + version + ".tar.gz"
+ string += getTrans("Source", lang)
+ string += ": lilypond-" + version + ".tar.gz"
string += "}"
- make_macro(name, string)
+ make_macro(macroLang(name,lang), string)
def make_all_downloads(macroName, version):
make_download("download"+macroName+"LinuxNormal", "linux-x86/",
- "linux-x86.sh", version, "1", "Linux x86")
+ "linux-x86.sh", version, "1", "GNU/Linux x86")
make_download("download"+macroName+"LinuxBig", "linux-64/",
- "linux-64.sh", version, "1", "Linux 64")
+ "linux-64.sh", version, "1", "GNU/Linux 64")
make_download("download"+macroName+"LinuxPPC", "linux-ppc/",
- "linux-ppc.sh", version, "1", "Linux PPC")
+ "linux-ppc.sh", version, "1", "GNU/Linux PPC")
make_download("download"+macroName+"FreeBSDNormal", "freebsd-x86/",
"freebsd-x86.sh", version, "1", "FreeBSD i386")
ver_minor = ver_split[0] + '.' + ver_split[1]
url = depth + "doc/v" + ver_minor + "/Documentation/"
- if (ver_minor == '2.13'):
- return url+manual
if (ver_minor == '2.12'):
if (manual=='learning'):
return url+'user/lilypond-learning'
return url+'user/lilypond/Interfaces-for-programmers.html'
else:
return ''
+ else:
+ return url+manual
-
-def make_manual_links(name, version):
+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,
+ manualStableLearningBig, manualStableLearningSplitNoName, etc. are
+ created on the fly. Hopefully this documentation string will help
+ others a bit while grepping for those.
+ """
for m in manuals:
manual = m
+ # TODO: this is a stupid way of doing it
if (m=='music-glossary'):
mshort = 'Glossary'
else:
mshort = m.capitalize()
+ if (manual=='music-glossary'):
+ manual = 'Music glossary'
url = translateNameToUrl(m, version)
if (url == ''):
# can't have a comma here due to texinfo
- make_ver_link("manual"+name+mshort+'Pdf',
+ make_ver_link(macroLang("manual"+name+mshort+'Pdf',lang),
"http://lilypond.org",
- mshort+" (did not exist in 2.12)")
- make_ver_link("manual"+name+mshort+'Split',
+ mshort+getTrans(" (did not exist in 2.12)",lang))
+ make_ver_link(macroLang("manual"+name+mshort+'Split',lang),
"http://lilypond.org",
- mshort+" (did not exist in 2.12)")
- make_ver_link("manual"+name+mshort+'Big',
+ mshort+getTrans(" (did not exist in 2.12)",lang))
+ make_ver_link(macroLang("manual"+name+mshort+'Big',lang),
"http://lilypond.org",
- mshort+" (did not exist in 2.12)")
- make_ver_link("manual"+name+mshort+'SplitNoName',
+ mshort+getTrans(" (did not exist in 2.12)",lang))
+ make_ver_link(macroLang("manual"+name+mshort+'SplitNoName',lang),
"http://lilypond.org",
- mshort+" (did not exist in 2.12)")
+ mshort+getTrans(" (did not exist in 2.12)",lang))
continue
- make_ver_link("manual"+name+mshort+'Pdf',
- url + '.pdf',
- manual.capitalize() + '.pdf')
- make_ver_link("manual"+name+mshort+'Split',
- url + '/index.html',
- manual.capitalize() + ' (split HTML)')
- make_ver_link("manual"+name+mshort+'Big',
- url + '-big-page.html',
- manual.capitalize() + ' (big HTML)')
- # 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
+ # 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("manual"+name+mshort+'SplitNoName',
- newurl,
- manual.capitalize())
+ make_ver_link(macroLang("manual"+name+mshort+'SplitNoName',lang),
+ addLang(newurl, lang),
+ getTrans(manual.capitalize(),lang))
-def make_regtest_links(name, version):
+def make_regtest_links(name, version, lang):
ver_split = version.split('.')
ver_minor = ver_split[0] + '.' + ver_split[1]
url = depth + "doc/v" + ver_minor + "/input/regression/"
- make_ver_link("regtest"+name, url+"collated-files.html",
- "Regression tests for "+version)
- make_ver_link("regtest"+name+"Pdf", url+"collated-files.pdf",
- "pdf of "+version+" regtests")
- make_ver_link("regtest"+name+"Xml", url+"musicxml/collated-files.html",
- "MusicXML Regression tests for "+version)
- make_ver_link("regtest"+name+"XmlPdf", url+"musicxml/collated-files.html",
- "pdf of "+version+" musicxml regtests")
-
-def make_doctarball_links(name, version):
+ make_ver_link(macroLang("regtest"+name, lang),
+ url+"collated-files.html",
+ getTrans("Regression tests for ", lang)+version)
+ make_ver_link(macroLang("regtest"+name+"Pdf", lang),
+ url+"collated-files.pdf",
+ getTrans("PDF of regtests for ", lang)+version)
+ 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.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-"
# ugly FIXME, but proper build number support isn't Critical.
url += version + "-1"
url += ".documentation.tar.bz2"
- make_ver_link("doctarball"+name, url, "Doc tarball for "+version)
+ make_ver_link(macroLang("doctarball"+name, lang),
+ url, getTrans("Doc tarball for ", lang)+version)
print "@c ************************ Download binaries ************"
make_all_downloads("Stable", VERSION_STABLE)
print "@c ************************ Download source ************"
# FIXME: icky hard-coding! -gp
-make_download_source("downloadStableSource", "v2.12", VERSION_STABLE)
-make_download_source("downloadDevelSource", "v2.13", VERSION_DEVEL)
+for lang in langs:
+ print "@c *********", lang, "***"
+ make_download_source("downloadStableSource","v2.14",VERSION_STABLE,lang)
+ make_download_source("downloadDevelSource","v2.15",VERSION_DEVEL,lang)
print "@c ************************ Manual links ************"
-make_manual_links("Stable", VERSION_STABLE)
-make_manual_links("Devel", VERSION_DEVEL)
-make_doctarball_links("Stable", VERSION_STABLE)
-make_doctarball_links("Devel", VERSION_DEVEL)
+for lang in langs:
+ print "@c *********", lang, "***"
+ make_manual_links("Stable", VERSION_STABLE,lang)
+ make_manual_links("Devel", VERSION_DEVEL,lang)
+
+ make_doctarball_links("Stable", VERSION_STABLE,lang)
+ make_doctarball_links("Devel", VERSION_DEVEL,lang)
print "@c ************************ Regtest links ************"
-make_regtest_links("Stable", VERSION_STABLE)
-make_regtest_links("Devel", VERSION_DEVEL)
+for lang in langs:
+ print "@c *********", lang, "***"
+ make_regtest_links("Stable", VERSION_STABLE,lang)
+ make_regtest_links("Devel", VERSION_DEVEL,lang)
+