annotate en/Makefile @ 58:3649ee841264

Merge with bos
author Josef "Jeff" Sipek <jeffpc@josefsipek.net>
date Tue, 25 Jul 2006 09:07:20 -0400
parents fa8bafe467cb 18210d46491f
children 0aae9d676e0f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
57
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
1 # This makefile requires GNU make.
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
2
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
3 hg_id := $(shell hg parents --template '{node|short}\n' | head -1)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
4
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
5 sources := \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
6 00book.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
7 99book.bib \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
8 99defs.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
9 build_id.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
10 concepts.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
11 daily.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
12 hook.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
13 intro.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
14 mq.tex \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
15 preface.tex
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
16
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
17 image-sources := \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
18 mq-stack.svg
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
19
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
20 example-sources := \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
21 examples/daily.files \
58
3649ee841264 Merge with bos
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 57 49
diff changeset
22 examples/hook.msglen \
57
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
23 examples/hook.simple \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
24 examples/hook.ws \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
25 examples/concepts \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
26 examples/mq.qinit-help \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
27 examples/mq.dodiff \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
28 examples/mq.tarball \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
29 examples/mq.tools \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
30 examples/mq.tutorial
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
31
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
32 latex-options = \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
33 -interaction batchmode \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
34 -output-directory $(dir $(1)) \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
35 -jobname $(basename $(notdir $(1)))
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
36
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
37 all: pdf html
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
38
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
39 pdf: pdf/hgbook.pdf
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
40
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
41 define pdf
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
42 mkdir -p $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
43 TEXINPUTS=$(dir $<): pdflatex $(call latex-options,$@) $< || (rm -f $@; exit 1)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
44 cp 99book.bib $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
45 cd $(dir $@) && bibtex $(basename $(notdir $@))
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
46 cd $(dir $@) && makeindex $(basename $(notdir $@))
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
47 TEXINPUTS=$(dir $<): pdflatex $(call latex-options,$@) $< || (rm -f $@; exit 1)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
48 TEXINPUTS=$(dir $<): pdflatex $(call latex-options,$@) $< || (rm -f $@; exit 1)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
49 if grep 'Reference.*undefined' $(@:.pdf=.log); then exit 1; fi
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
50 endef
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
51
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
52 pdf/hgbook.pdf: $(sources) $(image-sources:%.svg=%.pdf) examples
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
53 $(call pdf)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
54
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
55 html: html/onepage/hgbook.html html/split/hgbook.html
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
56
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
57 # This is a horrible hack to work around the fact that the htlatex
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
58 # command in tex4ht is itself a horrible hack. I really don't want to
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
59 # include verbatim the big wad of TeX that is repeated in that script,
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
60 # so instead I mangle the script itself.
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
61
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
62 define htlatex
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
63 mkdir -p $(dir $(1))
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
64 head -2 $(shell which htlatex) > $(dir $(1))/htlatex.book
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
65 cp 99book.bib $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
66 echo '(cd $(dir $@) && bibtex $(basename $(notdir $@)))' >> $(dir $(1))/htlatex.book
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
67 echo '(cd $(dir $@) && makeindex $(basename $(notdir $@)))' >> $(dir $(1))/htlatex.book
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
68 head -3 $(shell which htlatex) >> $(dir $(1))/htlatex.book
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
69 echo 'echo status $$$$' >> $(dir $(1))/htlatex.book
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
70 chmod 755 $(dir $(1))/htlatex.book
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
71 TEXINPUTS=$(dir $(2)): $(dir $(1))/htlatex.book $(2) "xhtml,html4-uni,$(3)" " -cunihtf -utf8" "" "$(call latex-options,$(1))" || (rm -f $(1); exit 1)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
72 cd $(dir $(1)) && tex4ht -f/$(basename $(notdir $(1))) -cvalidate -cunihtf
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
73 cd $(dir $(1)) && t4ht -f/$(basename $(notdir $(1)))
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
74 perl -pi -e 's/&#x00([0-7][0-9a-f]);/chr(hex($$1))/egi' $(dir $(1))/*.html
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
75 endef
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
76
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
77 html/onepage/hgbook.html: $(sources) $(image-sources:%.svg=%.png) examples
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
78 $(call htlatex,$@,$<)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
79 cp $(image-sources:%.svg=%.png) $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
80
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
81 html/split/hgbook.html: $(sources) $(image-sources:%.svg=%.png) examples
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
82 $(call htlatex,$@,$<,2)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
83 cp $(image-sources:%.svg=%.png) $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
84
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
85 beta: beta/pdf/hgbook.pdf beta/html/onepage/hgbook.html beta/html/split/hgbook.html
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
86
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
87 beta/%.tex: %.tex
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
88 ./fblinks $(hg_id) $(dir $@) $<
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
89
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
90 beta/pdf/hgbook.pdf: $(sources:%.tex=beta/%.tex) $(image-sources:%.svg=%.pdf) examples fblinks
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
91 $(call pdf)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
92
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
93 beta/html/onepage/hgbook.html: $(sources:%.tex=beta/%.tex) $(image-sources:%.svg=%.png) examples
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
94 $(call htlatex,$@,$<)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
95 cp $(image-sources:%.svg=%.png) $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
96
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
97 beta/html/split/hgbook.html: $(sources:%.tex=beta/%.tex) $(image-sources:%.svg=%.png) examples
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
98 $(call htlatex,$@,$<,2)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
99 cp $(image-sources:%.svg=%.png) $(dir $@)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
100
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
101 # Produce 90dpi PNGs for the web.
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
102
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
103 %.png: %.svg
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
104 inkscape -D -e $@ $<
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
105
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
106 # Produce eps & pdf for the pdf
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
107
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
108 %.pdf: %.eps
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
109 epstopdf $<
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
110
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
111 %.eps: %.svg
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
112 inkscape -E $@ $<
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
113
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
114 examples: examples/.run
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
115
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
116 examples/.run: $(example-sources:%=%.run)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
117 touch examples/.run
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
118
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
119 examples/%.run: examples/% examples/run-example
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
120 cd examples && ./run-example $(notdir $<)
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
121
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
122 build_id.tex: $(wildcard ../.hg/00changelog.[id])
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
123 echo -n $(hg_id) > build_id.tex
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
124
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
125 clean:
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
126 rm -rf beta html pdf *.eps *.pdf *.png *.aux *.dvi *.log *.out \
fa8bafe467cb Merge with upstream
Josef "Jeff" Sipek <jeffpc@josefsipek.net>
parents: 56 46
diff changeset
127 examples/*.{out,run} examples/.run build_id.tex