/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 breezy/plugins/weave_fmt/xml4.py

  • Committer: Breezy landing bot
  • Author(s): Colin Watson
  • Date: 2020-11-16 21:47:08 UTC
  • mfrom: (7521.1.1 remove-lp-workaround)
  • Revision ID: breezy.the.bot@gmail.com-20201116214708-jos209mgxi41oy15
Remove breezy.git workaround for bazaar.launchpad.net.

Merged from https://code.launchpad.net/~cjwatson/brz/remove-lp-workaround/+merge/393710

Show diffs side-by-side

added added

removed removed

Lines of Context:
14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
16
 
17
 
from __future__ import absolute_import
18
 
 
19
 
from bzrlib.xml_serializer import (
 
17
from ...bzr.xml_serializer import (
20
18
    Element,
21
19
    SubElement,
22
20
    XMLSerializer,
23
21
    escape_invalid_chars,
24
22
    )
25
 
from bzrlib.inventory import ROOT_ID, Inventory
26
 
import bzrlib.inventory as inventory
27
 
from bzrlib.revision import Revision
28
 
from bzrlib.errors import BzrError
 
23
from ...bzr.inventory import ROOT_ID, Inventory
 
24
from ...bzr import inventory
 
25
from ...revision import Revision
 
26
from ...errors import BzrError
29
27
 
30
28
 
31
29
class _Serializer_v4(XMLSerializer):
42
40
        """Convert InventoryEntry to XML element"""
43
41
        e = Element('entry')
44
42
        e.set('name', ie.name)
45
 
        e.set('file_id', ie.file_id)
 
43
        e.set('file_id', ie.file_id.decode('ascii'))
46
44
        e.set('kind', ie.kind)
47
45
 
48
46
        if ie.text_size is not None:
63
61
 
64
62
        return e
65
63
 
66
 
 
67
64
    def _unpack_inventory(self, elt, revision_id=None, entry_cache=None,
68
65
                          return_from_cache=False):
69
66
        """Construct from XML Element
70
67
 
71
68
        :param revision_id: Ignored parameter used by xml5.
72
69
        """
73
 
        root_id = elt.get('file_id') or ROOT_ID
 
70
        root_id = elt.get('file_id')
 
71
        root_id = (root_id.encode('ascii') if root_id else ROOT_ID)
74
72
        inv = Inventory(root_id)
75
73
        for e in elt:
76
74
            ie = self._unpack_entry(e, entry_cache=entry_cache,
80
78
            inv.add(ie)
81
79
        return inv
82
80
 
83
 
 
84
81
    def _unpack_entry(self, elt, entry_cache=None, return_from_cache=False):
85
 
        ## original format inventories don't have a parent_id for
86
 
        ## nodes in the root directory, but it's cleaner to use one
87
 
        ## internally.
 
82
        # original format inventories don't have a parent_id for
 
83
        # nodes in the root directory, but it's cleaner to use one
 
84
        # internally.
88
85
        parent_id = elt.get('parent_id')
89
 
        if parent_id is None:
90
 
            parent_id = ROOT_ID
 
86
        parent_id = (parent_id.encode('ascii') if parent_id else ROOT_ID)
91
87
 
 
88
        file_id = elt.get('file_id').encode('ascii')
92
89
        kind = elt.get('kind')
93
90
        if kind == 'directory':
94
 
            ie = inventory.InventoryDirectory(elt.get('file_id'),
 
91
            ie = inventory.InventoryDirectory(file_id,
95
92
                                              elt.get('name'),
96
93
                                              parent_id)
97
94
        elif kind == 'file':
98
 
            ie = inventory.InventoryFile(elt.get('file_id'),
 
95
            ie = inventory.InventoryFile(file_id,
99
96
                                         elt.get('name'),
100
97
                                         parent_id)
101
98
            ie.text_id = elt.get('text_id')
 
99
            if ie.text_id is not None:
 
100
                ie.text_id = ie.text_id.encode('utf-8')
102
101
            ie.text_sha1 = elt.get('text_sha1')
 
102
            if ie.text_sha1 is not None:
 
103
                ie.text_sha1 = ie.text_sha1.encode('ascii')
103
104
            v = elt.get('text_size')
104
105
            ie.text_size = v and int(v)
105
106
        elif kind == 'symlink':
106
 
            ie = inventory.InventoryLink(elt.get('file_id'),
 
107
            ie = inventory.InventoryLink(file_id,
107
108
                                         elt.get('name'),
108
109
                                         parent_id)
109
110
            ie.symlink_target = elt.get('symlink_target')
114
115
 
115
116
        return ie
116
117
 
117
 
 
118
118
    def _pack_revision(self, rev):
119
119
        """Revision object -> xml tree"""
120
120
        root = Element('revision',
121
 
                       committer = rev.committer,
122
 
                       timestamp = '%.9f' % rev.timestamp,
123
 
                       revision_id = rev.revision_id,
124
 
                       inventory_id = rev.inventory_id,
125
 
                       inventory_sha1 = rev.inventory_sha1,
 
121
                       committer=rev.committer,
 
122
                       timestamp='%.9f' % rev.timestamp,
 
123
                       revision_id=rev.revision_id,
 
124
                       inventory_id=rev.inventory_id,
 
125
                       inventory_sha1=rev.inventory_sha1,
126
126
                       )
127
127
        if rev.timezone:
128
128
            root.set('timezone', str(rev.timezone))
143
143
                    p.set('revision_sha1', rev.parent_sha1s[i])
144
144
        return root
145
145
 
 
146
    def write_revision_to_string(self, rev):
 
147
        return tostring(self._pack_revision(rev)) + b'\n'
 
148
 
 
149
    def _write_element(self, elt, f):
 
150
        ElementTree(elt).write(f, 'utf-8')
 
151
        f.write(b'\n')
146
152
 
147
153
    def _unpack_revision(self, elt):
148
154
        """XML Element -> Revision object"""
151
157
        if elt.tag not in ('revision', 'changeset'):
152
158
            raise BzrError("unexpected tag in revision file: %r" % elt)
153
159
 
154
 
        rev = Revision(committer = elt.get('committer'),
155
 
                       timestamp = float(elt.get('timestamp')),
156
 
                       revision_id = elt.get('revision_id'),
157
 
                       inventory_id = elt.get('inventory_id'),
158
 
                       inventory_sha1 = elt.get('inventory_sha1')
 
160
        rev = Revision(committer=elt.get('committer'),
 
161
                       timestamp=float(elt.get('timestamp')),
 
162
                       revision_id=elt.get('revision_id'),
 
163
                       inventory_id=elt.get('inventory_id'),
 
164
                       inventory_sha1=elt.get('inventory_sha1')
159
165
                       )
160
166
 
161
167
        precursor = elt.get('precursor')
179
185
        v = elt.get('timezone')
180
186
        rev.timezone = v and int(v)
181
187
 
182
 
        rev.message = elt.findtext('message') # text of <message>
 
188
        rev.message = elt.findtext('message')  # text of <message>
183
189
        return rev
184
190
 
185
191
 
186
 
 
187
 
 
188
192
"""singleton instance"""
189
193
serializer_v4 = _Serializer_v4()
190