1
Exporting version information
2
=============================
7
This document describes ways of using ``bzr version-info`` as part of a
8
build process to embed version information into a final project.
14
TODO: Figure out how to attach into ``setup.py``
17
If using a Makefile to build your project, you can generate the version
18
information file as simply as::
21
bzr version-info --format=python > library/_version.py
23
This generates a file which contains 3 dictionaries:
25
* `version_info`: A dictionary containing the basic information about the
28
* `revisions`: A dictionary listing all of the revisions in the
29
history of the tree, along with the commit times and commit
30
message. This defaults to being empty unless ``--all`` or
31
``--include-history`` is supplied. This is useful if you want to
32
track what bug fixes, etc, might be included in the released
33
version. But for many projects it is more information than needed.
35
* `file_revisions`: A dictionary listing the last-modified revision
36
for all files in the project. This can be used similarly to how
37
``$Id$`` keywords are used in CVS-controlled files. The last
38
modified date can be determined by looking in the ``revisions``
39
map. This is also empty by default, and enabled only by ``--all``
40
or ``--include-file-revisions``.
45
Most information about the contents of the project can be cheaply
46
determined by just reading the revision entry. However, it can be useful
47
to know if the working tree was completely up-to-date when it was
48
packaged, or if there was a local modification. By supplying either
49
``--all`` or ``--check-clean``, ``bzr`` will inspect the working tree, and
50
set the ``clean`` flag in ``version_info``, as well as set entries in
51
``file_revisions`` as ``modified`` where appropriate.
54
vim: tw=74 ft=rst spell spelllang=en_us