chiark / gitweb /
utilize orphan-address
[developers-reference.git] / Makefile
index 43c602c5f35febc27064ff400feb44195fddd43e..4056d3518db9c14de8b313b12e2244cfa89d1602 100644 (file)
--- a/Makefile
+++ b/Makefile
 MANUAL         := $(notdir $(shell pwd))
 PUBLISHDIR     := ../../../public_html/manuals.html
 
-publish:       build
+SOURCES                := $(wildcard *.sgml)
+
+TARGETS                := $(foreach fmt,html txt pdf,developers-reference.$(fmt)) \
+                    $(filter-out developers-reference.ja.pdf, \
+                      $(foreach langext,.ja .fr, \
+                        $(foreach fmt,html txt pdf,developers-reference$(langext).$(fmt))))
+
+# programs for creating output
+DEBIANDOC2HTML := debiandoc2html -d debiandoc.decl -c
+DEBIANDOC2TEXT := debiandoc2text -d debiandoc.decl
+DEBIANDOC2LATEX        := debiandoc2latex -d debiandoc.decl
+
+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
-       install -d -m 755 $(PUBLISHDIR)/$(MANUAL)
-       install -m 644 --preserve-timestamps $(MANUAL).html/*.html      \
+       $(make_directory) $(PUBLISHDIR)/$(MANUAL)
+       $(install_file) developers-reference*.html/*.html       \
           $(PUBLISHDIR)/$(MANUAL)
 
-.PHONY:        build
-build:
-       debian/rules build
+developers-reference.html:     developers-reference.sgml
+       $(DEBIANDOC2HTML) -l C $<
+
+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 $< > $@
+
+%.pdf: %.tex
+#       note that I have seen bi-stable .aux files, thus we check two levels deep
+       -cp -pf prior.aux pprior.aux 2>/dev/null
+       -cp -pf $(basename $<).aux prior.aux 2>/dev/null
+#       fail if we don't have pdflatex correctly installed
+       kpsewhich pdflatex.fmt >/dev/null
+#       due to a bug in debiandoc2latex2e output, this might fail
+       -pdflatex '\nonstopmode\input{$<}' >/dev/null # see $(@:.pdf=.log) for details
+       @set -e                                                         ;\
+       if ! cmp $(basename $<).aux prior.aux 2>/dev/null &&            \
+          ! cmp $(basename $<).aux pprior.aux 2>/dev/null; then        \
+               if expr $(MAKELEVEL) '<' $(MAX_TEX_RECURSION) >/dev/null;\
+               then                                                    \
+                  echo "remaking $@ (take $(MAKELEVEL))"               ;\
+                  rm -f $@                                             ;\
+                  $(MAKE) $@                                           ;\
+               else                                                    \
+                  echo "E: $@ needs remaking, but we have reached max. level, $(MAX_TEX_RECURSION)" ;\
+               fi                                                      \
+       fi
+       rm -f prior.aux pprior.aux
+
+version.ent:   debian/changelog
+       ./debian/rules $@
+
+%.validate : %
+       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
+       rm -f version.ent
+       rm -f `find . -name "*~"`
+       rm -f *.validate
+
+developers-reference$(SRCEXT).sgml: version.ent common.ent
 
+html: $(MANUAL).html