~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to Makefile

Turn completion assertions into separate methods.

Many common assertions used to be expressed as arguments to the complete
method.  This makes the checks more explicit, and the code easier to read.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005-2011 Canonical Ltd
2
 
#
3
 
# This program is free software; you can redistribute it and/or modify
4
 
# it under the terms of the GNU General Public License as published by
5
 
# the Free Software Foundation; either version 2 of the License, or
6
 
# (at your option) any later version.
7
 
#
8
 
# This program is distributed in the hope that it will be useful,
9
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
 
# GNU General Public License for more details.
12
 
#
13
 
# You should have received a copy of the GNU General Public License
14
 
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
 
 
17
 
# A relatively simple Makefile to assist in building parts of bzr. Mostly for
18
 
# building documentation, etc.
19
 
 
20
 
 
21
 
### Core Stuff ###
22
 
 
23
 
PYTHON=python
24
 
PYTHON24=python24
25
 
PYTHON25=python25
26
 
PYTHON26=python26
27
 
BZR_TARGET=release
28
 
PLUGIN_TARGET=plugin-release
29
 
PYTHON_BUILDFLAGS=
30
 
 
31
 
.PHONY: all clean realclean extensions pyflakes api-docs check-nodocs check
32
 
 
33
 
all: extensions
34
 
 
35
 
extensions:
36
 
        @echo "building extension modules."
37
 
        $(PYTHON) setup.py build_ext -i $(PYTHON_BUILDFLAGS)
38
 
 
39
 
check: docs check-nodocs
40
 
 
41
 
check-nodocs: extensions
42
 
        set -e
43
 
        # Generate a stream for PQM to watch.
44
 
        -$(RM) -f selftest.log
45
 
        $(PYTHON) -Werror -Wignore::ImportWarning -O ./bzr selftest --subunit $(tests) | tee selftest.log
46
 
        # An empty log file should catch errors in the $(PYTHON)
47
 
        # command above (the '|' swallow any errors since 'make'
48
 
        # sees the 'tee' exit code for the whole line
49
 
        if [ ! -s selftest.log ] ; then exit 1 ; fi
50
 
        # Check that there were no errors reported.
51
 
        subunit-stats < selftest.log
52
 
 
53
 
# Run Python style checker (apt-get install pyflakes)
54
 
#
55
 
# Note that at present this gives many false warnings, because it doesn't
56
 
# know about identifiers loaded through lazy_import.
57
 
pyflakes:
58
 
        pyflakes bzrlib
59
 
 
60
 
pyflakes-nounused:
61
 
        # There are many of these warnings at the moment and they're not a
62
 
        # high priority to fix
63
 
        pyflakes bzrlib | grep -v ' imported but unused'
64
 
 
65
 
clean:
66
 
        $(PYTHON) setup.py clean
67
 
        -find . -name "*.pyc" -o -name "*.pyo" -o -name "*.so" | xargs rm -f
68
 
 
69
 
realclean: clean
70
 
        # Remove files which are autogenerated but included by the tarball.
71
 
        rm -f bzrlib/*_pyx.c
72
 
        rm -f bzrlib/_simple_set_pyx.h bzrlib/_simple_set_pyx_api.h
73
 
 
74
 
# Build API documentation
75
 
docfiles = bzr bzrlib
76
 
api-docs:
77
 
        mkdir -p api/html
78
 
        pydoctor --make-html --docformat='restructuredtext' --html-output=api/html $(docfiles)
79
 
 
80
 
# build tags for emacs and vim
81
 
TAGS:
82
 
        ctags -R -e bzrlib
83
 
 
84
 
tags:
85
 
        ctags -R bzrlib
86
 
 
87
 
# these are treated as phony so they'll always be rebuilt - it's pretty quick
88
 
.PHONY: TAGS tags
89
 
 
90
 
 
91
 
### Documentation ###
92
 
 
93
 
# Default to plain documentation for maximum backwards compatibility.
94
 
# (Post 2.0, the defaults will most likely be Sphinx-style instead.)
95
 
 
96
 
docs: docs-plain
97
 
 
98
 
clean-docs: clean-plain
99
 
 
100
 
html-docs: html-plain
101
 
 
102
 
 
103
 
### Man-page Documentation ###
104
 
 
105
 
MAN_DEPENDENCIES = bzrlib/builtins.py \
106
 
        $(wildcard bzrlib/*.py) \
107
 
        $(wildcard bzrlib/*/*.py) \
108
 
        tools/generate_docs.py \
109
 
        $(wildcard $(addsuffix /*.txt, bzrlib/help_topics/en)) 
110
 
 
111
 
MAN_PAGES = man1/bzr.1
112
 
man1/bzr.1: $(MAN_DEPENDENCIES)
113
 
        $(PYTHON) tools/generate_docs.py -o $@ man
114
 
 
115
 
 
116
 
### Sphinx-style Documentation ###
117
 
 
118
 
# Build the documentation. To keep the dependencies down to a minimum
119
 
# for distro packagers, we only build the html documentation by default.
120
 
# Sphinx 0.6 or later is preferred for the best rendering, though
121
 
# Sphinx 0.4 or later should work. See http://sphinx.pocoo.org/index.html
122
 
# for installation instructions.
123
 
docs-sphinx: html-sphinx
124
 
 
125
 
# Clean out generated documentation
126
 
clean-sphinx:
127
 
        cd doc/en && make clean
128
 
        cd doc/es && make clean
129
 
        cd doc/ja && make clean
130
 
        cd doc/ru && make clean
131
 
        cd doc/developers && make clean
132
 
 
133
 
SPHINX_DEPENDENCIES = \
134
 
        doc/en/release-notes/index.txt \
135
 
        doc/en/user-reference/index.txt \
136
 
        doc/es/Makefile \
137
 
        doc/es/make.bat \
138
 
        doc/ja/Makefile \
139
 
        doc/ja/make.bat \
140
 
        doc/ru/Makefile \
141
 
        doc/ru/make.bat \
142
 
        doc/developers/Makefile \
143
 
        doc/developers/make.bat
144
 
 
145
 
NEWS_FILES = $(wildcard doc/en/release-notes/bzr-*.txt)
146
 
 
147
 
doc/en/user-reference/index.txt: $(MAN_DEPENDENCIES)
148
 
        $(PYTHON) tools/generate_docs.py -o $@ rstx
149
 
 
150
 
doc/en/release-notes/index.txt: $(NEWS_FILES) tools/generate_release_notes.py
151
 
        $(PYTHON) tools/generate_release_notes.py $@ $(NEWS_FILES)
152
 
 
153
 
doc/%/Makefile: doc/en/Makefile
154
 
        $(PYTHON) -c "import shutil; shutil.copyfile('$<', '$@')"
155
 
 
156
 
doc/%/make.bat: doc/en/make.bat
157
 
        $(PYTHON) -c "import shutil; shutil.copyfile('$<', '$@')"
158
 
 
159
 
# Build the html docs using Sphinx.
160
 
html-sphinx: $(SPHINX_DEPENDENCIES)
161
 
        cd doc/en && make html
162
 
        cd doc/es && make html
163
 
        cd doc/ru && make html
164
 
        cd doc/ja && make html
165
 
        cd doc/developers && make html
166
 
 
167
 
# Build the PDF docs using Sphinx. This requires numerous LaTeX
168
 
# packages. See http://sphinx.pocoo.org/builders.html for details.
169
 
# Note: We don't currently build PDFs for the Russian docs because
170
 
# they require additional packages to be installed (to handle
171
 
# Russian hyphenation rules, etc.)
172
 
pdf-sphinx: $(SPHINX_DEPENDENCIES)
173
 
        cd doc/en && make latex
174
 
        cd doc/es && make latex
175
 
        cd doc/ja && make latex
176
 
        cd doc/developers && make latex
177
 
        cd doc/en/_build/latex && make all-pdf
178
 
        cd doc/es/_build/latex && make all-pdf
179
 
        cd doc/developers/_build/latex && make all-pdf
180
 
 
181
 
# Build the CHM (Windows Help) docs using Sphinx.
182
 
# Note: HtmlHelp Workshop needs to be used on the generated hhp files
183
 
# to generate the final chm files.
184
 
chm-sphinx: $(SPHINX_DEPENDENCIES)
185
 
        cd doc/en && make htmlhelp
186
 
        cd doc/es && make htmlhelp
187
 
        cd doc/ru && make htmlhelp
188
 
        cd doc/ja && make htmlhelp
189
 
        cd doc/developers && make htmlhelp
190
 
 
191
 
 
192
 
### Documentation Website ###
193
 
 
194
 
# Where to build the website
195
 
DOC_WEBSITE_BUILD = build_doc_website
196
 
 
197
 
# Build and package docs into a website, complete with downloads.
198
 
doc-website: html-sphinx pdf-sphinx
199
 
        $(PYTHON) tools/package_docs.py doc/en $(DOC_WEBSITE_BUILD)
200
 
        $(PYTHON) tools/package_docs.py doc/es $(DOC_WEBSITE_BUILD)
201
 
        $(PYTHON) tools/package_docs.py doc/ru $(DOC_WEBSITE_BUILD)
202
 
        $(PYTHON) tools/package_docs.py doc/ja $(DOC_WEBSITE_BUILD)
203
 
        $(PYTHON) tools/package_docs.py doc/developers $(DOC_WEBSITE_BUILD)
204
 
 
205
 
 
206
 
### Plain Documentation ###
207
 
 
208
 
# While Sphinx is the preferred tool for building documentation, we still
209
 
# support our "plain" html documentation so that Sphinx is not a hard
210
 
# dependency for packagers on older platforms.
211
 
 
212
 
rst2html = $(PYTHON) tools/rst2html.py --link-stylesheet --footnote-references=superscript --halt=warning
213
 
 
214
 
# translate txt docs to html
215
 
derived_txt_files = \
216
 
        doc/en/release-notes/NEWS.txt
217
 
txt_all = \
218
 
        doc/en/tutorials/tutorial.txt \
219
 
        doc/en/tutorials/using_bazaar_with_launchpad.txt \
220
 
        doc/en/tutorials/centralized_workflow.txt \
221
 
        $(wildcard doc/es/tutorials/*.txt) \
222
 
                $(wildcard doc/ru/tutorials/*.txt) \
223
 
        doc/ja/tutorials/tutorial.txt \
224
 
        doc/ja/tutorials/using_bazaar_with_launchpad.txt \
225
 
        doc/ja/tutorials/centralized_workflow.txt \
226
 
        $(wildcard doc/*/mini-tutorial/index.txt) \
227
 
        $(wildcard doc/*/user-guide/index-plain.txt) \
228
 
        doc/en/admin-guide/index-plain.txt \
229
 
        $(wildcard doc/es/guia-usario/*.txt) \
230
 
        $(derived_txt_files) \
231
 
        doc/en/upgrade-guide/index.txt \
232
 
        doc/index.txt \
233
 
        $(wildcard doc/index.*.txt)
234
 
txt_nohtml = \
235
 
        doc/en/user-guide/index.txt \
236
 
        doc/es/user-guide/index.txt \
237
 
        doc/ja/user-guide/index.txt \
238
 
        doc/ru/user-guide/index.txt \
239
 
        doc/en/admin-guide/index.txt
240
 
txt_files = $(filter-out $(txt_nohtml), $(txt_all))
241
 
htm_files = $(patsubst %.txt, %.html, $(txt_files)) 
242
 
 
243
 
non_txt_files = \
244
 
       doc/default.css \
245
 
       $(wildcard doc/*/bzr-en-quick-reference.svg) \
246
 
       $(wildcard doc/*/bzr-en-quick-reference.png) \
247
 
       $(wildcard doc/*/bzr-en-quick-reference.pdf) \
248
 
       $(wildcard doc/*/bzr-es-quick-reference.svg) \
249
 
       $(wildcard doc/*/bzr-es-quick-reference.png) \
250
 
       $(wildcard doc/*/bzr-es-quick-reference.pdf) \
251
 
       $(wildcard doc/*/bzr-ru-quick-reference.svg) \
252
 
       $(wildcard doc/*/bzr-ru-quick-reference.png) \
253
 
       $(wildcard doc/*/bzr-ru-quick-reference.pdf) \
254
 
       $(wildcard doc/*/user-guide/images/*.png)
255
 
 
256
 
# doc/developers/*.txt files that should *not* be individually
257
 
# converted to HTML
258
 
dev_txt_nohtml = \
259
 
        doc/developers/add.txt \
260
 
        doc/developers/annotate.txt \
261
 
        doc/developers/bundle-creation.txt \
262
 
        doc/developers/commit.txt \
263
 
        doc/developers/diff.txt \
264
 
        doc/developers/directory-fingerprints.txt \
265
 
        doc/developers/gc.txt \
266
 
        doc/developers/implementation-notes.txt \
267
 
        doc/developers/incremental-push-pull.txt \
268
 
        doc/developers/index.txt \
269
 
        doc/developers/initial-push-pull.txt \
270
 
        doc/developers/merge-scaling.txt \
271
 
        doc/developers/miscellaneous-notes.txt \
272
 
        doc/developers/missing.txt \
273
 
        doc/developers/performance-roadmap-rationale.txt \
274
 
        doc/developers/performance-use-case-analysis.txt \
275
 
        doc/developers/planned-change-integration.txt \
276
 
        doc/developers/planned-performance-changes.txt \
277
 
        doc/developers/plans.txt \
278
 
        doc/developers/process.txt \
279
 
        doc/developers/revert.txt \
280
 
        doc/developers/specifications.txt \
281
 
        doc/developers/status.txt \
282
 
        doc/developers/uncommit.txt
283
 
 
284
 
dev_txt_all = $(wildcard $(addsuffix /*.txt, doc/developers))
285
 
dev_txt_files = $(filter-out $(dev_txt_nohtml), $(dev_txt_all))
286
 
dev_htm_files = $(patsubst %.txt, %.html, $(dev_txt_files)) 
287
 
 
288
 
doc/en/user-guide/index-plain.html: $(wildcard $(addsuffix /*.txt, doc/en/user-guide)) 
289
 
        $(rst2html) --stylesheet=../../default.css $(dir $@)index-plain.txt $@
290
 
 
291
 
#doc/es/user-guide/index.html: $(wildcard $(addsuffix /*.txt, doc/es/user-guide)) 
292
 
#       $(rst2html) --stylesheet=../../default.css $(dir $@)index.txt $@
293
 
#
294
 
#doc/ru/user-guide/index.html: $(wildcard $(addsuffix /*.txt, doc/ru/user-guide)) 
295
 
#       $(rst2html) --stylesheet=../../default.css $(dir $@)index.txt $@
296
 
#
297
 
doc/en/admin-guide/index-plain.html: $(wildcard $(addsuffix /*.txt, doc/en/admin-guide)) 
298
 
        $(rst2html) --stylesheet=../../default.css $(dir $@)index-plain.txt $@
299
 
 
300
 
doc/developers/%.html: doc/developers/%.txt
301
 
        $(rst2html) --stylesheet=../default.css $< $@
302
 
 
303
 
doc/index.html: doc/index.txt
304
 
        $(rst2html) --stylesheet=default.css $< $@
305
 
 
306
 
doc/index.%.html: doc/index.%.txt
307
 
        $(rst2html) --stylesheet=default.css $< $@
308
 
 
309
 
%.html: %.txt
310
 
        $(rst2html) --stylesheet=../../default.css $< "$@"
311
 
 
312
 
doc/en/release-notes/NEWS.txt: $(NEWS_FILES) tools/generate_release_notes.py
313
 
        $(PYTHON) tools/generate_release_notes.py "$@" $(NEWS_FILES)
314
 
 
315
 
upgrade_guide_dependencies =  $(wildcard $(addsuffix /*.txt, doc/en/upgrade-guide)) 
316
 
 
317
 
doc/en/upgrade-guide/index.html: $(upgrade_guide_dependencies)
318
 
        $(rst2html) --stylesheet=../../default.css $(dir $@)index.txt $@
319
 
 
320
 
derived_web_docs = $(htm_files) $(dev_htm_files) 
321
 
WEB_DOCS = $(derived_web_docs) $(non_txt_files)
322
 
ALL_DOCS = $(derived_web_docs) $(MAN_PAGES)
323
 
 
324
 
# the main target to build all the docs
325
 
docs-plain: $(ALL_DOCS)
326
 
 
327
 
# produce a tree containing just the final docs, ready for uploading to the web
328
 
HTMLDIR = html_docs
329
 
html-plain: docs-plain
330
 
        $(PYTHON) tools/win32/ostools.py copytree $(WEB_DOCS) $(HTMLDIR)
331
 
 
332
 
# clean produced docs
333
 
clean-plain:
334
 
        $(PYTHON) tools/win32/ostools.py remove $(ALL_DOCS) \
335
 
            $(HTMLDIR) $(derived_txt_files)
336
 
 
337
 
 
338
 
### Miscellaneous Documentation Targets ###
339
 
 
340
 
# build a png of our performance task list
341
 
# this is no longer built by default; you can build it if you want to look at it
342
 
doc/developers/performance.png: doc/developers/performance.dot
343
 
        @echo Generating $@
344
 
        @dot -Tpng $< -o$@ || echo "Dot not installed; skipping generation of $@"
345
 
 
346
 
 
347
 
### Windows Support ###
348
 
 
349
 
# make all the installers completely from scratch, using zc.buildout
350
 
# to fetch the dependencies
351
 
# These are files that need to be copied into the build location to boostrap
352
 
# the build process.
353
 
# Note that the path is relative to tools/win32
354
 
BUILDOUT_FILES = buildout.cfg \
355
 
        buildout-templates/bin/build-installer.bat.in \
356
 
        ostools.py bootstrap.py
357
 
 
358
 
installer-all:
359
 
        @echo Make all the installers from scratch
360
 
        @# Build everything in a separate directory, to avoid cluttering the WT
361
 
        $(PYTHON) tools/win32/ostools.py makedir build-win32
362
 
        @# cd to tools/win32 so that the relative paths are copied correctly
363
 
        cd tools/win32 && $(PYTHON) ostools.py copytree $(BUILDOUT_FILES) ../../build-win32
364
 
        @# There seems to be a bug in gf.release.bzr, It doesn't correctly update
365
 
        @# existing release directories, so delete them manually before building
366
 
        @# It means things may be rebuilt that don't need to be, but at least
367
 
        @# it will be correct when they do.
368
 
        cd build-win32 && $(PYTHON) ostools.py remove release */release
369
 
        cd build-win32 && $(PYTHON) bootstrap.py
370
 
        cd build-win32 && bin/buildout
371
 
        cd build-win32 && bin/build-installer.bat $(BZR_TARGET) $(PLUGIN_TARGET)
372
 
 
373
 
 
374
 
clean-installer-all:
375
 
        $(PYTHON) tools/win32/ostools.py remove build-win32
376
 
 
377
 
# make bzr.exe for win32 with py2exe
378
 
exe:
379
 
        @echo *** Make bzr.exe
380
 
        $(PYTHON) tools/win32/ostools.py remove bzrlib/*.pyd
381
 
        $(PYTHON) setup.py build_ext -i -f $(PYTHON_BUILDFLAGS)
382
 
        $(PYTHON) setup.py py2exe > py2exe.log
383
 
        $(PYTHON) tools/win32/ostools.py copytodir tools/win32/start_bzr.bat win32_bzr.exe
384
 
        $(PYTHON) tools/win32/ostools.py copytodir tools/win32/bazaar.url win32_bzr.exe
385
 
 
386
 
# win32 installer for bzr.exe
387
 
installer: exe copy-docs
388
 
        @echo *** Make Windows installer
389
 
        $(PYTHON) tools/win32/run_script.py cog.py -d -o tools/win32/bzr.iss tools/win32/bzr.iss.cog
390
 
        iscc /Q tools/win32/bzr.iss
391
 
 
392
 
# win32 Python's distutils-based installer
393
 
# require to have Python interpreter installed on win32
394
 
py-inst-24: docs
395
 
        $(PYTHON24) setup.py bdist_wininst --install-script="bzr-win32-bdist-postinstall.py" -d .
396
 
 
397
 
py-inst-25: docs
398
 
        $(PYTHON25) setup.py bdist_wininst --install-script="bzr-win32-bdist-postinstall.py" -d .
399
 
 
400
 
py-inst-26: docs
401
 
        $(PYTHON26) setup.py bdist_wininst --install-script="bzr-win32-bdist-postinstall.py" -d .
402
 
 
403
 
python-installer: py-inst-24 py-inst-25 py-inst-26
404
 
 
405
 
 
406
 
copy-docs: docs
407
 
        $(PYTHON) tools/win32/ostools.py copytodir README win32_bzr.exe/doc
408
 
        $(PYTHON) tools/win32/ostools.py copytree $(WEB_DOCS) win32_bzr.exe
409
 
 
410
 
# clean on win32 all installer-related files and directories
411
 
clean-win32: clean-docs
412
 
        $(PYTHON) tools/win32/ostools.py remove build
413
 
        $(PYTHON) tools/win32/ostools.py remove win32_bzr.exe
414
 
        $(PYTHON) tools/win32/ostools.py remove py2exe.log
415
 
        $(PYTHON) tools/win32/ostools.py remove tools/win32/bzr.iss
416
 
        $(PYTHON) tools/win32/ostools.py remove bzr-setup*.exe
417
 
        $(PYTHON) tools/win32/ostools.py remove bzr-*win32.exe
418
 
        $(PYTHON) tools/win32/ostools.py remove dist
419
 
 
420
 
 
421
 
# i18n targets
422
 
 
423
 
.PHONY: update-pot po/bzr.pot
424
 
update-pot: po/bzr.pot
425
 
 
426
 
TRANSLATABLE_PYFILES:=$(shell find bzrlib -name '*.py' \
427
 
                | grep -v 'bzrlib/tests/' \
428
 
                | grep -v 'bzrlib/doc' \
429
 
                )
430
 
 
431
 
po/bzr.pot: $(PYFILES) $(DOCFILES)
432
 
        $(PYTHON) ./bzr export-pot > po/bzr.pot
433
 
        echo $(TRANSLATABLE_PYFILES) | xargs \
434
 
          xgettext --package-name "bzr" \
435
 
          --msgid-bugs-address "<bazaar@canonical.com>" \
436
 
          --copyright-holder "Canonical" \
437
 
          --from-code ISO-8859-1 --join --sort-by-file --add-comments=i18n: \
438
 
          -d bzr -p po -o bzr.pot
439
 
 
440
 
 
441
 
### Packaging Targets ###
442
 
 
443
 
.PHONY: dist check-dist-tarball
444
 
 
445
 
# build a distribution source tarball
446
 
#
447
 
# this method of copying the pyrex generated files is a bit ugly; it would be
448
 
# nicer to generate it from distutils.
449
 
dist: 
450
 
        version=`./bzr version --short` && \
451
 
        echo Building distribution of bzr $$version && \
452
 
        expbasedir=`mktemp -t -d tmp_bzr_dist.XXXXXXXXXX` && \
453
 
        expdir=$$expbasedir/bzr-$$version && \
454
 
        tarball=$$PWD/../bzr-$$version.tar.gz && \
455
 
        $(MAKE) clean && \
456
 
        $(MAKE) && \
457
 
        bzr export $$expdir && \
458
 
        cp bzrlib/*.c bzrlib/*.h $$expdir/bzrlib/. && \
459
 
        tar cfz $$tarball -C $$expbasedir bzr-$$version && \
460
 
        gpg --detach-sign $$tarball && \
461
 
        rm -rf $$expbasedir
462
 
 
463
 
# run all tests in a previously built tarball
464
 
check-dist-tarball:
465
 
        tmpdir=`mktemp -t -d tmp_bzr_check_dist.XXXXXXXXXX` && \
466
 
        version=`./bzr version --short` && \
467
 
        tarball=$$PWD/../bzr-$$version.tar.gz && \
468
 
        tar Cxz $$tmpdir -f $$tarball && \
469
 
        $(MAKE) -C $$tmpdir/bzr-$$version check && \
470
 
        rm -rf $$tmpdir