~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/cmd_version_info.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2008-03-16 16:58:03 UTC
  • mfrom: (3224.3.1 news-typo)
  • Revision ID: pqm@pqm.ubuntu.com-20080316165803-tisoc9mpob9z544o
(Matt Nordhoff) Trivial NEWS typo fix

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,
24
23
    errors,
25
 
    version_info_formats,
26
24
    workingtree,
27
25
    )
28
 
from bzrlib.i18n import gettext
29
26
""")
30
 
 
 
27
from bzrlib import (
 
28
    version_info_formats,
 
29
    )
31
30
from bzrlib.commands import Command
32
31
from bzrlib.option import Option, RegistryOption
33
32
 
42
41
        return version_info_formats.get_builder(format)
43
42
    except KeyError:
44
43
        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))
 
44
        raise errors.BzrCommandError('No known version info format %s.'
 
45
                                     ' Supported types are: %s'
 
46
                                     % (format, formats))
48
47
 
49
48
 
50
49
class cmd_version_info(Command):
51
 
    __doc__ = """Show version information about this tree.
 
50
    """Show version information about this tree.
52
51
 
53
52
    You can use this command to add information about version into
54
53
    source code of an application. The output can be in one of the
73
72
 
74
73
    takes_options = [RegistryOption('format',
75
74
                            'Select the output format.',
76
 
                            value_switches=True,
77
 
                            lazy_registry=('bzrlib.version_info_formats',
78
 
                                           'format_registry')),
 
75
                            version_info_formats.format_registry,
 
76
                            value_switches=True),
79
77
                     Option('all', help='Include all possible information.'),
80
78
                     Option('check-clean', help='Check if tree is clean.'),
81
79
                     Option('include-history',
83
81
                     Option('include-file-revisions',
84
82
                            help='Include the last revision for each file.'),
85
83
                     Option('template', type=str, help='Template for the output.'),
86
 
                     'revision',
87
84
                     ]
88
85
    takes_args = ['location?']
89
86
 
91
88
 
92
89
    def run(self, location=None, format=None,
93
90
            all=False, check_clean=False, include_history=False,
94
 
            include_file_revisions=False, template=None,
95
 
            revision=None):
96
 
 
97
 
        if revision and len(revision) > 1:
98
 
            raise errors.BzrCommandError(
99
 
                gettext('bzr version-info --revision takes exactly'
100
 
                        ' one revision specifier'))
 
91
            include_file_revisions=False, template=None):
101
92
 
102
93
        if location is None:
103
94
            location = '.'
116
107
        if all or template:
117
108
            include_history = True
118
109
            check_clean = True
119
 
            include_file_revisions = True
120
 
 
121
 
        if revision is not None:
122
 
            revision_id = revision[0].as_revision_id(b)
123
 
        else:
124
 
            revision_id = None
 
110
            include_file_revisions=True
125
111
 
126
112
        builder = format(b, working_tree=wt,
127
113
                check_for_clean=check_clean,
128
114
                include_revision_history=include_history,
129
115
                include_file_revisions=include_file_revisions,
130
 
                template=template, revision_id=revision_id)
 
116
                template=template)
131
117
        builder.generate(self.outf)