X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=scripts%2Fbuild%2Fcreate-weblinks-itexi.py;h=68e6ef95664945d700168c2a1f7488c75f63f598;hb=b514097e85c99f5178b45ee2a37c81bdf0c1d85c;hp=d30dc35e82cd6415cfc879fb01e69d2fad944177;hpb=e677f31c808c81cf9e42c660471d2c7d31908c06;p=lilypond.git diff --git a/scripts/build/create-weblinks-itexi.py b/scripts/build/create-weblinks-itexi.py index d30dc35e82..68e6ef9566 100644 --- a/scripts/build/create-weblinks-itexi.py +++ b/scripts/build/create-weblinks-itexi.py @@ -15,16 +15,13 @@ 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', '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/*) \ + (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 "}," @@ -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', @@ -61,6 +84,7 @@ translations = { }, 'fr': { 'Source': 'Sources', + 'Learning': 'Initiation', 'Music glossary': 'Glossaire', 'Essay': 'Essai', @@ -69,50 +93,21 @@ translations = { 'Snippets': 'Morceaux choisis', 'Web': 'Web', 'Changes': 'Nouveautés', + 'Extending': 'Extension', 'Internals': 'Propriétés internes', - - #TODO - }, - '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', + 'Contributor': 'Guide du contributeur', # keep the spaces! - ' (split HTML)': ' (opgesplitste HTML)', - ' (big HTML)': ' (grote pagina HTML)', + ' (split HTML)': ' (HTML multipages)', + ' (big HTML)': ' (HTML en page unique)', - '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 ', + '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 ': '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', - 'Internals': 'Interna', - - #TODO + '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', @@ -124,9 +119,22 @@ translations = { 'Snippets': 'Kódrészletek', 'Web': 'Web', 'Changes': 'Változások', - 'Internals': 'Belső működés', #TODO + 'Extending': 0, + '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': 'ソース', @@ -138,10 +146,52 @@ translations = { 'Snippets': 'コード断片集', 'Web': 'Web', 'Changes': '変更点', - 'Internals': '内部リファレンス', #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)', + }, } @@ -190,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 != ''): @@ -287,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, @@ -320,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): @@ -357,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-"