Browse Source

Add lilypond support to the depend computation mechanism.

remotes/origin/split-songs
Alexandre Dupas 15 years ago
parent
commit
22fd7ac44a
  1. 14
      songbook.py

14
songbook.py

@ -64,6 +64,7 @@ def makeDepend(sb, output):
# pattern that get dependencies # pattern that get dependencies
dependsPattern = re.compile(r"^[^%]*(?:include|input)\{(.*?)\}") dependsPattern = re.compile(r"^[^%]*(?:include|input)\{(.*?)\}")
indexPattern = re.compile(r"^[^%]*\\(?:newauthor|new)index\{.*\}\{(.*?)\}") indexPattern = re.compile(r"^[^%]*\\(?:newauthor|new)index\{.*\}\{(.*?)\}")
lilypondPattern = re.compile(r"^[^%]*\\(?:lilypond)\{(.*?)\}")
# check for deps (in sb data) # check for deps (in sb data)
deps = [] deps = []
@ -75,6 +76,17 @@ def makeDepend(sb, output):
if match: if match:
deps += [match.group(1)] 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) # check for index (in template file)
if "template" in sb: if "template" in sb:
filename = "templates/"+sb["template"] filename = "templates/"+sb["template"]
@ -91,7 +103,7 @@ def makeDepend(sb, output):
# write .d file # write .d file
out = open(output, 'w') out = open(output, 'w')
out.write('{0} {1} : {2}\n'.format(output, name+".tex", ' '.join(deps))) 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('\t$(LATEX) {0}\n'.format(name+".tex"))
out.write('{0} : {1}\n'.format(' '.join(map(lambda x: x+".sxd",idx)), name+".aux")) out.write('{0} : {1}\n'.format(' '.join(map(lambda x: x+".sxd",idx)), name+".aux"))
out.close() out.close()

Loading…
Cancel
Save