0e73916c160ca015ffb0db1dd4e177d66c885a1d
[charm.git] / doc / Makefile.common
1 # Makefile included by each manual: contains the 
2 #   common build commands/targets ("make pdf", "make ps", "make html")
3 #   common "upload-to-web" targets ("make web")
4
5 # The enclosing Makefile is expected to set the variables:
6 #   FILE: base name of master TeX file (typically "manual")
7 #   TEX: all TeX files to depend on (often just "manual.tex")
8 #   DEST: destination manual name (e.g., "fem")
9 #   LATEX2HTML: call to latex2html, which should be "$(L2H) <args>"
10 # (optional) PROJECT_LINK: HTML to include at bottom of page
11
12 # Destination directory for local copy of files (e.g., on user machine)
13 DOCDIR=..
14
15 # Destination directory for web-accessible copy of files (e.g., on PPL machines)
16 WEBDIR=/www/ppl_manuals
17
18 # Call to Latex2html
19 L2H=latex2html -white -antialias -local_icons \
20         -long_titles 1 \
21         -show_section_numbers \
22         -top_navigation \
23         -address '<p align="right">'"`/bin/date +"%B %d, %Y"`"'<br> \
24             '$(PROJECT_LINK)'<a href="http://charm.cs.illinois.edu/">PPL Homepage</a>'
25
26 DEPTEX=$(TEX) $(FILE).aux index.tex
27
28 # Default target: build postscript, pdf, and html:
29
30 all: pdf ps html
31
32 # PostScript Target:
33 ps: $(FILE).ps
34
35 # latex does not create dvi anymore on new linux distributions
36 #$(FILE).dvi: $(TEX) $(FILE).aux 
37 #       latex $(FILE).tex
38
39 $(FILE).ps: $(FILE).pdf
40         pdftops -level1 -paper letter $(FILE).pdf $(FILE).ps
41         #dvips -t letter -f $(FILE).dvi > $(FILE).ps
42
43
44 # PDF Target:
45 pdf: $(FILE).pdf
46
47 $(FILE).pdf: $(TEX) $(FILE).aux
48         pdflatex $(FILE).tex
49         pdflatex $(FILE).tex
50
51 # HTML Target:
52 html: $(FILE)
53
54 $(FILE): $(TEX) $(FILE).aux
55         -@ln -s ../pplmanual.* .
56         -@ln -s ../dot.latex2html-init .latex2html-init
57         -@rm -fr $(FILE)/*.html $(FILE)/*.aux
58         -@mkdir $(FILE)
59         -@/bin/cp ../manual.css $(FILE)
60         -@/bin/cp ../*.js $(FILE)
61         -@/bin/cp ../navbarbkgd.png $(FILE)
62         -/bin/cp title.html $(FILE)
63         $(L2H) -split 0 $(FILE).tex
64         -@mv $(FILE)/$(FILE).html $(FILE)/$(FILE)-1p.html
65         $(LATEX2HTML) $(FILE).tex
66         ../l2h_sanitize_markup.sh
67
68 # LaTeX Index and link support
69 $(FILE).aux: $(TEX) index.tex $(FIG_TARGET)
70         pdflatex $(FILE).tex
71
72 index.tex: $(FILE).idx
73         makeindex -o index.tex $(FILE).idx
74
75 $(FILE).idx:
76         touch $(FILE).idx
77
78 # Clean out all TeX droppings:
79 clean:
80         -rm -fr *.aux *.log *.dvi *.ps *.pdf *.out *.ilg $(FILE)
81         -rm -fr *.idx *.log *.bbl *.blg *.toc *~ fig/*.bak
82         -rm -fr index.tex $(FIG_CLEAN)
83
84 # Build local copy of documentation:
85 doc: all
86         if [ ! -d $(DOCDIR) ] ; then mkdir $(DOCDIR) ; fi
87         if [ ! -d $(DOCDIR)/ps ] ; then mkdir $(DOCDIR)/ps ; fi
88         if [ ! -d $(DOCDIR)/pdf ] ; then mkdir $(DOCDIR)/pdf ; fi
89         if [ ! -d $(DOCDIR)/html ] ; then mkdir $(DOCDIR)/html ; fi
90         /bin/cp $(FILE).ps $(DOCDIR)/ps/$(DEST).ps
91         chmod 664 $(DOCDIR)/ps/$(DEST).ps
92         /bin/cp $(FILE).pdf $(DOCDIR)/pdf/$(DEST).pdf
93         chmod 664 $(DOCDIR)/pdf/$(DEST).pdf
94         /bin/rm -rf $(DOCDIR)/html/$(DEST)
95         /bin/cp -R $(FILE) $(DOCDIR)/html/$(DEST)
96         find $(DOCDIR)/html/$(DEST) $(DOCDIR)/p*/$(DEST).p* -type f -exec chmod 664 {} \;
97         find $(DOCDIR)/html/$(DEST) -type d -exec chmod 775 {} \;
98
99 # Build web copy of documentation (PPL-only):
100 web: all
101         /bin/cp $(FILE).ps $(WEBDIR)/ps/$(DEST).ps
102         -chmod 664 $(WEBDIR)/ps/$(DEST).ps
103         /bin/cp $(FILE).pdf $(WEBDIR)/pdf/$(DEST).pdf
104         -chmod 664 $(WEBDIR)/pdf/$(DEST).pdf
105         /bin/rm -rf $(WEBDIR)/html/$(DEST)
106         /bin/cp -R $(FILE) $(WEBDIR)/html/$(DEST)
107         find $(WEBDIR)/html/$(DEST) $(WEBDIR)/p*/$(DEST).p* -type f -exec chmod 664 {} \;
108         find $(WEBDIR)/html/$(DEST) -type d -exec chmod 775 {} \;
109         -chgrp -R kale $(WEBDIR)/html/$(DEST) $(WEBDIR)/p*/$(DEST).p*
110