~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/info.py

  • Committer: Robert Collins
  • Date: 2005-08-25 00:02:12 UTC
  • mto: (974.1.50) (1185.1.10) (1092.3.1)
  • mto: This revision was merged to the branch mainline in revision 1139.
  • Revision ID: robertc@robertcollins.net-20050825000212-b95ea0dafb96ddb2
start writing star-topology test, realise we need smart-add change

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
# along with this program; if not, write to the Free Software
17
17
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18
18
 
19
 
from sets import Set
20
19
import time
21
20
 
22
 
import bzrlib
23
21
from osutils import format_date
24
22
 
 
23
 
 
24
def _countiter(it):
 
25
    # surely there's a builtin for this?
 
26
    i = 0
 
27
    for j in it:
 
28
        i += 1
 
29
    return i        
 
30
 
 
31
 
 
32
 
25
33
def show_info(b):
 
34
    import diff
 
35
    
26
36
    print 'branch format:', b.controlfile('branch-format', 'r').readline().rstrip('\n')
27
37
 
28
38
    def plural(n, base='', pl=None):
35
45
 
36
46
    count_version_dirs = 0
37
47
 
38
 
    count_status = {'A': 0, 'D': 0, 'M': 0, 'R': 0, '?': 0, 'I': 0, '.': 0}
39
 
    for st_tup in bzrlib.diff_trees(b.basis_tree(), b.working_tree()):
40
 
        fs = st_tup[0]
41
 
        count_status[fs] += 1
42
 
        if fs not in ['I', '?'] and st_tup[4] == 'directory':
43
 
            count_version_dirs += 1
44
 
 
 
48
    basis = b.basis_tree()
 
49
    working = b.working_tree()
 
50
    work_inv = working.inventory
 
51
    delta = diff.compare_trees(basis, working, want_unchanged=True)
 
52
    
45
53
    print
46
54
    print 'in the working tree:'
47
 
    for name, fs in (('unchanged', '.'),
48
 
                     ('modified', 'M'), ('added', 'A'), ('removed', 'D'),
49
 
                     ('renamed', 'R'), ('unknown', '?'), ('ignored', 'I'),
50
 
                     ):
51
 
        print '  %8d %s' % (count_status[fs], name)
52
 
    print '  %8d versioned subdirector%s' % (count_version_dirs,
53
 
                                             plural(count_version_dirs, 'y', 'ies'))
 
55
    print '  %8s unchanged' % len(delta.unchanged)
 
56
    print '  %8d modified' % len(delta.modified)
 
57
    print '  %8d added' % len(delta.added)
 
58
    print '  %8d removed' % len(delta.removed)
 
59
    print '  %8d renamed' % len(delta.renamed)
 
60
 
 
61
    ignore_cnt = unknown_cnt = 0
 
62
    for path in working.extras():
 
63
        if working.is_ignored(path):
 
64
            ignore_cnt += 1
 
65
        else:
 
66
            unknown_cnt += 1
 
67
 
 
68
    print '  %8d unknown' % unknown_cnt
 
69
    print '  %8d ignored' % ignore_cnt
 
70
 
 
71
    dir_cnt = 0
 
72
    for file_id in work_inv:
 
73
        if work_inv.get_file_kind(file_id) == 'directory':
 
74
            dir_cnt += 1
 
75
    print '  %8d versioned %s' \
 
76
          % (dir_cnt,
 
77
             plural(dir_cnt, 'subdirectory', 'subdirectories'))
54
78
 
55
79
    print
56
80
    print 'branch history:'
57
81
    history = b.revision_history()
58
82
    revno = len(history)
59
83
    print '  %8d revision%s' % (revno, plural(revno))
60
 
    committers = Set()
 
84
    committers = {}
61
85
    for rev in history:
62
 
        committers.add(b.get_revision(rev).committer)
 
86
        committers[b.get_revision(rev).committer] = True
63
87
    print '  %8d committer%s' % (len(committers), plural(len(committers)))
64
88
    if revno > 0:
65
89
        firstrev = b.get_revision(history[0])