-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
153 lines (128 loc) · 3.98 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
OS:=$(shell uname | sed 's/[-_].*//')
CFLAGS:=-Wall -O2 -Werror $(PYINCLUDE)
SOEXT:=.so
ifeq ($(OS),CYGWIN)
SOEXT:=.dll
endif
default: all
all: bup Documentation/all
bup: lib/bup/_version.py lib/bup/_helpers$(SOEXT) cmds
Documentation/all: bup
INSTALL=install
PYTHON=python
MANDIR=$(DESTDIR)/usr/share/man
DOCDIR=$(DESTDIR)/usr/share/doc/bup
BINDIR=$(DESTDIR)/usr/bin
LIBDIR=$(DESTDIR)/usr/lib/bup
install: all
$(INSTALL) -d $(MANDIR)/man1 $(DOCDIR) $(BINDIR) \
$(LIBDIR)/bup $(LIBDIR)/cmd $(LIBDIR)/tornado \
$(LIBDIR)/web $(LIBDIR)/web/static
[ ! -e Documentation/.docs-available ] || \
$(INSTALL) -m 0644 \
Documentation/*.1 \
$(MANDIR)/man1
[ ! -e Documentation/.docs-available ] || \
$(INSTALL) -m 0644 \
Documentation/*.html \
$(DOCDIR)
$(INSTALL) -m 0755 bup $(BINDIR)
$(INSTALL) -m 0755 \
cmd/bup-* \
$(LIBDIR)/cmd
$(INSTALL) -m 0644 \
lib/bup/*.py \
$(LIBDIR)/bup
$(INSTALL) -m 0755 \
lib/bup/*$(SOEXT) \
$(LIBDIR)/bup
$(INSTALL) -m 0644 \
lib/tornado/*.py \
$(LIBDIR)/tornado
$(INSTALL) -m 0644 \
lib/web/static/* \
$(LIBDIR)/web/static/
$(INSTALL) -m 0644 \
lib/web/*.html \
$(LIBDIR)/web/
%/all:
$(MAKE) -C $* all
%/clean:
$(MAKE) -C $* clean
lib/bup/_helpers$(SOEXT): \
lib/bup/bupsplit.c lib/bup/_helpers.c lib/bup/csetup.py
@rm -f $@
cd lib/bup && LDFLAGS="$(LDFLAGS)" CFLAGS="$(CFLAGS)" $(PYTHON) csetup.py build
cp lib/bup/build/*/_helpers$(SOEXT) lib/bup/
.PHONY: lib/bup/_version.py
lib/bup/_version.py:
rm -f $@ [email protected]
./format-subst.pl [email protected] >[email protected]
mv [email protected] $@
runtests: all runtests-python runtests-cmdline
runtests-python:
$(PYTHON) wvtest.py t/t*.py lib/*/t/t*.py
runtests-cmdline: all
t/test.sh
t/test-meta.sh
stupid:
PATH=/bin:/usr/bin $(MAKE) test
test: all
./wvtestrun $(MAKE) PYTHON=$(PYTHON) runtests
check: test
bup: main.py
rm -f $@
ln -s $< $@
cmds: \
$(patsubst cmd/%-cmd.py,cmd/bup-%,$(wildcard cmd/*-cmd.py)) \
$(patsubst cmd/%-cmd.sh,cmd/bup-%,$(wildcard cmd/*-cmd.sh))
cmd/bup-%: cmd/%-cmd.py
rm -f $@
ln -s $*-cmd.py $@
%: %.py
rm -f $@
ln -s $< $@
bup-%: cmd-%.sh
rm -f $@
ln -s $< $@
cmd/bup-%: cmd/%-cmd.sh
rm -f $@
ln -s $*-cmd.sh $@
# update the local 'man' and 'html' branches with pregenerated output files, for
# people who don't have pandoc (and maybe to aid in google searches or something)
export-docs: Documentation/all
git update-ref refs/heads/man origin/man '' 2>/dev/null || true
git update-ref refs/heads/html origin/html '' 2>/dev/null || true
GIT_INDEX_FILE=gitindex.tmp; export GIT_INDEX_FILE; \
rm -f $${GIT_INDEX_FILE} && \
git add -f Documentation/*.1 && \
git update-ref refs/heads/man \
$$(echo "Autogenerated man pages for $$(git describe)" \
| git commit-tree $$(git write-tree --prefix=Documentation) \
-p refs/heads/man) && \
rm -f $${GIT_INDEX_FILE} && \
git add -f Documentation/*.html && \
git update-ref refs/heads/html \
$$(echo "Autogenerated html pages for $$(git describe)" \
| git commit-tree $$(git write-tree --prefix=Documentation) \
-p refs/heads/html)
# push the pregenerated doc files to origin/man and origin/html
push-docs: export-docs
git push origin man html
# import pregenerated doc files from origin/man and origin/html, in case you
# don't have pandoc but still want to be able to install the docs.
import-docs: Documentation/clean
git archive origin/html | (cd Documentation; tar -xvf -)
git archive origin/man | (cd Documentation; tar -xvf -)
# tgit.py plays with permissions on lib/bup/t/pybuptest.tmp, so we should
# ensure that we can delete the directory before doing it.
clean: Documentation/clean
rm -f *.o lib/*/*.o *.so lib/*/*.so *.dll *.exe \
.*~ *~ */*~ lib/*/*~ lib/*/*/*~ \
*.pyc */*.pyc lib/*/*.pyc lib/*/*/*.pyc \
bup bup-* cmd/bup-* lib/bup/_version.py randomgen memtest \
out[12] out2[tc] tags[12] tags2[tc] \
testfs.img lib/bup/t/testfs.img
rm -rf *.tmp t/*.tmp lib/*/*/*.tmp build lib/bup/build
if test -e testfs; then rmdir testfs; fi
if test -e lib/bup/t/testfs; then rmdir lib/bup/t/testfs; fi