From 22fd7ac44a5a39b1f231d9563a6d95ad7f959c84 Mon Sep 17 00:00:00 2001 From: Alexandre Dupas Date: Wed, 16 Jun 2010 14:50:35 +0200 Subject: [PATCH] Add lilypond support to the depend computation mechanism. --- songbook.py | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/songbook.py b/songbook.py index 4a394c2f..5fe664a8 100755 --- a/songbook.py +++ b/songbook.py @@ -64,6 +64,7 @@ def makeDepend(sb, output): # pattern that get dependencies dependsPattern = re.compile(r"^[^%]*(?:include|input)\{(.*?)\}") indexPattern = re.compile(r"^[^%]*\\(?:newauthor|new)index\{.*\}\{(.*?)\}") + lilypondPattern = re.compile(r"^[^%]*\\(?:lilypond)\{(.*?)\}") # check for deps (in sb data) deps = [] @@ -75,6 +76,17 @@ def makeDepend(sb, output): if match: deps += [match.group(1)] + # check for lilypond deps (in songs data) if necessary + lilypond = [] + if "booktype" in sb.keys() and "lilypond" in sb["booktype"]: + for filename in deps: + tmpl = open(filename) + for l in tmpl: + match = lilypondPattern.match(l) + if match: + lilypond.append(match.group(1)) + tmpl.close() + # check for index (in template file) if "template" in sb: filename = "templates/"+sb["template"] @@ -91,7 +103,7 @@ def makeDepend(sb, output): # write .d file out = open(output, 'w') out.write('{0} {1} : {2}\n'.format(output, name+".tex", ' '.join(deps))) - out.write('{0} : {1}\n'.format(name+".pdf", ' '.join(map(lambda x: x+".sbx",idx)))) + out.write('{0} : {1}\n'.format(name+".pdf", ' '.join(map(lambda x: x+".sbx",idx)+map(lambda x: "lilypond/"+x+".pdf", lilypond)))) out.write('\t$(LATEX) {0}\n'.format(name+".tex")) out.write('{0} : {1}\n'.format(' '.join(map(lambda x: x+".sxd",idx)), name+".aux")) out.close()