Commit 8ae42901 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 82a5c353
...@@ -292,37 +292,42 @@ def Restructure(ztree, newStructure): ...@@ -292,37 +292,42 @@ def Restructure(ztree, newStructure):
# set znode states according to established tnew->znode association # set znode states according to established tnew->znode association
for nodev in levelv: for rnodev in rlevelv:
for node in nodev: for rn in rnodev:
node = rn.node
assert isinstance(node, Tree) # buckets were filtered out to rbucketv
znode = node.Z znode = node.Z
if isinstance(node, Bucket): # https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BTreeTemplate.c#L1087
# https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BucketTemplate.c#L1195 if len(node.keyv) == 0:
zstate = () panic("TODO: empty tree + tree with bucket without oid")
for k in node.keyv:
zstate += (k, kv.pop(k)) # (k1, v1, k2, v2, ..., kN, vN)
zstate = (zstate,)
if node.next_bucket is not None: # next zstate = ()
zstate += (node.next_bucket.Z,) assert len(node.children) == len(node.keyv) + 1
zstate += node.children[0]
for (child, k) in zip(node.children[1:], node.keyv):
zstate += (k, child) # (child0, k0, child1, k1, ..., childN, kN, childN+1)
zstate = (zstate,)
else: # firstbucket
assert isinstance(node, Tree) zstate += (None,) # XXX
# https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BTreeTemplate.c#L1087
if len(node.keyv) == 0: znode.__setstate__(zstate)
panic("TODO: empty tree + tree with bucket without oid")
zstate = () # ----//---- for buckets
assert len(node.children) == len(node.keyv) + 1 for rbucket in rbucketv:
zstate += node.children[0] node = rbucket.node
for (child, k) in zip(node.children[1:], node.keyv):
zstate += (k, child) # (child0, k0, child1, k1, ..., childN, kN, childN+1)
zstate = (zstate,)
# firstbucket # https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BucketTemplate.c#L1195
zstate += (None,) # XXX zstate = ()
for k in node.keyv:
zstate += (k, kv.pop(k)) # (k1, v1, k2, v2, ..., kN, vN)
zstate = (zstate,)
znode.__setstate__(zstate) if node.next_bucket is not None: # next
zstate += (node.next_bucket.Z,)
node.Z.__setstate__(zstate)
assert tnew.Z is ztree assert tnew.Z is ztree
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment