~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/xml4.py

- add short-form of testaments

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006 Canonical Ltd
2
 
#
 
1
#! /usr/bin/env python
 
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
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
 
from bzrlib.xml_serializer import ElementTree, SubElement, Element, Serializer
 
17
 
 
18
from bzrlib.xml import ElementTree, SubElement, Element, Serializer
18
19
from bzrlib.inventory import ROOT_ID, Inventory, InventoryEntry
19
20
import bzrlib.inventory as inventory
20
 
from bzrlib.revision import Revision
 
21
from bzrlib.revision import Revision        
21
22
from bzrlib.errors import BzrError
22
23
 
23
24
 
 
25
 
 
26
 
 
27
 
 
28
 
24
29
class _Serializer_v4(Serializer):
25
30
    """Version 0.0.4 serializer
26
31
 
27
 
    You should use the serializer_v4 singleton.
28
 
    
29
 
    v4 serialisation is no longer supported, only deserialisation.
30
 
    """
 
32
    You should use the serialzer_v4 singleton."""
31
33
    
32
34
    __slots__ = []
33
35
    
 
36
    def _pack_inventory(self, inv):
 
37
        """Convert to XML Element"""
 
38
        e = Element('inventory')
 
39
        e.text = '\n'
 
40
        if inv.root.file_id not in (None, ROOT_ID):
 
41
            e.set('file_id', inv.root.file_id)
 
42
        for path, ie in inv.iter_entries():
 
43
            e.append(self._pack_entry(ie))
 
44
        return e
 
45
 
 
46
 
34
47
    def _pack_entry(self, ie):
35
48
        """Convert InventoryEntry to XML element"""
36
49
        e = Element('entry')
38
51
        e.set('file_id', ie.file_id)
39
52
        e.set('kind', ie.kind)
40
53
 
41
 
        if ie.text_size is not None:
 
54
        if ie.text_size != None:
42
55
            e.set('text_size', '%d' % ie.text_size)
43
56
 
44
57
        for f in ['text_id', 'text_sha1', 'symlink_target']:
45
58
            v = getattr(ie, f)
46
 
            if v is not None:
 
59
            if v != None:
47
60
                e.set(f, v)
48
61
 
49
62
        # to be conservative, we don't externalize the root pointers
50
63
        # for now, leaving them as null in the xml form.  in a future
51
64
        # version it will be implied by nested elements.
52
65
        if ie.parent_id != ROOT_ID:
 
66
            assert isinstance(ie.parent_id, basestring)
53
67
            e.set('parent_id', ie.parent_id)
54
68
 
55
69
        e.tail = '\n'
57
71
        return e
58
72
 
59
73
 
60
 
    def _unpack_inventory(self, elt, revision_id=None):
 
74
    def _unpack_inventory(self, elt):
61
75
        """Construct from XML Element
62
 
 
63
 
        :param revision_id: Ignored parameter used by xml5.
64
76
        """
 
77
        assert elt.tag == 'inventory'
65
78
        root_id = elt.get('file_id') or ROOT_ID
66
79
        inv = Inventory(root_id)
67
80
        for e in elt:
73
86
 
74
87
 
75
88
    def _unpack_entry(self, elt):
 
89
        assert elt.tag == 'entry'
 
90
 
76
91
        ## original format inventories don't have a parent_id for
77
92
        ## nodes in the root directory, but it's cleaner to use one
78
93
        ## internally.
79
94
        parent_id = elt.get('parent_id')
80
 
        if parent_id is None:
 
95
        if parent_id == None:
81
96
            parent_id = ROOT_ID
82
97
 
83
98
        kind = elt.get('kind')
101
116
        else:
102
117
            raise BzrError("unknown kind %r" % kind)
103
118
 
104
 
        ## mutter("read inventoryentry: %r", elt.attrib)
 
119
        ## mutter("read inventoryentry: %r" % (elt.attrib))
105
120
 
106
121
        return ie
107
122
 
129
144
            for i, parent_id in enumerate(rev.parents):
130
145
                p = SubElement(pelts, 'revision_ref')
131
146
                p.tail = '\n'
 
147
                assert parent_id
132
148
                p.set('revision_id', parent_id)
133
149
                if i < len(rev.parent_sha1s):
134
150
                    p.set('revision_sha1', rev.parent_sha1s[i])
156
172
 
157
173
        if pelts:
158
174
            for p in pelts:
 
175
                assert p.tag == 'revision_ref', \
 
176
                       "bad parent node tag %r" % p.tag
159
177
                rev.parent_ids.append(p.get('revision_id'))
160
178
                rev.parent_sha1s.append(p.get('revision_sha1'))
161
179
            if precursor:
162
180
                # must be consistent
163
181
                prec_parent = rev.parent_ids[0]
 
182
                assert prec_parent == precursor
164
183
        elif precursor:
165
184
            # revisions written prior to 0.0.5 have a single precursor
166
185
            # give as an attribute