Commit | Line | Data |
---|---|---|
5f7b975a JH |
1 | prefix = $(HOME) |
2 | bindir= $(prefix)/bin | |
3 | mandir = $(prefix)/man | |
bb8afc29 | 4 | docdir = $(prefix)/share/doc |
5f7b975a JH |
5 | # DESTDIR= |
6 | ||
a6ec85e1 | 7 | LDLIBS = -lcurses |
900666fc | 8 | CFLAGS = -Wall -O2 |
19f862bd | 9 | DFLAGS = -g -DDEBUG -Werror |
b801d8b2 | 10 | PROGS = tig |
ec4b9d91 GK |
11 | DOCS_MAN = tig.1 tigrc.5 |
12 | DOCS_HTML = tig.1.html tigrc.5.html \ | |
13 | manual.html manual.html-chunked \ | |
14 | README.html | |
15 | DOCS = $(DOCS_MAN) $(DOCS_HTML) \ | |
16 | manual.toc manual.pdf | |
e2beda18 JF |
17 | |
18 | ifneq (,$(wildcard .git)) | |
9074d9b6 JF |
19 | VERSION = $(shell git-describe) |
20 | WTDIRTY = $(shell git-diff-index --name-only HEAD 2>/dev/null) | |
21 | CFLAGS += '-DVERSION="$(VERSION)$(if $(WTDIRTY),-dirty)"' | |
e2beda18 | 22 | endif |
800a900c | 23 | |
a7bc4b14 | 24 | all: $(PROGS) |
82e78006 JF |
25 | all-debug: $(PROGS) |
26 | all-debug: CFLAGS += $(DFLAGS) | |
c92615b1 | 27 | doc: $(DOCS) |
ec4b9d91 GK |
28 | doc-man: $(DOCS_MAN) |
29 | doc-html: $(DOCS_HTML) | |
800a900c | 30 | |
05f1685b | 31 | install: all |
d441a715 | 32 | mkdir -p $(DESTDIR)$(bindir) && \ |
a7bc4b14 | 33 | for prog in $(PROGS); do \ |
5f7b975a | 34 | install $$prog $(DESTDIR)$(bindir); \ |
4c6fabc2 JF |
35 | done |
36 | ||
ec4b9d91 | 37 | install-doc-man: doc-man |
bb8afc29 | 38 | mkdir -p $(DESTDIR)$(mandir)/man1 \ |
ec4b9d91 | 39 | $(DESTDIR)$(mandir)/man5 |
4c6fabc2 JF |
40 | for doc in $(DOCS); do \ |
41 | case "$$doc" in \ | |
5f7b975a JH |
42 | *.1) install $$doc $(DESTDIR)$(mandir)/man1 ;; \ |
43 | *.5) install $$doc $(DESTDIR)$(mandir)/man5 ;; \ | |
ec4b9d91 GK |
44 | esac \ |
45 | done | |
46 | ||
47 | install-doc-html: doc-html | |
48 | mkdir -p $(DESTDIR)$(docdir)/tig | |
49 | for doc in $(DOCS); do \ | |
50 | case "$$doc" in \ | |
bb8afc29 | 51 | *.html) install $$doc $(DESTDIR)$(docdir)/tig ;; \ |
4c6fabc2 | 52 | esac \ |
a7bc4b14 | 53 | done |
05f1685b | 54 | |
ec4b9d91 GK |
55 | install-doc: install-doc-man install-doc-html |
56 | ||
05f1685b | 57 | clean: |
d839253b | 58 | rm -rf manual.html-chunked |
de8f9b2b | 59 | rm -f $(PROGS) $(DOCS) core *.xml |
05f1685b | 60 | |
57bdf034 | 61 | spell-check: |
8eb62770 | 62 | aspell --lang=en --check tig.1.txt tigrc.5.txt manual.txt |
57bdf034 | 63 | |
0e92d312 JF |
64 | strip: all |
65 | strip $(PROGS) | |
66 | ||
ec4b9d91 | 67 | .PHONY: all all-debug doc doc-man doc-html install install-doc install-doc-man install-doc-html clean spell-check |
a7bc4b14 | 68 | |
ec4b9d91 | 69 | manual.html: manual.toc |
9783cb12 JF |
70 | manual.toc: manual.txt |
71 | sed -n '/^\[\[/,/\(---\|~~~\)/p' < $< | while read line; do \ | |
72 | case "$$line" in \ | |
73 | "-----"*) echo ". <<$$ref>>"; ref= ;; \ | |
74 | "~~~~~"*) echo "- <<$$ref>>"; ref= ;; \ | |
75 | "[["*"]]") ref="$$line" ;; \ | |
76 | *) ref="$$ref, $$line" ;; \ | |
77 | esac; done | sed 's/\[\[\(.*\)\]\]/\1/' > $@ | |
78 | ||
b801d8b2 JF |
79 | tig: tig.c |
80 | ||
b8ae9346 | 81 | README.html: README |
511147de | 82 | asciidoc -b xhtml11 -d article -a readme $< |
b8ae9346 | 83 | |
de8f9b2b JF |
84 | %.pdf : %.xml |
85 | docbook2pdf $< | |
86 | ||
a7bc4b14 | 87 | %.1.html : %.1.txt |
4c6fabc2 | 88 | asciidoc -b xhtml11 -d manpage $< |
a7bc4b14 JF |
89 | |
90 | %.1.xml : %.1.txt | |
4c6fabc2 | 91 | asciidoc -b docbook -d manpage $< |
a7bc4b14 JF |
92 | |
93 | %.1 : %.1.xml | |
94 | xmlto man $< | |
cb7f42cd JF |
95 | |
96 | %.5.html : %.5.txt | |
97 | asciidoc -b xhtml11 -d manpage $< | |
98 | ||
99 | %.5.xml : %.5.txt | |
100 | asciidoc -b docbook -d manpage $< | |
101 | ||
102 | %.5 : %.5.xml | |
103 | xmlto man $< | |
d839253b JF |
104 | |
105 | %.html : %.txt | |
9783cb12 | 106 | asciidoc -b xhtml11 -d article -n $< |
d839253b JF |
107 | |
108 | %.xml : %.txt | |
109 | asciidoc -b docbook -d article $< | |
110 | ||
111 | %.html-chunked : %.xml | |
112 | xmlto html -o $@ $< | |
604da3b7 JF |
113 | |
114 | # Maintainer stuff | |
115 | sync-docs: | |
116 | cg switch release | |
117 | -cg merge -n master | |
118 | cg commit -m "Merge with master" | |
119 | make doc | |
120 | cg commit -m "Sync docs" | |
121 | cg switch master |