/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
0.1.80 by Martin Pool
Add test code to convert from old storage to a weave
1
#! /usr/bin/python
2
3
# Copyright (C) 2005 Canonical Ltd
4
5
# This program is free software; you can redistribute it and/or modify
6
# it under the terms of the GNU General Public License as published by
7
# the Free Software Foundation; either version 2 of the License, or
8
# (at your option) any later version.
9
10
# This program is distributed in the hope that it will be useful,
11
# but WITHOUT ANY WARRANTY; without even the implied warranty of
12
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
# GNU General Public License for more details.
14
15
# You should have received a copy of the GNU General Public License
16
# along with this program; if not, write to the Free Software
17
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18
19
"""Experiment in converting existing bzr branches to weaves."""
20
21
22
import sys
23
import bzrlib.branch
24
from weave import Weave
25
from weavefile import write_weave
26
27
import hotshot
28
import tempfile
29
30
31
def convert():
32
    WEAVE_NAME = "test.weave"
33
34
    wf = Weave()
35
36
    b = bzrlib.branch.find_branch('.')
37
38
    print 'converting...'
39
40
    fid = b.read_working_inventory().path2id(sys.argv[1])
41
0.1.81 by Martin Pool
Avoid re-encoding versions which have not changed
42
    last_lines = None
0.1.80 by Martin Pool
Add test code to convert from old storage to a weave
43
    parents = set()
0.1.81 by Martin Pool
Avoid re-encoding versions which have not changed
44
    revno = 0
0.1.80 by Martin Pool
Add test code to convert from old storage to a weave
45
    for rev_id in b.revision_history():
0.1.81 by Martin Pool
Avoid re-encoding versions which have not changed
46
        revno += 1
0.1.80 by Martin Pool
Add test code to convert from old storage to a weave
47
        print revno
48
        tree = b.revision_tree(rev_id)
49
        inv = tree.inventory
50
51
        if fid not in tree:
52
            print '  (not present)'
53
            continue
54
55
        text = tree.get_file(fid).readlines()
0.1.81 by Martin Pool
Avoid re-encoding versions which have not changed
56
57
        if text == last_lines:
58
            continue
59
        last_lines = text
60
        
0.1.80 by Martin Pool
Add test code to convert from old storage to a weave
61
        weave_id = wf.add(parents, text)
62
        parents.add(weave_id)
63
64
        print '  %4d lines' % len(text)
65
66
    write_weave(wf, file(WEAVE_NAME, 'wb'))
67
68
69
prof_f = tempfile.NamedTemporaryFile()
70
71
prof = hotshot.Profile(prof_f.name)
72
73
prof.runcall(convert) 
74
prof.close()
75
76
import hotshot.stats
77
stats = hotshot.stats.load(prof_f.name)
78
#stats.strip_dirs()
79
stats.sort_stats('time')
80
## XXX: Might like to write to stderr or the trace file instead but
81
## print_stats seems hardcoded to stdout
82
stats.print_stats(20)
83
            
84