bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
|
0.12.3
by Aaron Bentley
Add pack serialization |
1 |
from bzrlib import pack |
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
2 |
from bzrlib.util import bencode |
3 |
||
4 |
||
5 |
def serialize(tt): |
|
6 |
new_name = dict((k, v.encode('utf-8')) for k, v in tt._new_name.items()) |
|
|
0.12.7
by Aaron Bentley
Get executability under test. |
7 |
new_executability = dict((k, int(v)) for k, v in |
8 |
tt._new_executability.items()) |
|
|
0.12.8
by Aaron Bentley
Test deleting and unversioning |
9 |
tree_path_ids = dict((k.encode('utf-8'), v) |
10 |
for k, v in tt._tree_path_ids.items()) |
|
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
11 |
attribs = { |
12 |
'_id_number': tt._id_number, |
|
13 |
'_new_name': new_name, |
|
|
0.12.2
by Aaron Bentley
Handle parents |
14 |
'_new_parent': tt._new_parent, |
|
0.12.7
by Aaron Bentley
Get executability under test. |
15 |
'_new_executability': new_executability, |
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
16 |
'_new_id': tt._new_id, |
|
0.12.8
by Aaron Bentley
Test deleting and unversioning |
17 |
'_tree_path_ids': tree_path_ids, |
18 |
'_removed_id': list(tt._removed_id), |
|
19 |
'_removed_contents': list(tt._removed_contents), |
|
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
20 |
}
|
|
0.12.3
by Aaron Bentley
Add pack serialization |
21 |
serializer = pack.ContainerSerialiser() |
22 |
yield serializer.begin() |
|
23 |
yield serializer.bytes_record(bencode.bencode(attribs), (('attribs',),)) |
|
|
0.12.4
by Aaron Bentley
Start deserializing files |
24 |
for trans_id, kind in tt._new_contents.items(): |
25 |
if kind == 'file': |
|
|
0.12.5
by Aaron Bentley
Test file content |
26 |
cur_file = open(tt._limbo_name(trans_id), 'rb') |
27 |
try: |
|
28 |
content = cur_file.read() |
|
29 |
finally: |
|
30 |
cur_file.close() |
|
|
0.12.6
by Aaron Bentley
Support serializing/deserializing directories |
31 |
if kind == 'directory': |
32 |
content = '' |
|
|
0.12.4
by Aaron Bentley
Start deserializing files |
33 |
yield serializer.bytes_record(content, ((trans_id, kind),)) |
|
0.12.3
by Aaron Bentley
Add pack serialization |
34 |
yield serializer.end() |
35 |
||
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
36 |
|
37 |
def deserialize(tt, input): |
|
|
0.12.3
by Aaron Bentley
Add pack serialization |
38 |
parser = pack.ContainerPushParser() |
39 |
for bytes in input: |
|
40 |
parser.accept_bytes(bytes) |
|
41 |
iterator = iter(parser.read_pending_records()) |
|
42 |
names, content = iterator.next() |
|
43 |
attribs = bencode.bdecode(content) |
|
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
44 |
tt._id_number = attribs['_id_number'] |
45 |
tt._new_name = dict((k, v.decode('utf-8')) |
|
46 |
for k, v in attribs['_new_name'].items()) |
|
|
0.12.2
by Aaron Bentley
Handle parents |
47 |
tt._new_parent = attribs['_new_parent'] |
|
0.12.7
by Aaron Bentley
Get executability under test. |
48 |
tt._new_executability = dict((k, bool(v)) for k, v in |
49 |
attribs['_new_executability'].items()) |
|
|
0.12.1
by Aaron Bentley
Initial bencode-based encoding |
50 |
tt._new_id = attribs['_new_id'] |
51 |
tt._r_new_id = dict((v, k) for k, v in tt._new_id.items()) |
|
|
0.12.4
by Aaron Bentley
Start deserializing files |
52 |
for ((trans_id, kind),), content in iterator: |
53 |
if kind == 'file': |
|
54 |
tt.create_file(content, trans_id) |
|
|
0.12.6
by Aaron Bentley
Support serializing/deserializing directories |
55 |
if kind == 'directory': |
56 |
tt.create_directory(trans_id) |
|
|
0.12.8
by Aaron Bentley
Test deleting and unversioning |
57 |
tt._tree_path_ids = {} |
58 |
tt._tree_id_paths = {} |
|
59 |
for bytepath, trans_id in attribs['_tree_path_ids'].items(): |
|
60 |
path = bytepath.decode('utf-8') |
|
61 |
tt._tree_path_ids[path] = trans_id |
|
62 |
tt._tree_id_paths[trans_id] = path |
|
63 |
tt._removed_id = set(attribs['_removed_id']) |
|
64 |
tt._removed_contents = set(attribs['_removed_contents']) |