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