1
# Copyright (C) 2005, 2006 Canonical Ltd
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.
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.
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
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16
from bzrlib.xml_serializer import ElementTree, SubElement, Element, Serializer
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
from bzrlib.xml_serializer import (
17
24
from bzrlib.inventory import ROOT_ID, Inventory, InventoryEntry
18
25
import bzrlib.inventory as inventory
19
from bzrlib.revision import Revision
26
from bzrlib.revision import Revision
20
27
from bzrlib.errors import BzrError
27
class _Serializer_v4(Serializer):
30
class _Serializer_v4(XMLSerializer):
28
31
"""Version 0.0.4 serializer
30
You should use the serialzer_v4 singleton."""
33
You should use the serializer_v4 singleton.
35
v4 serialisation is no longer supported, only deserialisation.
34
def _pack_inventory(self, inv):
35
"""Convert to XML Element"""
36
e = Element('inventory')
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))
45
40
def _pack_entry(self, ie):
46
41
"""Convert InventoryEntry to XML element"""
49
44
e.set('file_id', ie.file_id)
50
45
e.set('kind', ie.kind)
52
if ie.text_size != None:
47
if ie.text_size is not None:
53
48
e.set('text_size', '%d' % ie.text_size)
55
50
for f in ['text_id', 'text_sha1', 'symlink_target']:
60
55
# to be conservative, we don't externalize the root pointers
61
56
# for now, leaving them as null in the xml form. in a future
62
57
# version it will be implied by nested elements.
63
58
if ie.parent_id != ROOT_ID:
64
assert isinstance(ie.parent_id, basestring)
65
59
e.set('parent_id', ie.parent_id)
72
def _unpack_inventory(self, elt):
66
def _unpack_inventory(self, elt, revision_id=None, entry_cache=None):
73
67
"""Construct from XML Element
69
:param revision_id: Ignored parameter used by xml5.
75
assert elt.tag == 'inventory'
76
71
root_id = elt.get('file_id') or ROOT_ID
77
72
inv = Inventory(root_id)
79
ie = self._unpack_entry(e)
74
ie = self._unpack_entry(e, entry_cache=entry_cache)
80
75
if ie.parent_id == ROOT_ID:
81
76
ie.parent_id = root_id
86
def _unpack_entry(self, elt):
87
assert elt.tag == 'entry'
81
def _unpack_entry(self, elt, entry_cache=None):
89
82
## original format inventories don't have a parent_id for
90
83
## nodes in the root directory, but it's cleaner to use one
92
85
parent_id = elt.get('parent_id')
94
87
parent_id = ROOT_ID
96
89
kind = elt.get('kind')
142
135
for i, parent_id in enumerate(rev.parents):
143
136
p = SubElement(pelts, 'revision_ref')
146
138
p.set('revision_id', parent_id)
147
139
if i < len(rev.parent_sha1s):
148
140
p.set('revision_sha1', rev.parent_sha1s[i])
152
144
def _unpack_revision(self, elt):
153
145
"""XML Element -> Revision object"""
155
147
# <changeset> is deprecated...
156
148
if elt.tag not in ('revision', 'changeset'):
157
149
raise BzrError("unexpected tag in revision file: %r" % elt)
173
assert p.tag == 'revision_ref', \
174
"bad parent node tag %r" % p.tag
175
165
rev.parent_ids.append(p.get('revision_id'))
176
166
rev.parent_sha1s.append(p.get('revision_sha1'))
178
168
# must be consistent
179
169
prec_parent = rev.parent_ids[0]
180
assert prec_parent == precursor
182
171
# revisions written prior to 0.0.5 have a single precursor
183
172
# give as an attribute