/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/xml4.py

  • Committer: Martin Pool
  • Date: 2007-10-03 08:06:44 UTC
  • mto: This revision was merged to the branch mainline in revision 2901.
  • Revision ID: mbp@sourcefrog.net-20071003080644-oivy0gkg98sex0ed
Avoid internal error tracebacks on failure to lock on readonly transport (#129701).

Add new LockFailed, which doesn't imply that we failed to get it because of
contention.  Raise this if we fail to create the pending or lock directories
because of Transport errors.

UnlockableTransport is not an internal error.

ReadOnlyLockError has a message which didn't match its name or usage; it's now
deprecated and callers are updated to use LockFailed which is more appropriate.

Add zero_ninetytwo deprecation symbol.

Unify assertMatchesRe with TestCase.assertContainsRe.

When the constructor is deprecated, just say that the class is deprecated, not
the __init__ method - this works better with applyDeprecated in tests.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2005, 2006 Canonical Ltd
 
2
#
 
3
# This program is free software; you can redistribute it and/or modify
 
4
# it under the terms of the GNU General Public License as published by
 
5
# the Free Software Foundation; either version 2 of the License, or
 
6
# (at your option) any later version.
 
7
#
 
8
# This program is distributed in the hope that it will be useful,
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
11
# GNU General Public License for more details.
 
12
#
 
13
# You should have received a copy of the GNU General Public License
 
14
# along with this program; if not, write to the Free Software
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
16
 
 
17
from bzrlib.xml_serializer import ElementTree, SubElement, Element, Serializer
 
18
from bzrlib.inventory import ROOT_ID, Inventory, InventoryEntry
 
19
import bzrlib.inventory as inventory
 
20
from bzrlib.revision import Revision
 
21
from bzrlib.errors import BzrError
 
22
 
 
23
 
 
24
class _Serializer_v4(Serializer):
 
25
    """Version 0.0.4 serializer
 
26
 
 
27
    You should use the serializer_v4 singleton.
 
28
    
 
29
    v4 serialisation is no longer supported, only deserialisation.
 
30
    """
 
31
    
 
32
    __slots__ = []
 
33
    
 
34
    def _pack_entry(self, ie):
 
35
        """Convert InventoryEntry to XML element"""
 
36
        e = Element('entry')
 
37
        e.set('name', ie.name)
 
38
        e.set('file_id', ie.file_id)
 
39
        e.set('kind', ie.kind)
 
40
 
 
41
        if ie.text_size is not None:
 
42
            e.set('text_size', '%d' % ie.text_size)
 
43
 
 
44
        for f in ['text_id', 'text_sha1', 'symlink_target']:
 
45
            v = getattr(ie, f)
 
46
            if v is not None:
 
47
                e.set(f, v)
 
48
 
 
49
        # to be conservative, we don't externalize the root pointers
 
50
        # for now, leaving them as null in the xml form.  in a future
 
51
        # version it will be implied by nested elements.
 
52
        if ie.parent_id != ROOT_ID:
 
53
            assert isinstance(ie.parent_id, basestring)
 
54
            e.set('parent_id', ie.parent_id)
 
55
 
 
56
        e.tail = '\n'
 
57
 
 
58
        return e
 
59
 
 
60
 
 
61
    def _unpack_inventory(self, elt):
 
62
        """Construct from XML Element
 
63
        """
 
64
        assert elt.tag == 'inventory'
 
65
        root_id = elt.get('file_id') or ROOT_ID
 
66
        inv = Inventory(root_id)
 
67
        for e in elt:
 
68
            ie = self._unpack_entry(e)
 
69
            if ie.parent_id == ROOT_ID:
 
70
                ie.parent_id = root_id
 
71
            inv.add(ie)
 
72
        return inv
 
73
 
 
74
 
 
75
    def _unpack_entry(self, elt):
 
76
        assert elt.tag == 'entry'
 
77
 
 
78
        ## original format inventories don't have a parent_id for
 
79
        ## nodes in the root directory, but it's cleaner to use one
 
80
        ## internally.
 
81
        parent_id = elt.get('parent_id')
 
82
        if parent_id is None:
 
83
            parent_id = ROOT_ID
 
84
 
 
85
        kind = elt.get('kind')
 
86
        if kind == 'directory':
 
87
            ie = inventory.InventoryDirectory(elt.get('file_id'),
 
88
                                              elt.get('name'),
 
89
                                              parent_id)
 
90
        elif kind == 'file':
 
91
            ie = inventory.InventoryFile(elt.get('file_id'),
 
92
                                         elt.get('name'),
 
93
                                         parent_id)
 
94
            ie.text_id = elt.get('text_id')
 
95
            ie.text_sha1 = elt.get('text_sha1')
 
96
            v = elt.get('text_size')
 
97
            ie.text_size = v and int(v)
 
98
        elif kind == 'symlink':
 
99
            ie = inventory.InventoryLink(elt.get('file_id'),
 
100
                                         elt.get('name'),
 
101
                                         parent_id)
 
102
            ie.symlink_target = elt.get('symlink_target')
 
103
        else:
 
104
            raise BzrError("unknown kind %r" % kind)
 
105
 
 
106
        ## mutter("read inventoryentry: %r", elt.attrib)
 
107
 
 
108
        return ie
 
109
 
 
110
 
 
111
    def _pack_revision(self, rev):
 
112
        """Revision object -> xml tree"""
 
113
        root = Element('revision',
 
114
                       committer = rev.committer,
 
115
                       timestamp = '%.9f' % rev.timestamp,
 
116
                       revision_id = rev.revision_id,
 
117
                       inventory_id = rev.inventory_id,
 
118
                       inventory_sha1 = rev.inventory_sha1,
 
119
                       )
 
120
        if rev.timezone:
 
121
            root.set('timezone', str(rev.timezone))
 
122
        root.text = '\n'
 
123
 
 
124
        msg = SubElement(root, 'message')
 
125
        msg.text = rev.message
 
126
        msg.tail = '\n'
 
127
 
 
128
        if rev.parents:
 
129
            pelts = SubElement(root, 'parents')
 
130
            pelts.tail = pelts.text = '\n'
 
131
            for i, parent_id in enumerate(rev.parents):
 
132
                p = SubElement(pelts, 'revision_ref')
 
133
                p.tail = '\n'
 
134
                assert parent_id
 
135
                p.set('revision_id', parent_id)
 
136
                if i < len(rev.parent_sha1s):
 
137
                    p.set('revision_sha1', rev.parent_sha1s[i])
 
138
        return root
 
139
 
 
140
    
 
141
    def _unpack_revision(self, elt):
 
142
        """XML Element -> Revision object"""
 
143
        
 
144
        # <changeset> is deprecated...
 
145
        if elt.tag not in ('revision', 'changeset'):
 
146
            raise BzrError("unexpected tag in revision file: %r" % elt)
 
147
 
 
148
        rev = Revision(committer = elt.get('committer'),
 
149
                       timestamp = float(elt.get('timestamp')),
 
150
                       revision_id = elt.get('revision_id'),
 
151
                       inventory_id = elt.get('inventory_id'),
 
152
                       inventory_sha1 = elt.get('inventory_sha1')
 
153
                       )
 
154
 
 
155
        precursor = elt.get('precursor')
 
156
        precursor_sha1 = elt.get('precursor_sha1')
 
157
 
 
158
        pelts = elt.find('parents')
 
159
 
 
160
        if pelts:
 
161
            for p in pelts:
 
162
                assert p.tag == 'revision_ref', \
 
163
                       "bad parent node tag %r" % p.tag
 
164
                rev.parent_ids.append(p.get('revision_id'))
 
165
                rev.parent_sha1s.append(p.get('revision_sha1'))
 
166
            if precursor:
 
167
                # must be consistent
 
168
                prec_parent = rev.parent_ids[0]
 
169
                assert prec_parent == precursor
 
170
        elif precursor:
 
171
            # revisions written prior to 0.0.5 have a single precursor
 
172
            # give as an attribute
 
173
            rev.parent_ids.append(precursor)
 
174
            rev.parent_sha1s.append(precursor_sha1)
 
175
 
 
176
        v = elt.get('timezone')
 
177
        rev.timezone = v and int(v)
 
178
 
 
179
        rev.message = elt.findtext('message') # text of <message>
 
180
        return rev
 
181
 
 
182
 
 
183
 
 
184
 
 
185
"""singleton instance"""
 
186
serializer_v4 = _Serializer_v4()
 
187