/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/annotate.py

  • Committer: Robert Collins
  • Date: 2005-10-16 22:31:25 UTC
  • mto: This revision was merged to the branch mainline in revision 1458.
  • Revision ID: robertc@lifelesslap.robertcollins.net-20051016223125-26d4401cb94b7b82
Branch.relpath has been moved to WorkingTree.relpath.

WorkingTree no no longer takes an inventory, rather it takes an optional branch
parameter, and if None is given will open the branch at basedir implicitly.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2004, 2005 by Canonical Ltd
 
2
 
 
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.
 
7
 
 
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.
 
12
 
 
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
 
 
17
"""File annotate based on weave storage"""
 
18
 
 
19
# TODO: Choice of more or less verbose formats:
 
20
 
21
# short: just show revno
 
22
# long: revno, author, date
 
23
# interposed: show more details between blocks of modified lines
 
24
 
 
25
# TODO: Show which revision caused a line to merge into the parent
 
26
 
 
27
import sys
 
28
import os
 
29
import time
 
30
 
 
31
import bzrlib.weave
 
32
 
 
33
def annotate_file(branch, rev_id, file_id, to_file=None):
 
34
    if to_file is None:
 
35
        to_file = sys.stdout
 
36
    rh = branch.revision_history()
 
37
    w = branch.weave_store.get_weave(file_id, branch.get_transaction())
 
38
    last_origin = None
 
39
    for origin, text in w.annotate_iter(rev_id):
 
40
        text = text.rstrip('\r\n')
 
41
        if origin == last_origin:
 
42
            anno = ''
 
43
        else:
 
44
            last_origin = origin
 
45
            line_rev_id = w.idx_to_name(origin)
 
46
            if not branch.has_revision(line_rev_id):
 
47
                anno = '???'
 
48
            else:
 
49
                if line_rev_id in rh:
 
50
                    revno_str = str(rh.index(line_rev_id) + 1)
 
51
                else:
 
52
                    revno_str = 'merge'
 
53
            rev = branch.get_revision(line_rev_id)
 
54
            tz = rev.timezone or 0
 
55
            date_str = time.strftime('%Y%m%d', 
 
56
                                     time.gmtime(rev.timestamp + tz))
 
57
            # a lazy way to get something like the email address
 
58
            # TODO: Get real email address
 
59
            author = line_rev_id
 
60
            if '@' in author:
 
61
                author = author[:author.index('@')]
 
62
            author = author[:12]
 
63
            anno = '%5s %-12s %8s' % (revno_str, author, date_str)
 
64
        print '%-27.27s | %s' % (anno, text)
 
65
 
 
66
 
 
67
if __name__ == '__main__':
 
68
    from bzrlib.branch import Branch
 
69
    from bzrlib.trace import enable_default_logging
 
70
    from bzrlib.workingtree import WorkingTree
 
71
 
 
72
    enable_default_logging()
 
73
    b = Branch.open_containing(sys.argv[1])
 
74
    tree = WorkingTree(b.base, b)
 
75
    rp = tree.relpath(sys.argv[1])
 
76
    tree = b.revision_tree(b.last_revision())
 
77
    file_id = tree.inventory.path2id(rp)
 
78
    file_version = tree.inventory[file_id].revision
 
79
    annotate_file(b, file_version, file_id, sys.stdout)