~bzr-pqm/bzr/bzr.dev

0.8.21 by John Arbash Meinel
Splitting up the version info code into a lazy factory style.
1
# Copyright (C) 2005, 2006 Canonical Ltd
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
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
2022.1.1 by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr
17
"""Commands for generating snapshot information about a bzr tree."""
0.8.1 by John Arbash Meinel
Creating a plugin to ease generating version information from a tree.
18
1996.3.26 by John Arbash Meinel
Make cmd_version_info.py lazy import most other modules
19
from bzrlib.lazy_import import lazy_import
20
lazy_import(globals(), """
2022.1.1 by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr
21
from bzrlib import (
2022.1.3 by John Arbash Meinel
Remove unused imports
22
    branch,
2030.1.4 by John Arbash Meinel
Add a test that we can find the version info when we only have a branch
23
    errors,
2022.1.3 by John Arbash Meinel
Remove unused imports
24
    workingtree,
2022.1.1 by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr
25
    )
1996.3.26 by John Arbash Meinel
Make cmd_version_info.py lazy import most other modules
26
""")
2948.4.2 by Lukáš Lalinský
Use registry for the list of formats. Documentation.
27
from bzrlib import (
28
    version_info_formats,
29
    )
2022.1.1 by John Arbash Meinel
[merge] version-info plugin, and cleanup for layout in bzr
30
from bzrlib.commands import Command
2948.4.2 by Lukáš Lalinský
Use registry for the list of formats. Documentation.
31
from bzrlib.option import Option, RegistryOption
0.8.2 by John Arbash Meinel
Have working rio output
32
33
34
def _parse_version_info_format(format):
2022.1.4 by John Arbash Meinel
test feedback from Robert.
35
    """Convert a string passed by the user into a VersionInfoFormat.
36
37
    This looks in the version info format registry, and if the format
38
    cannot be found, generates a useful error exception.
39
    """
0.8.2 by John Arbash Meinel
Have working rio output
40
    try:
0.8.21 by John Arbash Meinel
Splitting up the version info code into a lazy factory style.
41
        return version_info_formats.get_builder(format)
0.8.2 by John Arbash Meinel
Have working rio output
42
    except KeyError:
0.8.21 by John Arbash Meinel
Splitting up the version info code into a lazy factory style.
43
        formats = version_info_formats.get_builder_formats()
2030.1.4 by John Arbash Meinel
Add a test that we can find the version info when we only have a branch
44
        raise errors.BzrCommandError('No known version info format %s.'
45
                                     ' Supported types are: %s'
46
                                     % (format, formats))
0.8.2 by John Arbash Meinel
Have working rio output
47
48
49
class cmd_version_info(Command):
2948.4.2 by Lukáš Lalinský
Use registry for the list of formats. Documentation.
50
    """Show version information about this tree.
51
52
    You can use this command to add information about version into
53
    source code of an application. The output can be in one of the
54
    supported formats or in a custom format based on a template.
55
56
    For example::
57
58
      bzr version-info --custom \\
2948.4.3 by Lukáš Lalinský
Fix problems from Alexander's review.
59
        --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.
60
61
    will produce a C header file with formatted string containing the
62
    current revision number. Other supported variables in templates are:
63
64
      * {date} - date of the last revision
65
      * {build_date} - current date
66
      * {revno} - revision number
67
      * {revision_id} - revision id
68
      * {branch_nick} - branch nickname
2948.4.3 by Lukáš Lalinský
Fix problems from Alexander's review.
69
      * {clean} - 0 if the source tree contains uncommitted changes,
70
                  otherwise 1
2948.4.2 by Lukáš Lalinský
Use registry for the list of formats. Documentation.
71
    """
72
73
    takes_options = [RegistryOption('format',
74
                            'Select the output format.',
75
                            version_info_formats.format_registry,
76
                            value_switches=True),
2598.1.1 by Martin Pool
Add test for and documentation of option style, fix up existing options to comply
77
                     Option('all', help='Include all possible information.'),
78
                     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.
79
                     Option('include-history',
2598.1.1 by Martin Pool
Add test for and documentation of option style, fix up existing options to comply
80
                            help='Include the revision-history.'),
0.8.13 by John Arbash Meinel
Including file-revisions fields, updated test suite.
81
                     Option('include-file-revisions',
2948.4.1 by Lukáš Lalinský
Custom template-based version info formatter.
82
                            help='Include the last revision for each file.'),
83
                     Option('template', type=str, help='Template for the output.'),
0.8.2 by John Arbash Meinel
Have working rio output
84
                     ]
85
    takes_args = ['location?']
86
0.8.20 by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass.
87
    encoding_type = 'exact'
88
0.8.2 by John Arbash Meinel
Have working rio output
89
    def run(self, location=None, format=None,
0.8.3 by John Arbash Meinel
Playing around with some formats
90
            all=False, check_clean=False, include_history=False,
2948.4.3 by Lukáš Lalinský
Fix problems from Alexander's review.
91
            include_file_revisions=False, template=None):
0.8.2 by John Arbash Meinel
Have working rio output
92
93
        if location is None:
2022.1.4 by John Arbash Meinel
test feedback from Robert.
94
            location = '.'
0.8.2 by John Arbash Meinel
Have working rio output
95
96
        if format is None:
2948.4.2 by Lukáš Lalinský
Use registry for the list of formats. Documentation.
97
            format = version_info_formats.format_registry.get()
0.8.2 by John Arbash Meinel
Have working rio output
98
0.8.20 by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass.
99
        wt = None
100
        try:
2022.1.3 by John Arbash Meinel
Remove unused imports
101
            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
102
        except errors.NoWorkingTree:
2022.1.3 by John Arbash Meinel
Remove unused imports
103
            b = branch.Branch.open(location)
0.8.20 by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass.
104
        else:
105
            b = wt.branch
0.8.2 by John Arbash Meinel
Have working rio output
106
107
        if all:
108
            include_history = True
109
            check_clean = True
0.8.13 by John Arbash Meinel
Including file-revisions fields, updated test suite.
110
            include_file_revisions=True
0.8.2 by John Arbash Meinel
Have working rio output
111
0.8.20 by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass.
112
        builder = format(b, working_tree=wt,
0.8.2 by John Arbash Meinel
Have working rio output
113
                check_for_clean=check_clean,
0.8.13 by John Arbash Meinel
Including file-revisions fields, updated test suite.
114
                include_revision_history=include_history,
2948.4.1 by Lukáš Lalinský
Custom template-based version info formatter.
115
                include_file_revisions=include_file_revisions,
116
                template=template)
0.8.20 by John Arbash Meinel
Updated version-info to the latest bzr.dev codebase. Changed to using VersionInfoBuilder, and made tests pass.
117
        builder.generate(self.outf)