1
# Copyright (C) 2005-2011 Canonical Ltd
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.
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.
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
17
"""Commands for generating snapshot information about a brz tree."""
19
from __future__ import absolute_import
21
from .lazy_import import lazy_import
23
lazy_import(globals(), """
30
from breezy.i18n import gettext
33
from .commands import Command
34
from .option import Option, RegistryOption
35
from .sixish import text_type
38
def _parse_version_info_format(format):
39
"""Convert a string passed by the user into a VersionInfoFormat.
41
This looks in the version info format registry, and if the format
42
cannot be found, generates a useful error exception.
45
return version_info_formats.get_builder(format)
47
formats = version_info_formats.get_builder_formats()
48
raise errors.BzrCommandError(
49
gettext('No known version info format {0}.'
50
' Supported types are: {1}').format(format, formats))
53
class cmd_version_info(Command):
54
__doc__ = """Show version information about this tree.
56
You can use this command to add information about version into
57
source code of an application. The output can be in one of the
58
supported formats or in a custom format based on a template.
62
brz version-info --custom \\
63
--template="#define VERSION_INFO \\"Project 1.2.3 (r{revno})\\"\\n"
65
will produce a C header file with formatted string containing the
66
current revision number. Other supported variables in templates are:
68
* {date} - date of the last revision
69
* {build_date} - current date
70
* {revno} - revision number
71
* {revision_id} - revision id
72
* {branch_nick} - branch nickname
73
* {clean} - 0 if the source tree contains uncommitted changes,
77
takes_options = [RegistryOption('format',
78
'Select the output format.',
80
lazy_registry=('breezy.version_info_formats',
82
Option('all', help='Include all possible information.'),
83
Option('check-clean', help='Check if tree is clean.'),
84
Option('include-history',
85
help='Include the revision-history.'),
86
Option('include-file-revisions',
87
help='Include the last revision for each file.'),
88
Option('template', type=text_type,
89
help='Template for the output.'),
92
takes_args = ['location?']
94
encoding_type = 'replace'
96
def run(self, location=None, format=None,
97
all=False, check_clean=False, include_history=False,
98
include_file_revisions=False, template=None,
101
if revision and len(revision) > 1:
102
raise errors.BzrCommandError(
103
gettext('brz version-info --revision takes exactly'
104
' one revision specifier'))
110
format = version_info_formats.format_registry.get()
113
wt = workingtree.WorkingTree.open_containing(location)[0]
114
except errors.NoWorkingTree:
115
b = branch.Branch.open(location)
121
include_history = True
123
include_file_revisions = True
125
include_history = True
126
include_file_revisions = True
127
if '{clean}' in template:
130
if revision is not None:
131
revision_id = revision[0].as_revision_id(b)
135
builder = format(b, working_tree=wt,
136
check_for_clean=check_clean,
137
include_revision_history=include_history,
138
include_file_revisions=include_file_revisions,
139
template=template, revision_id=revision_id)
140
builder.generate(self.outf)