/brz/remove-bazaar

To get this branch, use:
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'])