741f14cfad214cfc69aad0f5965917bd2f0ef280
[git.git] / Documentation / Makefile
1 MAN1_TXT=$(wildcard git-*.txt) gitk.txt
2 MAN7_TXT=git.txt
3
4 DOC_HTML=$(patsubst %.txt,%.html,$(MAN1_TXT) $(MAN7_TXT))
5
6 ARTICLES = tutorial
7 ARTICLES += cvs-migration
8 ARTICLES += diffcore
9 ARTICLES += howto-index
10 ARTICLES += repository-layout
11 ARTICLES += hooks
12 # with their own formatting rules.
13 SP_ARTICLES = glossary howto/revert-branch-rebase
14
15 DOC_HTML += $(patsubst %,%.html,$(ARTICLES) $(SP_ARTICLES))
16
17 DOC_MAN1=$(patsubst %.txt,%.1,$(MAN1_TXT))
18 DOC_MAN7=$(patsubst %.txt,%.7,$(MAN7_TXT))
19
20 prefix?=$(HOME)
21 bin=$(prefix)/bin
22 mandir=$(prefix)/man
23 man1=$(mandir)/man1
24 man7=$(mandir)/man7
25 # DESTDIR=
26
27 INSTALL?=install
28
29 #
30 # Please note that there is a minor bug in asciidoc.
31 # The version after 6.0.3 _will_ include the patch found here:
32 #   http://marc.theaimsgroup.com/?l=git&m=111558757202243&w=2
33 #
34 # Until that version is released you may have to apply the patch
35 # yourself - yes, all 6 characters of it!
36 #
37
38 all: html man
39
40 html: $(DOC_HTML)
41
42
43 man: man1 man7
44 man1: $(DOC_MAN1)
45 man7: $(DOC_MAN7)
46
47 install: man
48         $(INSTALL) -d -m755 $(DESTDIR)/$(man1) $(DESTDIR)/$(man7)
49         $(INSTALL) $(DOC_MAN1) $(DESTDIR)/$(man1)
50         $(INSTALL) $(DOC_MAN7) $(DESTDIR)/$(man7)
51
52 # 'include' dependencies
53 $(patsubst %.txt,%.1,$(wildcard git-diff-*.txt)): \
54         diff-format.txt diff-options.txt
55 $(patsubst %.txt,%.html,$(wildcard git-diff-*.txt)): \
56         diff-format.txt diff-options.txt
57
58 $(patsubst %,%.1,git-fetch git-pull git-push): pull-fetch-param.txt
59 $(patsubst %,%.html,git-fetch git-pull git-push): pull-fetch-param.txt
60
61 $(patsubst %,%.1,git-merge git-pull): merge-pull-opts.txt
62 $(patsubst %,%.html,git-merge git-pull): merge-pull-opts.txt
63
64 git.7: ../README
65
66 clean:
67         rm -f *.xml *.html *.1 *.7 howto-index.txt howto/*.html
68
69 %.html : %.txt
70         asciidoc -b xhtml11 -d manpage -f asciidoc.conf $<
71
72 %.1 %.7 : %.xml
73         xmlto man $<
74
75 %.xml : %.txt
76         asciidoc -b docbook -d manpage -f asciidoc.conf $<
77
78 git.html: git.txt ../README
79
80 glossary.html : glossary.txt sort_glossary.pl
81         cat $< | \
82         perl sort_glossary.pl | \
83         asciidoc -b xhtml11 - > glossary.html
84
85 howto-index.txt: howto-index.sh $(wildcard howto/*.txt)
86         rm -f $@+ $@
87         sh ./howto-index.sh $(wildcard howto/*.txt) >$@+
88         mv $@+ $@
89
90 $(patsubst %,%.html,$(ARTICLES)) : %.html : %.txt
91         asciidoc -b xhtml11 $*.txt
92
93 WEBDOC_DEST = /pub/software/scm/git/docs
94
95 $(patsubst %.txt,%.html,$(wildcard howto/*.txt)): %.html : %.txt
96         rm -f $@+ $@
97         sed -e '1,/^$$/d' $? | asciidoc -b xhtml11 - >$@+
98         mv $@+ $@
99
100 install-webdoc : html
101         sh ./install-webdoc.sh $(WEBDOC_DEST)