##// END OF EJS Templates
make: introduce a target to clean everything but packages...
Pierre-Yves David -
r29640:17b3309b stable
parent child Browse files
Show More
@@ -1,261 +1,264 b''
1 # If you want to change PREFIX, do not just edit it below. The changed
1 # If you want to change PREFIX, do not just edit it below. The changed
2 # value wont get passed on to recursive make calls. You should instead
2 # value wont get passed on to recursive make calls. You should instead
3 # override the variable on the command like:
3 # override the variable on the command like:
4 #
4 #
5 # % make PREFIX=/opt/ install
5 # % make PREFIX=/opt/ install
6
6
7 export PREFIX=/usr/local
7 export PREFIX=/usr/local
8 PYTHON=python
8 PYTHON=python
9 $(eval HGROOT := $(shell pwd))
9 $(eval HGROOT := $(shell pwd))
10 HGPYTHONS ?= $(HGROOT)/build/pythons
10 HGPYTHONS ?= $(HGROOT)/build/pythons
11 PURE=
11 PURE=
12 PYFILES:=$(shell find mercurial hgext doc -name '*.py')
12 PYFILES:=$(shell find mercurial hgext doc -name '*.py')
13 DOCFILES=mercurial/help/*.txt
13 DOCFILES=mercurial/help/*.txt
14 export LANGUAGE=C
14 export LANGUAGE=C
15 export LC_ALL=C
15 export LC_ALL=C
16 TESTFLAGS ?= $(shell echo $$HGTESTFLAGS)
16 TESTFLAGS ?= $(shell echo $$HGTESTFLAGS)
17
17
18 # Set this to e.g. "mingw32" to use a non-default compiler.
18 # Set this to e.g. "mingw32" to use a non-default compiler.
19 COMPILER=
19 COMPILER=
20
20
21 COMPILERFLAG_tmp_ =
21 COMPILERFLAG_tmp_ =
22 COMPILERFLAG_tmp_${COMPILER} ?= -c $(COMPILER)
22 COMPILERFLAG_tmp_${COMPILER} ?= -c $(COMPILER)
23 COMPILERFLAG=${COMPILERFLAG_tmp_${COMPILER}}
23 COMPILERFLAG=${COMPILERFLAG_tmp_${COMPILER}}
24
24
25 help:
25 help:
26 @echo 'Commonly used make targets:'
26 @echo 'Commonly used make targets:'
27 @echo ' all - build program and documentation'
27 @echo ' all - build program and documentation'
28 @echo ' install - install program and man pages to $$PREFIX ($(PREFIX))'
28 @echo ' install - install program and man pages to $$PREFIX ($(PREFIX))'
29 @echo ' install-home - install with setup.py install --home=$$HOME ($(HOME))'
29 @echo ' install-home - install with setup.py install --home=$$HOME ($(HOME))'
30 @echo ' local - build for inplace usage'
30 @echo ' local - build for inplace usage'
31 @echo ' tests - run all tests in the automatic test suite'
31 @echo ' tests - run all tests in the automatic test suite'
32 @echo ' test-foo - run only specified tests (e.g. test-merge1.t)'
32 @echo ' test-foo - run only specified tests (e.g. test-merge1.t)'
33 @echo ' dist - run all tests and create a source tarball in dist/'
33 @echo ' dist - run all tests and create a source tarball in dist/'
34 @echo ' clean - remove files created by other targets'
34 @echo ' clean - remove files created by other targets'
35 @echo ' (except installed files or dist source tarball)'
35 @echo ' (except installed files or dist source tarball)'
36 @echo ' update-pot - update i18n/hg.pot'
36 @echo ' update-pot - update i18n/hg.pot'
37 @echo
37 @echo
38 @echo 'Example for a system-wide installation under /usr/local:'
38 @echo 'Example for a system-wide installation under /usr/local:'
39 @echo ' make all && su -c "make install" && hg version'
39 @echo ' make all && su -c "make install" && hg version'
40 @echo
40 @echo
41 @echo 'Example for a local installation (usable in this directory):'
41 @echo 'Example for a local installation (usable in this directory):'
42 @echo ' make local && ./hg version'
42 @echo ' make local && ./hg version'
43
43
44 all: build doc
44 all: build doc
45
45
46 local:
46 local:
47 $(PYTHON) setup.py $(PURE) \
47 $(PYTHON) setup.py $(PURE) \
48 build_py -c -d . \
48 build_py -c -d . \
49 build_ext $(COMPILERFLAG) -i \
49 build_ext $(COMPILERFLAG) -i \
50 build_hgexe $(COMPILERFLAG) -i \
50 build_hgexe $(COMPILERFLAG) -i \
51 build_mo
51 build_mo
52 env HGRCPATH= $(PYTHON) hg version
52 env HGRCPATH= $(PYTHON) hg version
53
53
54 build:
54 build:
55 $(PYTHON) setup.py $(PURE) build $(COMPILERFLAG)
55 $(PYTHON) setup.py $(PURE) build $(COMPILERFLAG)
56
56
57 wheel:
57 wheel:
58 FORCE_SETUPTOOLS=1 $(PYTHON) setup.py $(PURE) bdist_wheel $(COMPILERFLAG)
58 FORCE_SETUPTOOLS=1 $(PYTHON) setup.py $(PURE) bdist_wheel $(COMPILERFLAG)
59
59
60 doc:
60 doc:
61 $(MAKE) -C doc
61 $(MAKE) -C doc
62
62
63 clean:
63 cleanbutpackages:
64 -$(PYTHON) setup.py clean --all # ignore errors from this command
64 -$(PYTHON) setup.py clean --all # ignore errors from this command
65 find contrib doc hgext hgext3rd i18n mercurial tests \
65 find contrib doc hgext hgext3rd i18n mercurial tests \
66 \( -name '*.py[cdo]' -o -name '*.so' \) -exec rm -f '{}' ';'
66 \( -name '*.py[cdo]' -o -name '*.so' \) -exec rm -f '{}' ';'
67 rm -f $(addprefix mercurial/,$(notdir $(wildcard mercurial/pure/[a-z]*.py)))
67 rm -f $(addprefix mercurial/,$(notdir $(wildcard mercurial/pure/[a-z]*.py)))
68 rm -f MANIFEST MANIFEST.in hgext/__index__.py tests/*.err
68 rm -f MANIFEST MANIFEST.in hgext/__index__.py tests/*.err
69 rm -f mercurial/__modulepolicy__.py
69 rm -f mercurial/__modulepolicy__.py
70 if test -d .hg; then rm -f mercurial/__version__.py; fi
70 if test -d .hg; then rm -f mercurial/__version__.py; fi
71 rm -rf build packages mercurial/locale
71 rm -rf build mercurial/locale
72 $(MAKE) -C doc clean
72 $(MAKE) -C doc clean
73 $(MAKE) -C contrib/chg distclean
73 $(MAKE) -C contrib/chg distclean
74
74
75 clean: cleanbutpackages
76 rm -rf packages
77
75 install: install-bin install-doc
78 install: install-bin install-doc
76
79
77 install-bin: build
80 install-bin: build
78 $(PYTHON) setup.py $(PURE) install --root="$(DESTDIR)/" --prefix="$(PREFIX)" --force
81 $(PYTHON) setup.py $(PURE) install --root="$(DESTDIR)/" --prefix="$(PREFIX)" --force
79
82
80 install-doc: doc
83 install-doc: doc
81 cd doc && $(MAKE) $(MFLAGS) install
84 cd doc && $(MAKE) $(MFLAGS) install
82
85
83 install-home: install-home-bin install-home-doc
86 install-home: install-home-bin install-home-doc
84
87
85 install-home-bin: build
88 install-home-bin: build
86 $(PYTHON) setup.py $(PURE) install --home="$(HOME)" --prefix="" --force
89 $(PYTHON) setup.py $(PURE) install --home="$(HOME)" --prefix="" --force
87
90
88 install-home-doc: doc
91 install-home-doc: doc
89 cd doc && $(MAKE) $(MFLAGS) PREFIX="$(HOME)" install
92 cd doc && $(MAKE) $(MFLAGS) PREFIX="$(HOME)" install
90
93
91 MANIFEST-doc:
94 MANIFEST-doc:
92 $(MAKE) -C doc MANIFEST
95 $(MAKE) -C doc MANIFEST
93
96
94 MANIFEST.in: MANIFEST-doc
97 MANIFEST.in: MANIFEST-doc
95 hg manifest | sed -e 's/^/include /' > MANIFEST.in
98 hg manifest | sed -e 's/^/include /' > MANIFEST.in
96 echo include mercurial/__version__.py >> MANIFEST.in
99 echo include mercurial/__version__.py >> MANIFEST.in
97 sed -e 's/^/include /' < doc/MANIFEST >> MANIFEST.in
100 sed -e 's/^/include /' < doc/MANIFEST >> MANIFEST.in
98
101
99 dist: tests dist-notests
102 dist: tests dist-notests
100
103
101 dist-notests: doc MANIFEST.in
104 dist-notests: doc MANIFEST.in
102 TAR_OPTIONS="--owner=root --group=root --mode=u+w,go-w,a+rX-s" $(PYTHON) setup.py -q sdist
105 TAR_OPTIONS="--owner=root --group=root --mode=u+w,go-w,a+rX-s" $(PYTHON) setup.py -q sdist
103
106
104 check: tests
107 check: tests
105
108
106 tests:
109 tests:
107 cd tests && $(PYTHON) run-tests.py $(TESTFLAGS)
110 cd tests && $(PYTHON) run-tests.py $(TESTFLAGS)
108
111
109 test-%:
112 test-%:
110 cd tests && $(PYTHON) run-tests.py $(TESTFLAGS) $@
113 cd tests && $(PYTHON) run-tests.py $(TESTFLAGS) $@
111
114
112 testpy-%:
115 testpy-%:
113 @echo Looking for Python $* in $(HGPYTHONS)
116 @echo Looking for Python $* in $(HGPYTHONS)
114 [ -e $(HGPYTHONS)/$*/bin/python ] || ( \
117 [ -e $(HGPYTHONS)/$*/bin/python ] || ( \
115 cd $$(mktemp --directory --tmpdir) && \
118 cd $$(mktemp --directory --tmpdir) && \
116 $(MAKE) -f $(HGROOT)/contrib/Makefile.python PYTHONVER=$* PREFIX=$(HGPYTHONS)/$* python )
119 $(MAKE) -f $(HGROOT)/contrib/Makefile.python PYTHONVER=$* PREFIX=$(HGPYTHONS)/$* python )
117 cd tests && $(HGPYTHONS)/$*/bin/python run-tests.py $(TESTFLAGS)
120 cd tests && $(HGPYTHONS)/$*/bin/python run-tests.py $(TESTFLAGS)
118
121
119 check-code:
122 check-code:
120 hg manifest | xargs python contrib/check-code.py
123 hg manifest | xargs python contrib/check-code.py
121
124
122 update-pot: i18n/hg.pot
125 update-pot: i18n/hg.pot
123
126
124 i18n/hg.pot: $(PYFILES) $(DOCFILES) i18n/posplit i18n/hggettext
127 i18n/hg.pot: $(PYFILES) $(DOCFILES) i18n/posplit i18n/hggettext
125 $(PYTHON) i18n/hggettext mercurial/commands.py \
128 $(PYTHON) i18n/hggettext mercurial/commands.py \
126 hgext/*.py hgext/*/__init__.py \
129 hgext/*.py hgext/*/__init__.py \
127 mercurial/fileset.py mercurial/revset.py \
130 mercurial/fileset.py mercurial/revset.py \
128 mercurial/templatefilters.py mercurial/templatekw.py \
131 mercurial/templatefilters.py mercurial/templatekw.py \
129 mercurial/templater.py \
132 mercurial/templater.py \
130 mercurial/filemerge.py \
133 mercurial/filemerge.py \
131 mercurial/hgweb/webcommands.py \
134 mercurial/hgweb/webcommands.py \
132 $(DOCFILES) > i18n/hg.pot.tmp
135 $(DOCFILES) > i18n/hg.pot.tmp
133 # All strings marked for translation in Mercurial contain
136 # All strings marked for translation in Mercurial contain
134 # ASCII characters only. But some files contain string
137 # ASCII characters only. But some files contain string
135 # literals like this '\037\213'. xgettext thinks it has to
138 # literals like this '\037\213'. xgettext thinks it has to
136 # parse them even though they are not marked for translation.
139 # parse them even though they are not marked for translation.
137 # Extracting with an explicit encoding of ISO-8859-1 will make
140 # Extracting with an explicit encoding of ISO-8859-1 will make
138 # xgettext "parse" and ignore them.
141 # xgettext "parse" and ignore them.
139 echo $(PYFILES) | xargs \
142 echo $(PYFILES) | xargs \
140 xgettext --package-name "Mercurial" \
143 xgettext --package-name "Mercurial" \
141 --msgid-bugs-address "<mercurial-devel@selenic.com>" \
144 --msgid-bugs-address "<mercurial-devel@selenic.com>" \
142 --copyright-holder "Matt Mackall <mpm@selenic.com> and others" \
145 --copyright-holder "Matt Mackall <mpm@selenic.com> and others" \
143 --from-code ISO-8859-1 --join --sort-by-file --add-comments=i18n: \
146 --from-code ISO-8859-1 --join --sort-by-file --add-comments=i18n: \
144 -d hg -p i18n -o hg.pot.tmp
147 -d hg -p i18n -o hg.pot.tmp
145 $(PYTHON) i18n/posplit i18n/hg.pot.tmp
148 $(PYTHON) i18n/posplit i18n/hg.pot.tmp
146 # The target file is not created before the last step. So it never is in
149 # The target file is not created before the last step. So it never is in
147 # an intermediate state.
150 # an intermediate state.
148 mv -f i18n/hg.pot.tmp i18n/hg.pot
151 mv -f i18n/hg.pot.tmp i18n/hg.pot
149
152
150 %.po: i18n/hg.pot
153 %.po: i18n/hg.pot
151 # work on a temporary copy for never having a half completed target
154 # work on a temporary copy for never having a half completed target
152 cp $@ $@.tmp
155 cp $@ $@.tmp
153 msgmerge --no-location --update $@.tmp $^
156 msgmerge --no-location --update $@.tmp $^
154 mv -f $@.tmp $@
157 mv -f $@.tmp $@
155
158
156 # Packaging targets
159 # Packaging targets
157
160
158 osx:
161 osx:
159 /usr/bin/python2.7 setup.py install --optimize=1 \
162 /usr/bin/python2.7 setup.py install --optimize=1 \
160 --root=build/mercurial/ --prefix=/usr/local/ \
163 --root=build/mercurial/ --prefix=/usr/local/ \
161 --install-lib=/Library/Python/2.7/site-packages/
164 --install-lib=/Library/Python/2.7/site-packages/
162 make -C doc all install DESTDIR="$(PWD)/build/mercurial/"
165 make -C doc all install DESTDIR="$(PWD)/build/mercurial/"
163 mkdir -p $${OUTPUTDIR:-dist}
166 mkdir -p $${OUTPUTDIR:-dist}
164 pkgbuild --root build/mercurial/ --identifier org.mercurial-scm.mercurial \
167 pkgbuild --root build/mercurial/ --identifier org.mercurial-scm.mercurial \
165 build/mercurial.pkg
168 build/mercurial.pkg
166 HGVER=$$((cat build/mercurial/Library/Python/2.7/site-packages/mercurial/__version__.py; echo 'print(version)') | python) && \
169 HGVER=$$((cat build/mercurial/Library/Python/2.7/site-packages/mercurial/__version__.py; echo 'print(version)') | python) && \
167 OSXVER=$$(sw_vers -productVersion | cut -d. -f1,2) && \
170 OSXVER=$$(sw_vers -productVersion | cut -d. -f1,2) && \
168 productbuild --distribution contrib/macosx/distribution.xml \
171 productbuild --distribution contrib/macosx/distribution.xml \
169 --package-path build/ \
172 --package-path build/ \
170 --version "$${HGVER}" \
173 --version "$${HGVER}" \
171 --resources contrib/macosx/ \
174 --resources contrib/macosx/ \
172 "$${OUTPUTDIR:-dist/}"/Mercurial-"$${HGVER}"-macosx"$${OSXVER}".pkg
175 "$${OUTPUTDIR:-dist/}"/Mercurial-"$${HGVER}"-macosx"$${OSXVER}".pkg
173
176
174 deb:
177 deb:
175 contrib/builddeb
178 contrib/builddeb
176
179
177 ppa:
180 ppa:
178 contrib/builddeb --source-only
181 contrib/builddeb --source-only
179
182
180 docker-debian-jessie:
183 docker-debian-jessie:
181 mkdir -p packages/debian-jessie
184 mkdir -p packages/debian-jessie
182 contrib/dockerdeb debian jessie
185 contrib/dockerdeb debian jessie
183
186
184 contrib/docker/ubuntu-%: contrib/docker/ubuntu.template
187 contrib/docker/ubuntu-%: contrib/docker/ubuntu.template
185 sed "s/__CODENAME__/$*/" $< > $@
188 sed "s/__CODENAME__/$*/" $< > $@
186
189
187 docker-ubuntu-trusty: contrib/docker/ubuntu-trusty
190 docker-ubuntu-trusty: contrib/docker/ubuntu-trusty
188 contrib/dockerdeb ubuntu trusty
191 contrib/dockerdeb ubuntu trusty
189
192
190 docker-ubuntu-trusty-ppa: contrib/docker/ubuntu-trusty
193 docker-ubuntu-trusty-ppa: contrib/docker/ubuntu-trusty
191 contrib/dockerdeb ubuntu trusty --source-only
194 contrib/dockerdeb ubuntu trusty --source-only
192
195
193 docker-ubuntu-wily: contrib/docker/ubuntu-wily
196 docker-ubuntu-wily: contrib/docker/ubuntu-wily
194 contrib/dockerdeb ubuntu wily
197 contrib/dockerdeb ubuntu wily
195
198
196 docker-ubuntu-wily-ppa: contrib/docker/ubuntu-wily
199 docker-ubuntu-wily-ppa: contrib/docker/ubuntu-wily
197 contrib/dockerdeb ubuntu wily --source-only
200 contrib/dockerdeb ubuntu wily --source-only
198
201
199 docker-ubuntu-xenial: contrib/docker/ubuntu-xenial
202 docker-ubuntu-xenial: contrib/docker/ubuntu-xenial
200 contrib/dockerdeb ubuntu xenial
203 contrib/dockerdeb ubuntu xenial
201
204
202 docker-ubuntu-xenial-ppa: contrib/docker/ubuntu-xenial
205 docker-ubuntu-xenial-ppa: contrib/docker/ubuntu-xenial
203 contrib/dockerdeb ubuntu xenial --source-only
206 contrib/dockerdeb ubuntu xenial --source-only
204
207
205 fedora20:
208 fedora20:
206 mkdir -p packages/fedora20
209 mkdir -p packages/fedora20
207 contrib/buildrpm
210 contrib/buildrpm
208 cp rpmbuild/RPMS/*/* packages/fedora20
211 cp rpmbuild/RPMS/*/* packages/fedora20
209 cp rpmbuild/SRPMS/* packages/fedora20
212 cp rpmbuild/SRPMS/* packages/fedora20
210 rm -rf rpmbuild
213 rm -rf rpmbuild
211
214
212 docker-fedora20:
215 docker-fedora20:
213 mkdir -p packages/fedora20
216 mkdir -p packages/fedora20
214 contrib/dockerrpm fedora20
217 contrib/dockerrpm fedora20
215
218
216 fedora21:
219 fedora21:
217 mkdir -p packages/fedora21
220 mkdir -p packages/fedora21
218 contrib/buildrpm
221 contrib/buildrpm
219 cp rpmbuild/RPMS/*/* packages/fedora21
222 cp rpmbuild/RPMS/*/* packages/fedora21
220 cp rpmbuild/SRPMS/* packages/fedora21
223 cp rpmbuild/SRPMS/* packages/fedora21
221 rm -rf rpmbuild
224 rm -rf rpmbuild
222
225
223 docker-fedora21:
226 docker-fedora21:
224 mkdir -p packages/fedora21
227 mkdir -p packages/fedora21
225 contrib/dockerrpm fedora21
228 contrib/dockerrpm fedora21
226
229
227 centos5:
230 centos5:
228 mkdir -p packages/centos5
231 mkdir -p packages/centos5
229 contrib/buildrpm --withpython
232 contrib/buildrpm --withpython
230 cp rpmbuild/RPMS/*/* packages/centos5
233 cp rpmbuild/RPMS/*/* packages/centos5
231 cp rpmbuild/SRPMS/* packages/centos5
234 cp rpmbuild/SRPMS/* packages/centos5
232
235
233 docker-centos5:
236 docker-centos5:
234 mkdir -p packages/centos5
237 mkdir -p packages/centos5
235 contrib/dockerrpm centos5 --withpython
238 contrib/dockerrpm centos5 --withpython
236
239
237 centos6:
240 centos6:
238 mkdir -p packages/centos6
241 mkdir -p packages/centos6
239 contrib/buildrpm
242 contrib/buildrpm
240 cp rpmbuild/RPMS/*/* packages/centos6
243 cp rpmbuild/RPMS/*/* packages/centos6
241 cp rpmbuild/SRPMS/* packages/centos6
244 cp rpmbuild/SRPMS/* packages/centos6
242
245
243 docker-centos6:
246 docker-centos6:
244 mkdir -p packages/centos6
247 mkdir -p packages/centos6
245 contrib/dockerrpm centos6
248 contrib/dockerrpm centos6
246
249
247 centos7:
250 centos7:
248 mkdir -p packages/centos7
251 mkdir -p packages/centos7
249 contrib/buildrpm
252 contrib/buildrpm
250 cp rpmbuild/RPMS/*/* packages/centos7
253 cp rpmbuild/RPMS/*/* packages/centos7
251 cp rpmbuild/SRPMS/* packages/centos7
254 cp rpmbuild/SRPMS/* packages/centos7
252
255
253 docker-centos7:
256 docker-centos7:
254 mkdir -p packages/centos7
257 mkdir -p packages/centos7
255 contrib/dockerrpm centos7
258 contrib/dockerrpm centos7
256
259
257 .PHONY: help all local build doc clean install install-bin install-doc \
260 .PHONY: help all local build doc cleanbutpackages clean install install-bin \
258 install-home install-home-bin install-home-doc \
261 install-doc install-home install-home-bin install-home-doc \
259 dist dist-notests check tests check-code update-pot \
262 dist dist-notests check tests check-code update-pot \
260 osx fedora20 docker-fedora20 fedora21 docker-fedora21 \
263 osx fedora20 docker-fedora20 fedora21 docker-fedora21 \
261 centos5 docker-centos5 centos6 docker-centos6 centos7 docker-centos7
264 centos5 docker-centos5 centos6 docker-centos6 centos7 docker-centos7
General Comments 0
You need to be logged in to leave comments. Login now