~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/info.py

  • Committer: Jelmer Vernooij
  • Date: 2010-12-20 11:57:14 UTC
  • mto: This revision was merged to the branch mainline in revision 5577.
  • Revision ID: jelmer@samba.org-20101220115714-2ru3hfappjweeg7q
Don't use no-plugins.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006, 2007 Canonical Ltd
2
 
 
1
# Copyright (C) 2005-2010 Canonical Ltd
 
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
5
5
# the Free Software Foundation; either version 2 of the License, or
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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
17
__all__ = ['show_bzrdir_info']
18
18
 
19
 
import os
 
19
from cStringIO import StringIO
20
20
import time
21
21
import sys
22
22
 
23
23
from bzrlib import (
24
24
    bzrdir,
25
 
    diff,
26
25
    errors,
 
26
    hooks as _mod_hooks,
27
27
    osutils,
28
28
    urlutils,
29
29
    )
30
30
from bzrlib.errors import (NoWorkingTree, NotBranchError,
31
31
                           NoRepositoryPresent, NotLocalUrl)
32
32
from bzrlib.missing import find_unmerged
33
 
from bzrlib.symbol_versioning import (deprecated_function,
34
 
        zero_eighteen)
35
33
 
36
34
 
37
35
def plural(n, base='', pl=None):
80
78
 
81
79
def gather_location_info(repository, branch=None, working=None):
82
80
    locs = {}
83
 
    repository_path = repository.bzrdir.root_transport.base
 
81
    repository_path = repository.user_url
84
82
    if branch is not None:
85
 
        branch_path = branch.bzrdir.root_transport.base
 
83
        branch_path = branch.user_url
86
84
        master_path = branch.get_bound_location()
87
85
        if master_path is None:
88
86
            master_path = branch_path
90
88
        branch_path = None
91
89
        master_path = None
92
90
    if working:
93
 
        working_path = working.bzrdir.root_transport.base
 
91
        working_path = working.user_url
94
92
        if working_path != branch_path:
95
93
            locs['light checkout root'] = working_path
96
94
        if master_path != branch_path:
143
141
    locs.add_url('push branch', branch.get_push_location())
144
142
    locs.add_url('parent branch', branch.get_parent())
145
143
    locs.add_url('submit branch', branch.get_submit_branch())
 
144
    try:
 
145
        locs.add_url('stacked on', branch.get_stacked_on_url())
 
146
    except (errors.UnstackableBranchFormat, errors.UnstackableRepositoryFormat,
 
147
        errors.NotStacked):
 
148
        pass
146
149
    return locs
147
150
 
148
151
 
258
261
 
259
262
    dir_cnt = 0
260
263
    for file_id in work_inv:
261
 
        if (work_inv.get_file_kind(file_id) == 'directory' and 
 
264
        if (work_inv.get_file_kind(file_id) == 'directory' and
262
265
            not work_inv.is_root(file_id)):
263
266
            dir_cnt += 1
264
267
    outfile.write('  %8d versioned %s\n' % (dir_cnt,
296
299
            'the repository.\n')
297
300
 
298
301
 
299
 
def _show_repository_stats(stats, outfile):
 
302
def _show_repository_stats(repository, stats, outfile):
300
303
    """Show statistics about a repository."""
301
 
    if 'revisions' in stats or 'size' in stats:
302
 
        outfile.write('\n')
303
 
        outfile.write('Repository:\n')
 
304
    f = StringIO()
304
305
    if 'revisions' in stats:
305
306
        revisions = stats['revisions']
306
 
        outfile.write('  %8d revision%s\n' % (revisions, plural(revisions)))
 
307
        f.write('  %8d revision%s\n' % (revisions, plural(revisions)))
307
308
    if 'size' in stats:
308
 
        outfile.write('  %8d KiB\n' % (stats['size']/1024))
 
309
        f.write('  %8d KiB\n' % (stats['size']/1024))
 
310
    for hook in hooks['repository']:
 
311
        hook(repository, stats, f)
 
312
    if f.getvalue() != "":
 
313
        outfile.write('\n')
 
314
        outfile.write('Repository:\n')
 
315
        outfile.write(f.getvalue())
309
316
 
310
317
 
311
318
def show_bzrdir_info(a_bzrdir, verbose=False, outfile=None):
373
380
    elif branch is not None:
374
381
        _show_missing_revisions_branch(branch, outfile)
375
382
    if branch is not None:
376
 
        stats = _show_branch_stats(branch, verbose==2, outfile)
 
383
        show_committers = verbose >= 2
 
384
        stats = _show_branch_stats(branch, show_committers, outfile)
377
385
    else:
378
386
        stats = repository.gather_stats()
379
387
    if branch is None and working is None:
380
388
        _show_repository_info(repository, outfile)
381
 
    _show_repository_stats(stats, outfile)
 
389
    _show_repository_stats(repository, stats, outfile)
382
390
 
383
391
 
384
392
def describe_layout(repository=None, branch=None, tree=None):
410
418
        if branch is None and tree is not None:
411
419
            phrase = "branchless tree"
412
420
        else:
413
 
            if (tree is not None and tree.bzrdir.root_transport.base !=
414
 
                branch.bzrdir.root_transport.base):
 
421
            if (tree is not None and tree.user_url !=
 
422
                branch.user_url):
415
423
                independence = ''
416
424
                phrase = "Lightweight checkout"
417
425
            elif branch.get_bound_location() is not None:
436
444
    """
437
445
    candidates  = []
438
446
    if (branch is not None and tree is not None and
439
 
        branch.bzrdir.root_transport.base !=
440
 
        tree.bzrdir.root_transport.base):
 
447
        branch.user_url != tree.user_url):
441
448
        branch = None
442
449
        repository = None
443
 
    for key in bzrdir.format_registry.keys():
 
450
    non_aliases = set(bzrdir.format_registry.keys())
 
451
    non_aliases.difference_update(bzrdir.format_registry.aliases())
 
452
    for key in non_aliases:
444
453
        format = bzrdir.format_registry.make_bzrdir(key)
445
454
        if isinstance(format, bzrdir.BzrDirMetaFormat1):
446
455
            if (tree and format.workingtree_format !=
457
466
        candidates.append(key)
458
467
    if len(candidates) == 0:
459
468
        return 'unnamed'
460
 
    new_candidates = [c for c in candidates if c != 'default']
461
 
    if len(new_candidates) > 0:
462
 
        candidates = new_candidates
 
469
    candidates.sort()
463
470
    new_candidates = [c for c in candidates if not
464
471
        bzrdir.format_registry.get_info(c).hidden]
465
472
    if len(new_candidates) > 0:
 
473
        # If there are any non-hidden formats that match, only return those to
 
474
        # avoid listing hidden formats except when only a hidden format will
 
475
        # do.
466
476
        candidates = new_candidates
467
477
    return ' or '.join(candidates)
 
478
 
 
479
 
 
480
class InfoHooks(_mod_hooks.Hooks):
 
481
    """Hooks for the info command."""
 
482
 
 
483
    def __init__(self):
 
484
        super(InfoHooks, self).__init__()
 
485
        self.create_hook(_mod_hooks.HookPoint('repository',
 
486
            "Invoked when displaying the statistics for a repository. "
 
487
            "repository is called with a statistics dictionary as returned "
 
488
            "by the repository and a file-like object to write to.", (1, 15), 
 
489
            None))
 
490
 
 
491
 
 
492
hooks = InfoHooks()