X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=developers-reference.git;a=blobdiff_plain;f=Makefile;h=b6b0757ff200354a39465cb95a88f95f540641dc;hp=ccff8d6d5ce75bfa5f481c70a12e7a062334a569;hb=057fd42386bdc2c5362a5732030935a12af47687;hpb=5d8e1f03f84c3398bd6a0d3116292df347e3ffed diff --git a/Makefile b/Makefile index ccff8d6..b6b0757 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,110 @@ -# Makefile, only used for the DDP manuals.sgml area +# Makefile, used for the DDP manuals.sgml area -all: - debian/rules build +MANUAL := $(notdir $(shell pwd)) +PUBLISHDIR := /org/www.debian.org/www/doc/manuals +SOURCES := $(wildcard *.sgml) + +TARGETS := $(foreach fmt,html txt pdf,developers-reference.$(fmt)) \ + $(filter-out developers-reference.ja.pdf, \ + $(foreach langext,.ja, \ + $(foreach fmt,html txt pdf,developers-reference$(langext).$(fmt)))) + +# programs for creating output +DEBIANDOC2HTML := debiandoc2html -c +DEBIANDOC2TEXT := debiandoc2text +DEBIANDOC2LATEX := debiandoc2latex +DEBIANDOC2PS := debiandoc2latexps +DEBIANDOC2PDF := debiandoc2latexpdf + +make_directory := install -d -m 755 +install_file := install -m 644 -p + +MAX_TEX_RECURSION := 5 + +.PHONY: all +all: $(TARGETS) + +.PHONY: validate +validate: $(addsuffix .validate,$(SOURCES)) + +# hmmm, this rule may need to be revised/tested +publish: all + [ -d $(PUBLISHDIR) ] || exit 1 + rm -f $(PUBLISHDIR)/$(MANUAL)/*.html + $(make_directory) $(PUBLISHDIR)/$(MANUAL) + $(install_file) developers-reference*.html/*.html \ + $(PUBLISHDIR)/$(MANUAL) + +developers-reference.html: developers-reference.sgml + $(DEBIANDOC2HTML) -l C $< + +developers-reference.html/*: developers-reference.html + +developers-reference.%.html: developers-reference.%.sgml + $(DEBIANDOC2HTML) -l $* $< + +developers-reference.txt: developers-reference.sgml + $(DEBIANDOC2TEXT) -l C -O $< > $@ + +developers-reference.%.txt: developers-reference.%.sgml + $(DEBIANDOC2TEXT) -l $* -O $< > $@ + +developers-reference.tex: developers-reference.sgml + $(DEBIANDOC2LATEX) -l C -O $< > $@ + +developers-reference.%.tex: developers-reference.%.sgml + $(DEBIANDOC2LATEX) -l $* -O $< > $@ + +developers-reference.ps: developers-reference.sgml + $(DEBIANDOC2PS) -l C $< + +developers-reference.%.ps: developers-reference.%.sgml + $(DEBIANDOC2PS) -l $* $< + +developers-reference.pdf: developers-reference.sgml + $(DEBIANDOC2PDF) -l C $< + +developers-reference.%.pdf: developers-reference.%.sgml + $(DEBIANDOC2PDF) -l $* $< + +version.ent: debian/changelog + ./debian/rules $@ + +%.validate : % version.ent + nsgmls -wall -gues $< + touch $@ + +USERMAP := ../../ddp/CVSROOT/users +.PHONY: prepare +prepare: + @[ -f CVS/Root -a -f $(USERMAP) ] || \ + ( echo "silly rabbit, prepare is for Adam" 1>&2; exit 1 ) + cvs2cl -r --usermap $(USERMAP) + cvs ci -m "update for next release" ChangeLog + +.PHONY: clean clean: - debian/rules clean + rm -rf developers-reference*.html + rm -f developers-reference*.txt developers-reference*.pdf \ + developers-reference*.ps developers-reference*.lout* lout.li \ + developers-reference*.sasp* developers-reference*.tex \ + developers-reference*.aux developers-reference*.toc \ + developers-reference*.idx developers-reference*.log \ + developers-reference*.out developers-reference*.dvi \ + developers-reference*.tpt + rm -f version.ent + rm -f `find . -name "*~" -o -name "*.bak"` + rm -f *.validate + rm -f *~ *.bak .#* core + +.PHONY: distclean +distclean: clean + rm -f *.rej *.orig + +developers-reference$(SRCEXT).sgml: version.ent common.ent + +html: $(MANUAL).html + +# if rule bomb out, delete the target +.DELETE_ON_ERROR: