Make keybinding reference more dynamic
[tig] / Makefile
CommitLineData
5f7b975a
JH
1prefix = $(HOME)
2bindir= $(prefix)/bin
3mandir = $(prefix)/man
bb8afc29 4docdir = $(prefix)/share/doc
5f7b975a
JH
5# DESTDIR=
6
a6ec85e1 7LDLIBS = -lcurses
900666fc 8CFLAGS = -Wall -O2
19f862bd 9DFLAGS = -g -DDEBUG -Werror
b801d8b2 10PROGS = tig
ec4b9d91
GK
11DOCS_MAN = tig.1 tigrc.5
12DOCS_HTML = tig.1.html tigrc.5.html \
13 manual.html manual.html-chunked \
14 README.html
15DOCS = $(DOCS_MAN) $(DOCS_HTML) \
16 manual.toc manual.pdf
e2beda18
JF
17
18ifneq (,$(wildcard .git))
9074d9b6
JF
19VERSION = $(shell git-describe)
20WTDIRTY = $(shell git-diff-index --name-only HEAD 2>/dev/null)
21CFLAGS += '-DVERSION="$(VERSION)$(if $(WTDIRTY),-dirty)"'
e2beda18 22endif
800a900c 23
a7bc4b14 24all: $(PROGS)
82e78006
JF
25all-debug: $(PROGS)
26all-debug: CFLAGS += $(DFLAGS)
c92615b1 27doc: $(DOCS)
ec4b9d91
GK
28doc-man: $(DOCS_MAN)
29doc-html: $(DOCS_HTML)
800a900c 30
05f1685b 31install: 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 37install-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
47install-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
55install-doc: install-doc-man install-doc-html
56
05f1685b 57clean:
d839253b 58 rm -rf manual.html-chunked
de8f9b2b 59 rm -f $(PROGS) $(DOCS) core *.xml
05f1685b 60
57bdf034 61spell-check:
8eb62770 62 aspell --lang=en --check tig.1.txt tigrc.5.txt manual.txt
57bdf034 63
0e92d312
JF
64strip: 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 69manual.html: manual.toc
9783cb12
JF
70manual.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
79tig: tig.c
80
b8ae9346 81README.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
115sync-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