5752.3.8
by John Arbash Meinel
Merge bzr.dev 5764 to resolve release-notes (aka NEWS) conflicts |
1 |
# Copyright (C) 2005-2011 Canonical Ltd
|
0.8.21
by John Arbash Meinel
Splitting up the version info code into a lazy factory style. |
2 |
#
|
0.8.1
by John Arbash Meinel
Creating a plugin to ease generating version information from a tree. |
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.
|
|
0.8.21
by John Arbash Meinel
Splitting up the version info code into a lazy factory style. |
7 |
#
|
0.8.1
by John Arbash Meinel
Creating a plugin to ease generating version information from a tree. |
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.
|
|
0.8.21
by John Arbash Meinel
Splitting up the version info code into a lazy factory style. |
12 |
#
|
0.8.1
by John Arbash Meinel
Creating a plugin to ease generating version information from a tree. |
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
|
|
4183.7.1
by Sabin Iacob
update FSF mailing address |
15 |
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
0.8.1
by John Arbash Meinel
Creating a plugin to ease generating version information from a tree. |
16 |
|
6379.6.7
by Jelmer Vernooij
Move importing from future until after doc string, otherwise the doc string will disappear. |
17 |
"""Commands for generating snapshot information about a bzr tree."""
|
18 |
||
6379.6.1
by Jelmer Vernooij
Import absolute_import in a few places. |
19 |
from __future__ import absolute_import |
20 |
||
1996.3.26
by John Arbash Meinel
Make cmd_version_info.py lazy import most other modules |
21 |
from bzrlib.lazy_import import lazy_import |
4792.8.4
by Martin Pool
Convert version-info to use TextUIOutputStream |
22 |
|
1996.3.26
by John Arbash Meinel
Make cmd_version_info.py lazy import most other modules |
23 |
lazy_import(globals(), """ |
2022.1.1
by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr |
24 |
from bzrlib import (
|
2022.1.3
by John Arbash Meinel
Remove unused imports |
25 |
branch,
|
2030.1.4
by John Arbash Meinel
Add a test that we can find the version info when we only have a branch |
26 |
errors,
|
4792.8.4
by Martin Pool
Convert version-info to use TextUIOutputStream |
27 |
version_info_formats,
|
2022.1.3
by John Arbash Meinel
Remove unused imports |
28 |
workingtree,
|
2022.1.1
by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr |
29 |
)
|
6138.3.8
by Jonathan Riddell
more error gettext()ing |
30 |
from bzrlib.i18n import gettext
|
1996.3.26
by John Arbash Meinel
Make cmd_version_info.py lazy import most other modules |
31 |
""") |
4792.8.4
by Martin Pool
Convert version-info to use TextUIOutputStream |
32 |
|
2022.1.1
by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr |
33 |
from bzrlib.commands import Command |
2948.4.2
by Lukáš Lalinský
Use registry for the list of formats. Documentation. |
34 |
from bzrlib.option import Option, RegistryOption |
0.8.2
by John Arbash Meinel
Have working rio output |
35 |
|
36 |
||
37 |
def _parse_version_info_format(format): |
|
2022.1.4
by John Arbash Meinel
test feedback from Robert. |
38 |
"""Convert a string passed by the user into a VersionInfoFormat.
|
39 |
||
40 |
This looks in the version info format registry, and if the format
|
|
41 |
cannot be found, generates a useful error exception.
|
|
42 |
"""
|
|
0.8.2
by John Arbash Meinel
Have working rio output |
43 |
try: |
0.8.21
by John Arbash Meinel
Splitting up the version info code into a lazy factory style. |
44 |
return version_info_formats.get_builder(format) |
0.8.2
by John Arbash Meinel
Have working rio output |
45 |
except KeyError: |
0.8.21
by John Arbash Meinel
Splitting up the version info code into a lazy factory style. |
46 |
formats = version_info_formats.get_builder_formats() |
6138.3.8
by Jonathan Riddell
more error gettext()ing |
47 |
raise errors.BzrCommandError(gettext('No known version info format {0}.' |
48 |
' Supported types are: {1}').format( |
|
49 |
format, formats)) |
|
0.8.2
by John Arbash Meinel
Have working rio output |
50 |
|
51 |
||
52 |
class cmd_version_info(Command): |
|
5131.2.1
by Martin
Permit bzrlib to run under python -OO by explictly assigning to __doc__ for user-visible docstrings |
53 |
__doc__ = """Show version information about this tree. |
2948.4.2
by Lukáš Lalinský
Use registry for the list of formats. Documentation. |
54 |
|
55 |
You can use this command to add information about version into
|
|
56 |
source code of an application. The output can be in one of the
|
|
57 |
supported formats or in a custom format based on a template.
|
|
58 |
||
59 |
For example::
|
|
60 |
||
61 |
bzr version-info --custom \\ |
|
2948.4.3
by Lukáš Lalinský
Fix problems from Alexander's review. |
62 |
--template="#define VERSION_INFO \\"Project 1.2.3 (r{revno})\\"\\n" |
2948.4.2
by Lukáš Lalinský
Use registry for the list of formats. Documentation. |
63 |
|
64 |
will produce a C header file with formatted string containing the
|
|
65 |
current revision number. Other supported variables in templates are:
|
|
66 |
||
67 |
* {date} - date of the last revision |
|
68 |
* {build_date} - current date |
|
69 |
* {revno} - revision number |
|
70 |
* {revision_id} - revision id |
|
71 |
* {branch_nick} - branch nickname |
|
2948.4.3
by Lukáš Lalinský
Fix problems from Alexander's review. |
72 |
* {clean} - 0 if the source tree contains uncommitted changes, |
73 |
otherwise 1
|
|
2948.4.2
by Lukáš Lalinský
Use registry for the list of formats. Documentation. |
74 |
"""
|
75 |
||
76 |
takes_options = [RegistryOption('format', |
|
77 |
'Select the output format.', |
|
3224.5.1
by Andrew Bennetts
Lots of assorted hackery to reduce the number of imports for common operations. Improves 'rocks', 'st' and 'help' times by ~50ms on my laptop. |
78 |
value_switches=True, |
79 |
lazy_registry=('bzrlib.version_info_formats', |
|
80 |
'format_registry')), |
|
2598.1.1
by Martin Pool
Add test for and documentation of option style, fix up existing options to comply |
81 |
Option('all', help='Include all possible information.'), |
82 |
Option('check-clean', help='Check if tree is clean.'), |
|
0.8.21
by John Arbash Meinel
Splitting up the version info code into a lazy factory style. |
83 |
Option('include-history', |
2598.1.1
by Martin Pool
Add test for and documentation of option style, fix up existing options to comply |
84 |
help='Include the revision-history.'), |
0.8.13
by John Arbash Meinel
Including file-revisions fields, updated test suite. |
85 |
Option('include-file-revisions', |
2948.4.1
by Lukáš Lalinský
Custom template-based version info formatter. |
86 |
help='Include the last revision for each file.'), |
87 |
Option('template', type=str, help='Template for the output.'), |
|
6196.1.1
by Jelmer Vernooij
Add --revision argument to 'bzr version-info'. |
88 |
'revision', |
0.8.2
by John Arbash Meinel
Have working rio output |
89 |
]
|
90 |
takes_args = ['location?'] |
|
91 |
||
0.8.20
by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass. |
92 |
encoding_type = 'exact' |
93 |
||
0.8.2
by John Arbash Meinel
Have working rio output |
94 |
def run(self, location=None, format=None, |
0.8.3
by John Arbash Meinel
Playing around with some formats |
95 |
all=False, check_clean=False, include_history=False, |
6196.1.1
by Jelmer Vernooij
Add --revision argument to 'bzr version-info'. |
96 |
include_file_revisions=False, template=None, |
97 |
revision=None): |
|
98 |
||
99 |
if revision and len(revision) > 1: |
|
100 |
raise errors.BzrCommandError( |
|
101 |
gettext('bzr version-info --revision takes exactly' |
|
102 |
' one revision specifier')) |
|
0.8.2
by John Arbash Meinel
Have working rio output |
103 |
|
104 |
if location is None: |
|
2022.1.4
by John Arbash Meinel
test feedback from Robert. |
105 |
location = '.' |
0.8.2
by John Arbash Meinel
Have working rio output |
106 |
|
107 |
if format is None: |
|
2948.4.2
by Lukáš Lalinský
Use registry for the list of formats. Documentation. |
108 |
format = version_info_formats.format_registry.get() |
0.8.2
by John Arbash Meinel
Have working rio output |
109 |
|
0.8.20
by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass. |
110 |
try: |
2022.1.3
by John Arbash Meinel
Remove unused imports |
111 |
wt = workingtree.WorkingTree.open_containing(location)[0] |
2030.1.4
by John Arbash Meinel
Add a test that we can find the version info when we only have a branch |
112 |
except errors.NoWorkingTree: |
2022.1.3
by John Arbash Meinel
Remove unused imports |
113 |
b = branch.Branch.open(location) |
6406.1.2
by Jelmer Vernooij
Simplify code a bit. |
114 |
wt = None |
0.8.20
by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass. |
115 |
else: |
116 |
b = wt.branch |
|
0.8.2
by John Arbash Meinel
Have working rio output |
117 |
|
6234.3.2
by Lawrence Mitchell
Only set check_clean if {clean} is asked for in template |
118 |
if all: |
0.8.2
by John Arbash Meinel
Have working rio output |
119 |
include_history = True |
120 |
check_clean = True |
|
6196.1.1
by Jelmer Vernooij
Add --revision argument to 'bzr version-info'. |
121 |
include_file_revisions = True |
6234.3.2
by Lawrence Mitchell
Only set check_clean if {clean} is asked for in template |
122 |
if template: |
123 |
include_history = True |
|
124 |
include_file_revisions = True |
|
125 |
if '{clean}' in template: |
|
126 |
check_clean = True |
|
6196.1.1
by Jelmer Vernooij
Add --revision argument to 'bzr version-info'. |
127 |
|
128 |
if revision is not None: |
|
129 |
revision_id = revision[0].as_revision_id(b) |
|
130 |
else: |
|
131 |
revision_id = None |
|
0.8.2
by John Arbash Meinel
Have working rio output |
132 |
|
0.8.20
by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass. |
133 |
builder = format(b, working_tree=wt, |
0.8.2
by John Arbash Meinel
Have working rio output |
134 |
check_for_clean=check_clean, |
0.8.13
by John Arbash Meinel
Including file-revisions fields, updated test suite. |
135 |
include_revision_history=include_history, |
2948.4.1
by Lukáš Lalinský
Custom template-based version info formatter. |
136 |
include_file_revisions=include_file_revisions, |
6196.1.1
by Jelmer Vernooij
Add --revision argument to 'bzr version-info'. |
137 |
template=template, revision_id=revision_id) |
5436.1.6
by Andrej A Antonov
code simplification: object 'ui.ui_factory.make_output_stream(encoding_type=self.encoding_type)' already created as 'self.outf' in function 'Command._setup_outf(...)' |
138 |
builder.generate(self.outf) |