~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/xml4.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2008-09-02 03:59:07 UTC
  • mfrom: (3653.2.3 integration)
  • Revision ID: pqm@pqm.ubuntu.com-20080902035907-3b81euge0gyypozk
Remove obsolete dev formats.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2005, 2006 Canonical Ltd
 
2
#
1
3
# This program is free software; you can redistribute it and/or modify
2
4
# it under the terms of the GNU General Public License as published by
3
5
# the Free Software Foundation; either version 2 of the License, or
4
6
# (at your option) any later version.
5
 
 
 
7
#
6
8
# This program is distributed in the hope that it will be useful,
7
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
8
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
9
11
# GNU General Public License for more details.
10
 
 
 
12
#
11
13
# You should have received a copy of the GNU General Public License
12
14
# along with this program; if not, write to the Free Software
13
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
14
16
 
15
 
 
16
 
from bzrlib.xml import ElementTree, SubElement, Element, Serializer
 
17
from bzrlib.xml_serializer import ElementTree, SubElement, Element, Serializer
17
18
from bzrlib.inventory import ROOT_ID, Inventory, InventoryEntry
18
19
import bzrlib.inventory as inventory
19
 
from bzrlib.revision import Revision        
 
20
from bzrlib.revision import Revision
20
21
from bzrlib.errors import BzrError
21
22
 
22
23
 
23
 
 
24
 
 
25
 
 
26
 
 
27
24
class _Serializer_v4(Serializer):
28
25
    """Version 0.0.4 serializer
29
26
 
30
 
    You should use the serialzer_v4 singleton."""
 
27
    You should use the serializer_v4 singleton.
 
28
    
 
29
    v4 serialisation is no longer supported, only deserialisation.
 
30
    """
31
31
    
32
32
    __slots__ = []
33
33
    
34
 
    def _pack_inventory(self, inv):
35
 
        """Convert to XML Element"""
36
 
        e = Element('inventory')
37
 
        e.text = '\n'
38
 
        if inv.root.file_id not in (None, ROOT_ID):
39
 
            e.set('file_id', inv.root.file_id)
40
 
        for path, ie in inv.iter_entries():
41
 
            e.append(self._pack_entry(ie))
42
 
        return e
43
 
 
44
 
 
45
34
    def _pack_entry(self, ie):
46
35
        """Convert InventoryEntry to XML element"""
47
36
        e = Element('entry')
49
38
        e.set('file_id', ie.file_id)
50
39
        e.set('kind', ie.kind)
51
40
 
52
 
        if ie.text_size != None:
 
41
        if ie.text_size is not None:
53
42
            e.set('text_size', '%d' % ie.text_size)
54
43
 
55
44
        for f in ['text_id', 'text_sha1', 'symlink_target']:
56
45
            v = getattr(ie, f)
57
 
            if v != None:
 
46
            if v is not None:
58
47
                e.set(f, v)
59
48
 
60
49
        # to be conservative, we don't externalize the root pointers
61
50
        # for now, leaving them as null in the xml form.  in a future
62
51
        # version it will be implied by nested elements.
63
52
        if ie.parent_id != ROOT_ID:
64
 
            assert isinstance(ie.parent_id, basestring)
65
53
            e.set('parent_id', ie.parent_id)
66
54
 
67
55
        e.tail = '\n'
69
57
        return e
70
58
 
71
59
 
72
 
    def _unpack_inventory(self, elt):
 
60
    def _unpack_inventory(self, elt, revision_id=None):
73
61
        """Construct from XML Element
 
62
 
 
63
        :param revision_id: Ignored parameter used by xml5.
74
64
        """
75
 
        assert elt.tag == 'inventory'
76
65
        root_id = elt.get('file_id') or ROOT_ID
77
66
        inv = Inventory(root_id)
78
67
        for e in elt:
84
73
 
85
74
 
86
75
    def _unpack_entry(self, elt):
87
 
        assert elt.tag == 'entry'
88
 
 
89
76
        ## original format inventories don't have a parent_id for
90
77
        ## nodes in the root directory, but it's cleaner to use one
91
78
        ## internally.
92
79
        parent_id = elt.get('parent_id')
93
 
        if parent_id == None:
 
80
        if parent_id is None:
94
81
            parent_id = ROOT_ID
95
82
 
96
83
        kind = elt.get('kind')
142
129
            for i, parent_id in enumerate(rev.parents):
143
130
                p = SubElement(pelts, 'revision_ref')
144
131
                p.tail = '\n'
145
 
                assert parent_id
146
132
                p.set('revision_id', parent_id)
147
133
                if i < len(rev.parent_sha1s):
148
134
                    p.set('revision_sha1', rev.parent_sha1s[i])
170
156
 
171
157
        if pelts:
172
158
            for p in pelts:
173
 
                assert p.tag == 'revision_ref', \
174
 
                       "bad parent node tag %r" % p.tag
175
159
                rev.parent_ids.append(p.get('revision_id'))
176
160
                rev.parent_sha1s.append(p.get('revision_sha1'))
177
161
            if precursor:
178
162
                # must be consistent
179
163
                prec_parent = rev.parent_ids[0]
180
 
                assert prec_parent == precursor
181
164
        elif precursor:
182
165
            # revisions written prior to 0.0.5 have a single precursor
183
166
            # give as an attribute