~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/cmd_version_info.py

  • Committer: Ian Clatworthy
  • Date: 2007-08-13 14:33:10 UTC
  • mto: (2733.1.1 ianc-integration)
  • mto: This revision was merged to the branch mainline in revision 2734.
  • Revision ID: ian.clatworthy@internode.on.net-20070813143310-twhj4la0qnupvze8
Added Quick Start Summary

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005-2011 Canonical Ltd
 
1
# Copyright (C) 2005, 2006 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
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
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
"""Commands for generating snapshot information about a bzr tree."""
18
18
 
19
19
from bzrlib.lazy_import import lazy_import
20
 
 
21
20
lazy_import(globals(), """
22
21
from bzrlib import (
23
22
    branch,
25
24
    version_info_formats,
26
25
    workingtree,
27
26
    )
28
 
from bzrlib.i18n import gettext
29
27
""")
30
 
 
31
28
from bzrlib.commands import Command
32
 
from bzrlib.option import Option, RegistryOption
 
29
from bzrlib.option import Option
33
30
 
34
31
 
35
32
def _parse_version_info_format(format):
42
39
        return version_info_formats.get_builder(format)
43
40
    except KeyError:
44
41
        formats = version_info_formats.get_builder_formats()
45
 
        raise errors.BzrCommandError(gettext('No known version info format {0}.'
46
 
                                     ' Supported types are: {1}').format(
47
 
                                     format, formats))
 
42
        raise errors.BzrCommandError('No known version info format %s.'
 
43
                                     ' Supported types are: %s'
 
44
                                     % (format, formats))
48
45
 
49
46
 
50
47
class cmd_version_info(Command):
51
 
    __doc__ = """Show version information about this tree.
52
 
 
53
 
    You can use this command to add information about version into
54
 
    source code of an application. The output can be in one of the
55
 
    supported formats or in a custom format based on a template.
56
 
 
57
 
    For example::
58
 
 
59
 
      bzr version-info --custom \\
60
 
        --template="#define VERSION_INFO \\"Project 1.2.3 (r{revno})\\"\\n"
61
 
 
62
 
    will produce a C header file with formatted string containing the
63
 
    current revision number. Other supported variables in templates are:
64
 
 
65
 
      * {date} - date of the last revision
66
 
      * {build_date} - current date
67
 
      * {revno} - revision number
68
 
      * {revision_id} - revision id
69
 
      * {branch_nick} - branch nickname
70
 
      * {clean} - 0 if the source tree contains uncommitted changes,
71
 
                  otherwise 1
72
 
    """
73
 
 
74
 
    takes_options = [RegistryOption('format',
75
 
                            'Select the output format.',
76
 
                            value_switches=True,
77
 
                            lazy_registry=('bzrlib.version_info_formats',
78
 
                                           'format_registry')),
 
48
    """Show version information about this tree."""
 
49
 
 
50
    takes_options = [Option('format', type=_parse_version_info_format,
 
51
                            help='Select the output format.'),
79
52
                     Option('all', help='Include all possible information.'),
80
53
                     Option('check-clean', help='Check if tree is clean.'),
81
54
                     Option('include-history',
82
55
                            help='Include the revision-history.'),
83
56
                     Option('include-file-revisions',
84
 
                            help='Include the last revision for each file.'),
85
 
                     Option('template', type=str, help='Template for the output.'),
 
57
                            help='Include the last revision for each file.')
86
58
                     ]
87
59
    takes_args = ['location?']
88
60
 
90
62
 
91
63
    def run(self, location=None, format=None,
92
64
            all=False, check_clean=False, include_history=False,
93
 
            include_file_revisions=False, template=None):
 
65
            include_file_revisions=False):
94
66
 
95
67
        if location is None:
96
68
            location = '.'
97
69
 
98
70
        if format is None:
99
 
            format = version_info_formats.format_registry.get()
 
71
            format = version_info_formats.get_builder(None)
100
72
 
101
73
        wt = None
102
74
        try:
106
78
        else:
107
79
            b = wt.branch
108
80
 
109
 
        if all or template:
 
81
        if all:
110
82
            include_history = True
111
83
            check_clean = True
112
84
            include_file_revisions=True
114
86
        builder = format(b, working_tree=wt,
115
87
                check_for_clean=check_clean,
116
88
                include_revision_history=include_history,
117
 
                include_file_revisions=include_file_revisions,
118
 
                template=template)
 
89
                include_file_revisions=include_file_revisions)
119
90
        builder.generate(self.outf)