/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/weavefile.py

  • Committer: Michael Ellerman
  • Date: 2006-05-31 08:44:29 UTC
  • mto: (1711.2.63 jam-integration)
  • mto: This revision was merged to the branch mainline in revision 1792.
  • Revision ID: michael@ellerman.id.au-20060531084429-35e5429abda9f560
Add optional location to ancestry and fix behaviour for checkouts.

This adds an optional location parameter to the ancestry command. It also
changes the behaviour of ancestry on checkouts such that if they have
been created with a subset of the branch history, only the subset is
shown by 'bzr ancestry'. Tests for all of that as well.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Copyright (C) 2005 Canonical Ltd
2
 
#
 
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
6
6
# (at your option) any later version.
7
 
#
 
7
 
8
8
# This program is distributed in the hope that it will be useful,
9
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
11
# GNU General Public License for more details.
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
 
#
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
17
17
# Author: Martin Pool <mbp@canonical.com>
18
18
 
19
19
 
45
45
 
46
46
 
47
47
def write_weave(weave, f, format=None):
48
 
    if format is None or format == 1:
 
48
    if format == None or format == 1:
49
49
        return write_weave_v5(weave, f)
50
50
    else:
51
51
        raise ValueError("unknown weave format %r" % format)
53
53
 
54
54
def write_weave_v5(weave, f):
55
55
    """Write weave to file f."""
56
 
    f.write(FORMAT_1)
 
56
    print >>f, FORMAT_1,
57
57
 
58
58
    for version, included in enumerate(weave._parents):
59
59
        if included:
60
60
            # mininc = weave.minimal_parents(version)
61
61
            mininc = included
62
 
            f.write('i ')
63
 
            f.write(' '.join(str(i) for i in mininc))
64
 
            f.write('\n')
 
62
            print >>f, 'i',
 
63
            for i in mininc:
 
64
                print >>f, i,
 
65
            print >>f
65
66
        else:
66
 
            f.write('i\n')
67
 
        f.write('1 ' + weave._sha1s[version] + '\n')
68
 
        f.write('n ' + weave._names[version] + '\n')
69
 
        f.write('\n')
 
67
            print >>f, 'i'
 
68
        print >>f, '1', weave._sha1s[version]
 
69
        print >>f, 'n', weave._names[version]
 
70
        print >>f
70
71
 
71
 
    f.write('w\n')
 
72
    print >>f, 'w'
72
73
 
73
74
    for l in weave._weave:
74
75
        if isinstance(l, tuple):
 
76
            assert l[0] in '{}[]'
75
77
            if l[0] == '}':
76
 
                f.write('}\n')
 
78
                print >>f, '}'
77
79
            else:
78
 
                f.write('%s %d\n' % l)
 
80
                print >>f, '%s %d' % l
79
81
        else: # text line
80
82
            if not l:
81
 
                f.write(', \n')
 
83
                print >>f, ', '
82
84
            elif l[-1] == '\n':
83
 
                f.write('. ' + l)
 
85
                assert l.find('\n', 0, -1) == -1
 
86
                print >>f, '.', l,
84
87
            else:
85
 
                f.write(', ' + l + '\n')
 
88
                assert l.find('\n') == -1
 
89
                print >>f, ',', l
86
90
 
87
 
    f.write('W\n')
 
91
    print >>f, 'W'
88
92
 
89
93
 
90
94
 
99
103
 
100
104
def _read_weave_v5(f, w):
101
105
    """Private helper routine to read a weave format 5 file into memory.
102
 
 
 
106
    
103
107
    This is only to be used by read_weave and WeaveFile.__init__.
104
108
    """
105
109
    #  200   0   2075.5080   1084.0360   bzrlib.weavefile:104(_read_weave_v5)
115
119
    #  200   0    851.7250    501.1120   bzrlib.weavefile:104(_read_weave_v5)
116
120
    # +59363 0    311.8780    311.8780   +<method 'append' of 'list' objects>
117
121
    # +200   0     30.2500     30.2500   +<method 'readlines' of 'file' objects>
118
 
 
 
122
                  
119
123
    from weave import WeaveFormatError
120
124
 
121
125
    lines = iter(f.readlines())
122
 
 
123
 
    try:
124
 
        l = lines.next()
125
 
    except StopIteration:
126
 
        raise WeaveFormatError('invalid weave file: no header')
127
 
 
 
126
    
 
127
    l = lines.next()
128
128
    if l != FORMAT_1:
129
129
        raise WeaveFormatError('invalid weave file header: %r' % l)
130
130
 
137
137
                w._parents.append(map(int, l[2:].split(' ')))
138
138
            else:
139
139
                w._parents.append([])
 
140
 
140
141
            l = lines.next()[:-1]
 
142
            assert '1 ' == l[0:2]
141
143
            w._sha1s.append(l[2:])
 
144
                
142
145
            l = lines.next()
 
146
            assert 'n ' == l[0:2]
143
147
            name = l[2:-1]
 
148
            assert name not in w._name_map
144
149
            w._names.append(name)
145
150
            w._name_map[name] = ver
 
151
                
146
152
            l = lines.next()
 
153
            assert l == '\n'
 
154
 
147
155
            ver += 1
148
156
        elif l == 'w\n':
149
157
            break
162
170
        elif l == '}\n':
163
171
            w._weave.append(('}', None))
164
172
        else:
 
173
            assert l[0] in '{[]', l
 
174
            assert l[1] == ' ', l
165
175
            w._weave.append((intern(l[0]), int(l[2:])))
 
176
 
166
177
    return w
 
178