/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
4763.2.4 by John Arbash Meinel
merge bzr.2.1 in preparation for NEWS entry.
1
# Copyright (C) 2005-2010 Canonical Ltd
3943.8.1 by Marius Kruger
remove all trailing whitespace from bzr source
2
#
77 by mbp at sourcefrog
- split info command out into separate file
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.
2052.3.1 by John Arbash Meinel
Add tests to cleanup the copyright of all source files
7
#
77 by mbp at sourcefrog
- split info command out into separate file
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.
2052.3.1 by John Arbash Meinel
Add tests to cleanup the copyright of all source files
12
#
77 by mbp at sourcefrog
- split info command out into separate file
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
77 by mbp at sourcefrog
- split info command out into separate file
16
6379.6.3 by Jelmer Vernooij
Use absolute_import.
17
from __future__ import absolute_import
18
1534.5.1 by Robert Collins
Give info some reasonable output and tests.
19
__all__ = ['show_bzrdir_info']
20
6963.2.18 by Jelmer Vernooij
Add bees to some of bp.weave_fmt.
21
from io import StringIO
77 by mbp at sourcefrog
- split info command out into separate file
22
import time
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
23
import sys
1534.5.1 by Robert Collins
Give info some reasonable output and tests.
24
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
25
from . import (
6734.1.11 by Jelmer Vernooij
Move UnstackableBranchFormat.
26
    branch as _mod_branch,
6207.3.3 by jelmer at samba
Fix tests and the like.
27
    controldir,
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
28
    errors,
4307.3.1 by Jelmer Vernooij
Allow registering hooks that extend the Repository section in 'bzr info -v'.
29
    hooks as _mod_hooks,
1551.9.22 by Aaron Bentley
Use urlutils for info. Fixes bug #76229
30
    osutils,
31
    urlutils,
32
    )
6670.4.1 by Jelmer Vernooij
Update imports.
33
from .bzr import (
34
    bzrdir,
35
    )
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
36
from .errors import (NoWorkingTree, NotBranchError,
7143.15.2 by Jelmer Vernooij
Run autopep8.
37
                     NoRepositoryPresent, NotLocalUrl)
6624 by Jelmer Vernooij
Merge Python3 porting work ('py3 pokes')
38
from .missing import find_unmerged
77 by mbp at sourcefrog
- split info command out into separate file
39
462 by Martin Pool
- New form 'file_id in tree' to check if the file is present
40
6985 by Jelmer Vernooij
Merge lp:~jelmer/brz/python3-weave-fmt.
41
def plural(n, base=u'', pl=None):
1563.2.28 by Robert Collins
Add total_size to the revision_store api.
42
    if n == 1:
43
        return base
1963.2.6 by Robey Pointer
pychecker is on crack; go back to using 'is None'.
44
    elif pl is not None:
1563.2.28 by Robert Collins
Add total_size to the revision_store api.
45
        return pl
46
    else:
6985 by Jelmer Vernooij
Merge lp:~jelmer/brz/python3-weave-fmt.
47
        return u's'
1563.2.28 by Robert Collins
Add total_size to the revision_store api.
48
49
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
50
class LocationList(object):
51
52
    def __init__(self, base_path):
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
53
        self.locs = []
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
54
        self.base_path = base_path
55
56
    def add_url(self, label, url):
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
57
        """Add a URL to the list, converting it to a path if possible"""
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
58
        if url is None:
59
            return
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
60
        try:
61
            path = urlutils.local_path_from_url(url)
6729.6.1 by Jelmer Vernooij
Move urlutils errors.
62
        except urlutils.InvalidURL:
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
63
            self.locs.append((label, url))
64
        else:
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
65
            self.add_path(label, path)
2363.5.18 by Aaron Bentley
Get all tests passing
66
67
    def add_path(self, label, path):
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
68
        """Add a path, converting it to a relative path if possible"""
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
69
        try:
70
            path = osutils.relpath(self.base_path, path)
71
        except errors.PathNotChild:
72
            pass
73
        else:
74
            if path == '':
75
                path = '.'
76
        if path != '/':
77
            path = path.rstrip('/')
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
78
        self.locs.append((label, path))
2363.5.18 by Aaron Bentley
Get all tests passing
79
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
80
    def get_lines(self):
81
        max_len = max(len(l) for l, u in self.locs)
7143.15.2 by Jelmer Vernooij
Run autopep8.
82
        return ["  %*s: %s\n" % (max_len, l, u) for l, u in self.locs]
2363.5.18 by Aaron Bentley
Get all tests passing
83
84
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
85
def gather_location_info(repository=None, branch=None, working=None,
7143.15.2 by Jelmer Vernooij
Run autopep8.
86
                         control=None):
2363.5.18 by Aaron Bentley
Get all tests passing
87
    locs = {}
88
    if branch is not None:
5158.6.6 by Martin Pool
Change info code to use user_url etc
89
        branch_path = branch.user_url
2363.5.18 by Aaron Bentley
Get all tests passing
90
        master_path = branch.get_bound_location()
91
        if master_path is None:
92
            master_path = branch_path
93
    else:
94
        branch_path = None
95
        master_path = None
6241.4.3 by Jelmer Vernooij
Add test for dangling tree references.
96
        try:
97
            if control is not None and control.get_branch_reference():
98
                locs['checkout of branch'] = control.get_branch_reference()
99
        except NotBranchError:
100
            pass
2363.5.18 by Aaron Bentley
Get all tests passing
101
    if working:
5158.6.6 by Martin Pool
Change info code to use user_url etc
102
        working_path = working.user_url
1694.2.6 by Martin Pool
[merge] bzr.dev
103
        if working_path != branch_path:
2363.5.18 by Aaron Bentley
Get all tests passing
104
            locs['light checkout root'] = working_path
105
        if master_path != branch_path:
1694.2.6 by Martin Pool
[merge] bzr.dev
106
            if repository.is_shared():
2363.5.18 by Aaron Bentley
Get all tests passing
107
                locs['repository checkout root'] = branch_path
1694.2.6 by Martin Pool
[merge] bzr.dev
108
            else:
2363.5.18 by Aaron Bentley
Get all tests passing
109
                locs['checkout root'] = branch_path
110
        if working_path != master_path:
7211.9.1 by Jelmer Vernooij
Report colocated branch name in 'brz info'.
111
            (master_path_base, params) = urlutils.split_segment_parameters(
112
                master_path)
113
            if working_path == master_path_base:
114
                locs['checkout of co-located branch'] = params['branch']
115
            elif 'branch' in params:
7385.1.1 by Miro Hrončok
SyntaxWarning: 'str' object is not callable; perhaps you missed a comma?
116
                locs['checkout of branch'] = "%s, branch %s" % (
7211.9.1 by Jelmer Vernooij
Report colocated branch name in 'brz info'.
117
                    master_path_base, params['branch'])
118
            else:
119
                locs['checkout of branch'] = master_path
1694.2.6 by Martin Pool
[merge] bzr.dev
120
        elif repository.is_shared():
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
121
            locs['repository branch'] = branch_path
2363.5.18 by Aaron Bentley
Get all tests passing
122
        elif branch_path is not None:
1694.2.6 by Martin Pool
[merge] bzr.dev
123
            # standalone
2363.5.18 by Aaron Bentley
Get all tests passing
124
            locs['branch root'] = branch_path
125
    else:
126
        working_path = None
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
127
        if repository is not None and repository.is_shared():
2363.5.18 by Aaron Bentley
Get all tests passing
128
            # lightweight checkout of branch in shared repository
129
            if branch_path is not None:
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
130
                locs['repository branch'] = branch_path
2363.5.18 by Aaron Bentley
Get all tests passing
131
        elif branch_path is not None:
132
            # standalone
133
            locs['branch root'] = branch_path
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
134
        elif repository is not None:
135
            locs['repository'] = repository.user_url
136
        elif control is not None:
137
            locs['control directory'] = control.user_url
1624.3.48 by Olaf Conradi
Add info on standalone branches without a working tree.
138
        else:
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
139
            # Really, at least a control directory should be
140
            # passed in for this method to be useful.
141
            pass
6241.2.1 by Jelmer Vernooij
bzr info now shows the bound location too for local branches without tree.
142
        if master_path != branch_path:
143
            locs['bound to branch'] = master_path
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
144
    if repository is not None and repository.is_shared():
2363.5.18 by Aaron Bentley
Get all tests passing
145
        # lightweight checkout of branch in shared repository
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
146
        locs['shared repository'] = repository.user_url
147
    order = ['control directory', 'light checkout root',
148
             'repository checkout root', 'checkout root',
7211.9.1 by Jelmer Vernooij
Report colocated branch name in 'brz info'.
149
             'checkout of branch', 'checkout of co-located branch',
150
             'shared repository', 'repository', 'repository branch',
151
             'branch root', 'bound to branch']
2363.5.23 by Aaron Bentley
Output 2-tuples from gather_locations
152
    return [(n, locs[n]) for n in order if n in locs]
2363.5.18 by Aaron Bentley
Get all tests passing
153
154
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
155
def _show_location_info(locs, outfile):
2363.5.18 by Aaron Bentley
Get all tests passing
156
    """Show known locations for working, branch and repository."""
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
157
    outfile.write('Location:\n')
2804.4.3 by Alexander Belchenko
fix for test_info-tests: using osutils.getcwd instead of os.getcwd (sigh)
158
    path_list = LocationList(osutils.getcwd())
2363.5.23 by Aaron Bentley
Output 2-tuples from gather_locations
159
    for name, loc in locs:
160
        path_list.add_url(name, loc)
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
161
    outfile.writelines(path_list.get_lines())
162
1694.2.6 by Martin Pool
[merge] bzr.dev
163
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
164
def _gather_related_branches(branch):
2804.4.3 by Alexander Belchenko
fix for test_info-tests: using osutils.getcwd instead of os.getcwd (sigh)
165
    locs = LocationList(osutils.getcwd())
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
166
    locs.add_url('public branch', branch.get_public_branch())
167
    locs.add_url('push branch', branch.get_push_location())
168
    locs.add_url('parent branch', branch.get_parent())
169
    locs.add_url('submit branch', branch.get_submit_branch())
3221.11.21 by Robert Collins
Have info report on stacked branches.
170
    try:
3537.3.1 by Martin Pool
Rename branch.get_stacked_on to get_stacked_on_url
171
        locs.add_url('stacked on', branch.get_stacked_on_url())
6734.1.11 by Jelmer Vernooij
Move UnstackableBranchFormat.
172
    except (_mod_branch.UnstackableBranchFormat, errors.UnstackableRepositoryFormat,
7143.15.2 by Jelmer Vernooij
Run autopep8.
173
            errors.NotStacked):
3221.11.21 by Robert Collins
Have info report on stacked branches.
174
        pass
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
175
    return locs
1694.2.6 by Martin Pool
[merge] bzr.dev
176
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
177
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
178
def _show_related_info(branch, outfile):
1694.2.6 by Martin Pool
[merge] bzr.dev
179
    """Show parent and push location of branch."""
1551.15.41 by Aaron Bentley
Make info provide more related brances, and format all branches nicely
180
    locs = _gather_related_branches(branch)
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
181
    if len(locs.locs) > 0:
2911.6.1 by Blake Winton
Change 'print >> f,'s to 'f.write('s.
182
        outfile.write('\n')
183
        outfile.write('Related branches:\n')
1551.15.43 by Aaron Bentley
Provide ways of getting at unicode-clean output
184
        outfile.writelines(locs.get_lines())
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
185
186
6240.1.1 by Jelmer Vernooij
Show the number of colocated branches in 'bzr info -v'.
187
def _show_control_dir_info(control, outfile):
188
    """Show control dir information."""
189
    if control._format.colocated_branches:
190
        outfile.write('\n')
191
        outfile.write('Control directory:\n')
192
        outfile.write('         %d branches\n' % len(control.list_branches()))
193
194
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
195
def _show_format_info(control=None, repository=None, branch=None,
196
                      working=None, outfile=None):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
197
    """Show known formats for control, working, branch and repository."""
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
198
    outfile.write('\n')
199
    outfile.write('Format:\n')
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
200
    if control:
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
201
        outfile.write('       control: %s\n' %
7143.15.2 by Jelmer Vernooij
Run autopep8.
202
                      control._format.get_format_description())
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
203
    if working:
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
204
        outfile.write('  working tree: %s\n' %
7143.15.2 by Jelmer Vernooij
Run autopep8.
205
                      working._format.get_format_description())
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
206
    if branch:
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
207
        outfile.write('        branch: %s\n' %
7143.15.2 by Jelmer Vernooij
Run autopep8.
208
                      branch._format.get_format_description())
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
209
    if repository:
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
210
        outfile.write('    repository: %s\n' %
7143.15.2 by Jelmer Vernooij
Run autopep8.
211
                      repository._format.get_format_description())
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
212
213
6437.33.2 by Jelmer Vernooij
Cope with repository being missing in 'bzr info'.
214
def _show_locking_info(repository=None, branch=None, working=None,
7143.15.2 by Jelmer Vernooij
Run autopep8.
215
                       outfile=None):
1694.2.6 by Martin Pool
[merge] bzr.dev
216
    """Show locking status of working, branch and repository."""
6437.33.2 by Jelmer Vernooij
Cope with repository being missing in 'bzr info'.
217
    if (repository and repository.get_physical_lock_status() or
1694.2.6 by Martin Pool
[merge] bzr.dev
218
        (branch and branch.get_physical_lock_status()) or
7143.15.2 by Jelmer Vernooij
Run autopep8.
219
            (working and working.get_physical_lock_status())):
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
220
        outfile.write('\n')
221
        outfile.write('Lock status:\n')
1694.2.6 by Martin Pool
[merge] bzr.dev
222
        if working:
223
            if working.get_physical_lock_status():
224
                status = 'locked'
225
            else:
226
                status = 'unlocked'
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
227
            outfile.write('  working tree: %s\n' % status)
1694.2.6 by Martin Pool
[merge] bzr.dev
228
        if branch:
229
            if branch.get_physical_lock_status():
230
                status = 'locked'
231
            else:
232
                status = 'unlocked'
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
233
            outfile.write('        branch: %s\n' % status)
1694.2.6 by Martin Pool
[merge] bzr.dev
234
        if repository:
235
            if repository.get_physical_lock_status():
236
                status = 'locked'
237
            else:
238
                status = 'unlocked'
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
239
            outfile.write('    repository: %s\n' % status)
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
240
241
242
def _show_missing_revisions_branch(branch, outfile):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
243
    """Show missing master revisions in branch."""
1587.1.14 by Robert Collins
Make bound branch creation happen via 'checkout'
244
    # Try with inaccessible branch ?
1624.3.2 by Olaf Conradi
Implemented table of constructs from BzrInfo specification.
245
    master = branch.get_master_branch()
1587.1.14 by Robert Collins
Make bound branch creation happen via 'checkout'
246
    if master:
1624.3.2 by Olaf Conradi
Implemented table of constructs from BzrInfo specification.
247
        local_extra, remote_extra = find_unmerged(branch, master)
1587.1.14 by Robert Collins
Make bound branch creation happen via 'checkout'
248
        if remote_extra:
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
249
            outfile.write('\n')
250
            outfile.write(('Branch is out of date: missing %d '
7143.15.2 by Jelmer Vernooij
Run autopep8.
251
                           'revision%s.\n') % (len(remote_extra),
252
                                               plural(len(remote_extra))))
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
253
254
255
def _show_missing_revisions_working(working, outfile):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
256
    """Show missing revisions in working tree."""
257
    branch = working.branch
6181.1.1 by Jelmer Vernooij
If the branch doesn't support last_revision_info, don't display
258
    try:
259
        branch_revno, branch_last_revision = branch.last_revision_info()
260
    except errors.UnsupportedOperation:
261
        return
1908.7.6 by Robert Collins
Deprecate WorkingTree.last_revision.
262
    try:
263
        tree_last_id = working.get_parent_ids()[0]
264
    except IndexError:
265
        tree_last_id = None
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
266
2249.4.2 by Wouter van Heyst
Convert callers of Branch.revision_history() to Branch.last_revision_info() where sensible.
267
    if branch_revno and tree_last_id != branch_last_revision:
1624.3.11 by Olaf Conradi
Test cases exposed a bug in missing revisions count of working tree. It
268
        tree_last_revno = branch.revision_id_to_revno(tree_last_id)
2249.4.2 by Wouter van Heyst
Convert callers of Branch.revision_history() to Branch.last_revision_info() where sensible.
269
        missing_count = branch_revno - tree_last_revno
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
270
        outfile.write('\n')
271
        outfile.write(('Working tree is out of date: missing %d '
7143.15.2 by Jelmer Vernooij
Run autopep8.
272
                       'revision%s.\n') % (missing_count, plural(missing_count)))
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
273
274
275
def _show_working_stats(working, outfile):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
276
    """Show statistics about a working tree."""
277
    basis = working.basis_tree()
1852.10.3 by Robert Collins
Remove all uses of compare_trees and replace with Tree.changes_from throughout bzrlib.
278
    delta = working.changes_from(basis, want_unchanged=True)
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
279
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
280
    outfile.write('\n')
281
    outfile.write('In the working tree:\n')
282
    outfile.write('  %8s unchanged\n' % len(delta.unchanged))
283
    outfile.write('  %8d modified\n' % len(delta.modified))
284
    outfile.write('  %8d added\n' % len(delta.added))
285
    outfile.write('  %8d removed\n' % len(delta.removed))
286
    outfile.write('  %8d renamed\n' % len(delta.renamed))
7358.17.1 by Jelmer Vernooij
Add TreeDelta.copied and TreeChange.copied fields.
287
    outfile.write('  %8d copied\n' % len(delta.copied))
462 by Martin Pool
- New form 'file_id in tree' to check if the file is present
288
289
    ignore_cnt = unknown_cnt = 0
290
    for path in working.extras():
291
        if working.is_ignored(path):
292
            ignore_cnt += 1
293
        else:
294
            unknown_cnt += 1
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
295
    outfile.write('  %8d unknown\n' % unknown_cnt)
296
    outfile.write('  %8d ignored\n' % ignore_cnt)
462 by Martin Pool
- New form 'file_id in tree' to check if the file is present
297
298
    dir_cnt = 0
5777.5.5 by Jelmer Vernooij
Use working.iter_entries_by_dir.
299
    for path, entry in working.iter_entries_by_dir():
6913.3.2 by Jelmer Vernooij
Avoid file id usage.
300
        if entry.kind == 'directory' and path != '':
1731.1.39 by Aaron Bentley
Reject removing is_root
301
            dir_cnt += 1
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
302
    outfile.write('  %8d versioned %s\n' % (dir_cnt,
7143.15.2 by Jelmer Vernooij
Run autopep8.
303
                                            plural(dir_cnt, 'subdirectory', 'subdirectories')))
77 by mbp at sourcefrog
- split info command out into separate file
304
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
305
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
306
def _show_branch_stats(branch, verbose, outfile):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
307
    """Show statistics about a branch."""
6181.1.1 by Jelmer Vernooij
If the branch doesn't support last_revision_info, don't display
308
    try:
309
        revno, head = branch.last_revision_info()
310
    except errors.UnsupportedOperation:
311
        return {}
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
312
    outfile.write('\n')
313
    outfile.write('Branch history:\n')
314
    outfile.write('  %8d revision%s\n' % (revno, plural(revno)))
2258.1.1 by Robert Collins
Move info branch statistics gathering into the repository to allow smart server optimisation (Robert Collins).
315
    stats = branch.repository.gather_stats(head, committers=verbose)
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
316
    if verbose:
2258.1.1 by Robert Collins
Move info branch statistics gathering into the repository to allow smart server optimisation (Robert Collins).
317
        committers = stats['committers']
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
318
        outfile.write('  %8d committer%s\n' % (committers,
7143.15.2 by Jelmer Vernooij
Run autopep8.
319
                                               plural(committers)))
2258.1.1 by Robert Collins
Move info branch statistics gathering into the repository to allow smart server optimisation (Robert Collins).
320
    if revno:
321
        timestamp, timezone = stats['firstrev']
322
        age = int((time.time() - timestamp) / 3600 / 24)
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
323
        outfile.write('  %8d day%s old\n' % (age, plural(age)))
324
        outfile.write('   first revision: %s\n' %
7143.15.2 by Jelmer Vernooij
Run autopep8.
325
                      osutils.format_date(timestamp, timezone))
2258.1.1 by Robert Collins
Move info branch statistics gathering into the repository to allow smart server optimisation (Robert Collins).
326
        timestamp, timezone = stats['latestrev']
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
327
        outfile.write('  latest revision: %s\n' %
7143.15.2 by Jelmer Vernooij
Run autopep8.
328
                      osutils.format_date(timestamp, timezone))
2258.1.2 by Robert Collins
New version of gather_stats which gathers aggregate data too.
329
    return stats
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
330
331
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
332
def _show_repository_info(repository, outfile):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
333
    """Show settings of a repository."""
334
    if repository.make_working_trees():
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
335
        outfile.write('\n')
336
        outfile.write('Create working tree for new branches inside '
7143.15.2 by Jelmer Vernooij
Run autopep8.
337
                      'the repository.\n')
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
338
339
4307.3.3 by Jelmer Vernooij
Add repository argument to 'repository' info hook, per Roberts review.
340
def _show_repository_stats(repository, stats, outfile):
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
341
    """Show statistics about a repository."""
6963.2.18 by Jelmer Vernooij
Add bees to some of bp.weave_fmt.
342
    f = StringIO()
2258.1.2 by Robert Collins
New version of gather_stats which gathers aggregate data too.
343
    if 'revisions' in stats:
344
        revisions = stats['revisions']
4307.3.1 by Jelmer Vernooij
Allow registering hooks that extend the Repository section in 'bzr info -v'.
345
        f.write('  %8d revision%s\n' % (revisions, plural(revisions)))
2258.1.2 by Robert Collins
New version of gather_stats which gathers aggregate data too.
346
    if 'size' in stats:
7143.15.2 by Jelmer Vernooij
Run autopep8.
347
        f.write('  %8d KiB\n' % (stats['size'] / 1024))
4307.3.1 by Jelmer Vernooij
Allow registering hooks that extend the Repository section in 'bzr info -v'.
348
    for hook in hooks['repository']:
4307.3.3 by Jelmer Vernooij
Add repository argument to 'repository' info hook, per Roberts review.
349
        hook(repository, stats, f)
7045.3.1 by Jelmer Vernooij
Fix another ~500 tests.
350
    if f.getvalue() != "":
4307.3.1 by Jelmer Vernooij
Allow registering hooks that extend the Repository section in 'bzr info -v'.
351
        outfile.write('\n')
352
        outfile.write('Repository:\n')
353
        outfile.write(f.getvalue())
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
354
1624.3.21 by Olaf Conradi
Make bzr info command work on both local and remote locations. Support
355
6653.6.1 by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir.
356
def show_bzrdir_info(a_controldir, verbose=False, outfile=None):
357
    """Output to stdout the 'info' for a_controldir."""
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
358
    if outfile is None:
359
        outfile = sys.stdout
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
360
    try:
6653.6.1 by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir.
361
        tree = a_controldir.open_workingtree(
2363.5.9 by Aaron Bentley
Merge from bzr.dev
362
            recommend_upgrade=False)
6241.4.3 by Jelmer Vernooij
Add test for dangling tree references.
363
    except (NoWorkingTree, NotLocalUrl, NotBranchError):
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
364
        tree = None
365
        try:
6653.6.1 by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir.
366
            branch = a_controldir.open_branch(name="")
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
367
        except NotBranchError:
368
            branch = None
369
            try:
6653.6.1 by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir.
370
                repository = a_controldir.open_repository()
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
371
            except NoRepositoryPresent:
6241.4.2 by Jelmer Vernooij
No longer show empty output when only control directory is present.
372
                lockable = None
373
                repository = None
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
374
            else:
375
                lockable = repository
376
        else:
377
            repository = branch.repository
378
            lockable = branch
379
    else:
380
        branch = tree.branch
381
        repository = branch.repository
382
        lockable = tree
383
6241.4.2 by Jelmer Vernooij
No longer show empty output when only control directory is present.
384
    if lockable is not None:
385
        lockable.lock_read()
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
386
    try:
6653.6.1 by Jelmer Vernooij
Rename a number of attributes from bzrdir to controldir.
387
        show_component_info(a_controldir, repository, branch, tree, verbose,
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
388
                            outfile)
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
389
    finally:
6241.4.2 by Jelmer Vernooij
No longer show empty output when only control directory is present.
390
        if lockable is not None:
391
            lockable.unlock()
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
392
393
394
def show_component_info(control, repository, branch=None, working=None,
7143.15.2 by Jelmer Vernooij
Run autopep8.
395
                        verbose=1, outfile=None):
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
396
    """Write info about all bzrdir components to stdout"""
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
397
    if outfile is None:
398
        outfile = sys.stdout
2363.5.7 by Aaron Bentley
Make verbose mean what I want
399
    if verbose is False:
400
        verbose = 1
401
    if verbose is True:
402
        verbose = 2
6241.4.3 by Jelmer Vernooij
Add test for dangling tree references.
403
    layout = describe_layout(repository, branch, working, control)
2363.5.6 by Aaron Bentley
Add short format description
404
    format = describe_format(control, repository, branch, working)
2968.2.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``
405
    outfile.write("%s (format: %s)\n" % (layout, format))
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
406
    _show_location_info(
407
        gather_location_info(control=control, repository=repository,
7143.15.2 by Jelmer Vernooij
Run autopep8.
408
                             branch=branch, working=working),
6241.4.1 by Jelmer Vernooij
Make gather_location_info understand control directories.
409
        outfile)
2584.2.1 by Adeodato Simó
Make `bzr info` show related branches in non-verbose mode.
410
    if branch is not None:
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
411
        _show_related_info(branch, outfile)
2363.5.7 by Aaron Bentley
Make verbose mean what I want
412
    if verbose == 0:
413
        return
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
414
    _show_format_info(control, repository, branch, working, outfile)
415
    _show_locking_info(repository, branch, working, outfile)
6240.1.1 by Jelmer Vernooij
Show the number of colocated branches in 'bzr info -v'.
416
    _show_control_dir_info(control, outfile)
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
417
    if branch is not None:
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
418
        _show_missing_revisions_branch(branch, outfile)
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
419
    if working is not None:
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
420
        _show_missing_revisions_working(working, outfile)
421
        _show_working_stats(working, outfile)
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
422
    elif branch is not None:
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
423
        _show_missing_revisions_branch(branch, outfile)
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
424
    if branch is not None:
4032.2.1 by Ian Clatworthy
omit branch committers from info -v (now requires -vv)
425
        show_committers = verbose >= 2
426
        stats = _show_branch_stats(branch, show_committers, outfile)
6437.33.3 by Jelmer Vernooij
Cope with repository being missing in more cases.
427
    elif repository is not None:
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
428
        stats = repository.gather_stats()
6437.33.3 by Jelmer Vernooij
Cope with repository being missing in more cases.
429
    if branch is None and working is None and repository is not None:
2904.3.1 by Lukáš Lalinský
Unicode-safe output from ``bzr info``.
430
        _show_repository_info(repository, outfile)
6437.33.3 by Jelmer Vernooij
Cope with repository being missing in more cases.
431
    if repository is not None:
432
        _show_repository_stats(repository, stats, outfile)
2363.5.1 by Aaron Bentley
Unify info display into show_component_info
433
434
6241.4.3 by Jelmer Vernooij
Add test for dangling tree references.
435
def describe_layout(repository=None, branch=None, tree=None, control=None):
2363.5.2 by Aaron Bentley
Implement layout description
436
    """Convert a control directory layout into a user-understandable term
437
438
    Common outputs include "Standalone tree", "Repository branch" and
439
    "Checkout".  Uncommon outputs include "Unshared repository with trees"
440
    and "Empty control directory"
441
    """
6241.4.3 by Jelmer Vernooij
Add test for dangling tree references.
442
    if branch is None and control is not None:
443
        try:
444
            branch_reference = control.get_branch_reference()
445
        except NotBranchError:
446
            pass
447
        else:
448
            if branch_reference is not None:
449
                return "Dangling branch reference"
2363.5.2 by Aaron Bentley
Implement layout description
450
    if repository is None:
451
        return 'Empty control directory'
452
    if branch is None and tree is None:
453
        if repository.is_shared():
454
            phrase = 'Shared repository'
455
        else:
456
            phrase = 'Unshared repository'
6437.9.1 by Jelmer Vernooij
Report present but unused colocated branches in `bzr info`.
457
        extra = []
2363.5.2 by Aaron Bentley
Implement layout description
458
        if repository.make_working_trees():
6437.9.1 by Jelmer Vernooij
Report present but unused colocated branches in `bzr info`.
459
            extra.append('trees')
460
        if len(control.get_branches()) > 0:
461
            extra.append('colocated branches')
462
        if extra:
463
            phrase += ' with ' + " and ".join(extra)
2363.5.2 by Aaron Bentley
Implement layout description
464
        return phrase
465
    else:
466
        if repository.is_shared():
467
            independence = "Repository "
468
        else:
469
            independence = "Standalone "
470
        if tree is not None:
471
            phrase = "tree"
472
        else:
473
            phrase = "branch"
474
        if branch is None and tree is not None:
475
            phrase = "branchless tree"
476
        else:
6874.1.2 by Jelmer Vernooij
Consistently use Branch.user_url.
477
            if (tree is not None and tree.controldir.control_url !=
7143.15.2 by Jelmer Vernooij
Run autopep8.
478
                    branch.controldir.control_url):
2363.5.4 by Aaron Bentley
Eliminate the concept of a 'repository lightweight checkout'
479
                independence = ''
2363.5.2 by Aaron Bentley
Implement layout description
480
                phrase = "Lightweight checkout"
481
            elif branch.get_bound_location() is not None:
482
                if independence == 'Standalone ':
483
                    independence = ''
484
                if tree is None:
485
                    phrase = "Bound branch"
486
                else:
487
                    phrase = "Checkout"
488
        if independence != "":
489
            phrase = phrase.lower()
490
        return "%s%s" % (independence, phrase)
491
492
2363.5.5 by Aaron Bentley
add info.describe_format
493
def describe_format(control, repository, branch, tree):
494
    """Determine the format of an existing control directory
495
496
    Several candidates may be found.  If so, the names are returned as a
2363.5.17 by Aaron Bentley
Change separator from '/' to 'or'
497
    single string, separated by ' or '.
2363.5.5 by Aaron Bentley
add info.describe_format
498
499
    If no matching candidate is found, "unnamed" is returned.
500
    """
7143.15.2 by Jelmer Vernooij
Run autopep8.
501
    candidates = []
2363.5.6 by Aaron Bentley
Add short format description
502
    if (branch is not None and tree is not None and
7143.15.2 by Jelmer Vernooij
Run autopep8.
503
            branch.user_url != tree.user_url):
2363.5.6 by Aaron Bentley
Add short format description
504
        branch = None
505
        repository = None
6207.3.3 by jelmer at samba
Fix tests and the like.
506
    non_aliases = set(controldir.format_registry.keys())
507
    non_aliases.difference_update(controldir.format_registry.aliases())
3152.2.2 by Robert Collins
The bzrdir format registry now accepts an ``alias`` keyword to
508
    for key in non_aliases:
6653.6.5 by Jelmer Vernooij
Rename make_bzrdir to make_controldir.
509
        format = controldir.format_registry.make_controldir(key)
2363.5.5 by Aaron Bentley
add info.describe_format
510
        if isinstance(format, bzrdir.BzrDirMetaFormat1):
511
            if (tree and format.workingtree_format !=
7143.15.2 by Jelmer Vernooij
Run autopep8.
512
                    tree._format):
2363.5.5 by Aaron Bentley
add info.describe_format
513
                continue
514
            if (branch and format.get_branch_format() !=
7143.15.2 by Jelmer Vernooij
Run autopep8.
515
                    branch._format):
2363.5.5 by Aaron Bentley
add info.describe_format
516
                continue
517
            if (repository and format.repository_format !=
7143.15.2 by Jelmer Vernooij
Run autopep8.
518
                    repository._format):
2363.5.5 by Aaron Bentley
add info.describe_format
519
                continue
520
        if format.__class__ is not control._format.__class__:
521
            continue
522
        candidates.append(key)
523
    if len(candidates) == 0:
524
        return 'unnamed'
3152.2.2 by Robert Collins
The bzrdir format registry now accepts an ``alias`` keyword to
525
    candidates.sort()
2363.5.6 by Aaron Bentley
Add short format description
526
    new_candidates = [c for c in candidates if not
7143.15.2 by Jelmer Vernooij
Run autopep8.
527
                      controldir.format_registry.get_info(c).hidden]
2363.5.6 by Aaron Bentley
Add short format description
528
    if len(new_candidates) > 0:
3152.2.2 by Robert Collins
The bzrdir format registry now accepts an ``alias`` keyword to
529
        # If there are any non-hidden formats that match, only return those to
530
        # avoid listing hidden formats except when only a hidden format will
531
        # do.
2363.5.6 by Aaron Bentley
Add short format description
532
        candidates = new_candidates
2363.5.17 by Aaron Bentley
Change separator from '/' to 'or'
533
    return ' or '.join(candidates)
4307.3.1 by Jelmer Vernooij
Allow registering hooks that extend the Repository section in 'bzr info -v'.
534
535
536
class InfoHooks(_mod_hooks.Hooks):
537
    """Hooks for the info command."""
538
5622.3.10 by Jelmer Vernooij
Don't require arguments to hooks.
539
    def __init__(self):
6622.1.34 by Jelmer Vernooij
Rename brzlib => breezy.
540
        super(InfoHooks, self).__init__("breezy.info", "hooks")
7143.15.5 by Jelmer Vernooij
More PEP8 fixes.
541
        self.add_hook(
542
            'repository',
543
            "Invoked when displaying the statistics for a repository. "
544
            "repository is called with a statistics dictionary as returned "
545
            "by the repository and a file-like object to write to.", (1, 15))
5622.3.2 by Jelmer Vernooij
Add more lazily usable hook points.
546
547
5622.3.10 by Jelmer Vernooij
Don't require arguments to hooks.
548
hooks = InfoHooks()