X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=make%2Fly-rules.make;h=25dd5b2fbbb64afbc1a0bd315f46694cb15c8389;hb=7f510ef24dde5a9312362b8f75f97bd23b4f9798;hp=3849b142a77d933ac645e6e716e0439256a874a7;hpb=70f979b6f259e273bf8756af56f438401ebc6f3b;p=lilypond.git diff --git a/make/ly-rules.make b/make/ly-rules.make index 3849b142a7..25dd5b2fbb 100644 --- a/make/ly-rules.make +++ b/make/ly-rules.make @@ -1,61 +1,33 @@ -.SUFFIXES: .doc .dvi .tely .texi .ly +.SUFFIXES: .doc .tely .texi .ly +# TODO: fix hardcoded out/ ? +LYS_OUTPUT_OPTION= --lily-output-dir $(LYS_OUTPUT_DIR) +LYS_OUTPUT_DIR=$(top-build-dir)/out/lybook-db +LILYPOND_BOOK_FLAGS += $(LYS_OUTPUT_OPTION) +$(outdir)/%.latex: %.doc $(INIT_LY_SOURCES) $(SCHEME_SOURCES) + LILYPOND_VERSION=$(TOPLEVEL_VERSION) $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --process='$(LILYPOND_BOOK_PROCESS) $(LILYPOND_BOOK_LILYPOND_FLAGS)' --output=$(outdir) $(LILYPOND_BOOK_FLAGS) --redirect-lilypond-output $< -$(outdir)/%.latex: %.doc - if [ -f $@ ]; then chmod a+w $@; fi - $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --process='$(LILYPOND) $(LILYPOND_BOOK_INCLUDES)' --output=$(outdir) --verbose $(LILYPOND_BOOK_FLAGS) $< - chmod -w $@ -# don't do ``cd $(outdir)'', and assume that $(outdir)/.. is the src dir. -# it is not, for --srcdir builds -$(outdir)/%.texi: %.tely - if [ -f $@ ]; then chmod a+w $@; fi - rm -f $$(grep -LF '\lilypondend' out/lily-*.tex) - $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --process='$(LILYPOND) $(LILYPOND_BOOK_INCLUDES)' --output=$(outdir) --format=$(LILYPOND_BOOK_FORMAT) --verbose $(LILYPOND_BOOK_FLAGS) $< - chmod -w $@ - -$(outdir)/%.texi: $(outdir)/%.tely - if [ -f $@ ]; then chmod a+w $@; fi - rm -f $$(grep -LF '\lilypondend' out/lily-*.tex) - $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --process='$(LILYPOND) $(LILYPOND_BOOK_INCLUDES)' --output=$(outdir) --format=$(LILYPOND_BOOK_FORMAT) --verbose $(LILYPOND_BOOK_FLAGS) $< -# -# DON'T REMOVE SOURCE FILES, otherwise the .TEXI ALWAYS OUT OF DATE. -# rm -f $< - chmod -w $@ - -# nexi: no-lily texi -# for plain info doco: don't run lily -$(outdir)/%.nexi: %.tely - if [ -f $@ ]; then chmod a+w $@; fi - rm -f $(outdir)/$*.texi - $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --output=$(outdir) --format=$(LILYPOND_BOOK_FORMAT) --verbose $(LILYPOND_BOOK_FLAGS) --process='true' $< - mv $(outdir)/$*.texinfo $@ 2>/dev/null || mv $(outdir)/$*.texi $@ - chmod -w $@ - -# nfo: info from non-lily texi -$(outdir)/%.info: $(outdir)/%.nexi - $(MAKEINFO) -I $(outdir) --output=$(outdir)/$(*F).info $< +# This allows -j make option while making sure only one lilypond-book instance +# is running at the same time, using GNU make's order-only prerequisites so +# as to not create superficial dependencies between unrelated manuals. +define CHAIN_RULE +| $(i) +$(i): +endef -# nfo: info from non-lily texi -#$(outdir)/%.nfo: $(outdir)/%.nexi -# $(MAKEINFO) --output=$(outdir)/$(*F).info $< +$(eval $(firstword $(TEXI_FILES_FROM_TELY)):\ + $(foreach i, $(wordlist 2, $(words $(TEXI_FILES_FROM_TELY)),\ + $(TEXI_FILES_FROM_TELY)),$(CHAIN_RULE))) -# -# let's not do this: this interferes with the lilypond-book dependency mechanism. -# -##$(outdir)/%.tex: $(outdir)/%.ly -## $(LILYPOND) $(LILYPOND_BOOK_INCLUDES) -o $@ $< +# don't do ``cd $(outdir)'', and assume that $(outdir)/.. is the src dir. +# it is not, for --srcdir builds +$(outdir)/%.texi: %.tely $(outdir)/version.itexi $(DOCUMENTATION_LOCALE_TARGET) $(INIT_LY_SOURCES) $(SCHEME_SOURCES) + LILYPOND_VERSION=$(TOPLEVEL_VERSION) $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --process='$(LILYPOND_BOOK_PROCESS) $(LILYPOND_BOOK_LILYPOND_FLAGS)' --output=$(outdir) --format=$(LILYPOND_BOOK_FORMAT) $(LILYPOND_BOOK_FLAGS) --redirect-lilypond-output $< -# -# Timothy's booklet -# -$(outdir)/%-book.ps: $(outdir)/%.ps - psbook $< $<.tmp - pstops '2:0L@.7(21cm,0)+1L@.7(21cm,14.85cm)' $<.tmp $@ -$(outdir)/%.pdf: $(outdir)/%.dvi - dvips $(DVIPS_FLAGS) -o $@.pdfps -t $(DVIPS_PAPERSIZE) $< - ps2pdf -sPAPERSIZE=$(DVIPS_PAPERSIZE) $@.pdfps $@ +$(outdir)/%.texi: $(outdir)/%.tely $(outdir)/version.itexi $(DOCUMENTATION_LOCALE_TARGET) $(INIT_LY_SOURCES) $(SCHEME_SOURCES) + LILYPOND_VERSION=$(TOPLEVEL_VERSION) $(PYTHON) $(LILYPOND_BOOK) $(LILYPOND_BOOK_INCLUDES) --process='$(LILYPOND_BOOK_PROCESS) $(LILYPOND_BOOK_INCLUDES) $(LILYPOND_BOOK_LILYPOND_FLAGS)' --output=$(outdir) --format=$(LILYPOND_BOOK_FORMAT) $(LILYPOND_BOOK_FLAGS) --redirect-lilypond-output $< $(outdir)/%.html.omf: %.tely @@ -64,15 +36,15 @@ $(outdir)/%.html.omf: %.tely $(outdir)/%.pdf.omf: %.tely $(call GENERATE_OMF,pdf) -$(outdir)/%.ps.gz.omf: %.tely - $(call GENERATE_OMF,ps.gz) - - -$(outdir)/%.html.omf: $(outdir)/%.texi +$(outdir)/%.html.omf: $(outdir)/%.texi | $(OUT_TEXINFO_MANUALS) $(call GENERATE_OMF,html) -$(outdir)/%.pdf.omf: $(outdir)/%.texi +$(outdir)/%.pdf.omf: $(outdir)/%.texi | $(OUT_TEXINFO_MANUALS) $(call GENERATE_OMF,pdf) -$(outdir)/%.ps.gz.omf: $(outdir)/%.texi - $(call GENERATE_OMF,ps.gz) +$(outdir)/others-did.itexi $(outdir)/we-wrote.itexi: $(outdir)/%.itexi: $(top-src-dir)/Documentation/web/%.bib $(top-src-dir)/Documentation/lily-bib.bst + BSTINPUTS=$(top-src-dir)/Documentation/web/ $(buildscript-dir)/bib2texi \ + -s $(top-src-dir)/Documentation/lily-bib \ + -o $(outdir)/$*.itexi \ + -q \ + $(top-src-dir)/Documentation/web/$*.bib