Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neo
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
2
Merge Requests
2
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
Kirill Smelkov
neo
Commits
72a0bb1e
Commit
72a0bb1e
authored
Aug 08, 2018
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
a52a3be0
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
12 additions
and
5 deletions
+12
-5
go/zodb/btree/btree.go
go/zodb/btree/btree.go
+12
-5
No files found.
go/zodb/btree/btree.go
View file @
72a0bb1e
...
@@ -20,7 +20,7 @@
...
@@ -20,7 +20,7 @@
package
btree
package
btree
// See https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/Development.txt#L198
// See https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/Development.txt#L198
// for
details
BTree & Bucket organization details.
// for BTree & Bucket organization details.
import
(
import
(
"context"
"context"
...
@@ -35,7 +35,7 @@ import (
...
@@ -35,7 +35,7 @@ import (
// KEY is the type for BTree keys.
// KEY is the type for BTree keys.
//
//
// XXX -> template
// XXX -> template
?
type
KEY
int64
type
KEY
int64
...
@@ -45,7 +45,7 @@ type KEY int64
...
@@ -45,7 +45,7 @@ type KEY int64
type
Bucket
struct
{
type
Bucket
struct
{
zodb
.
Persistent
zodb
.
Persistent
//
py description
:
//
https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BTreeModuleTemplate.c#L179
:
//
//
// A Bucket wraps contiguous vectors of keys and values. Keys are unique,
// A Bucket wraps contiguous vectors of keys and values. Keys are unique,
// and stored in sorted order. The 'values' pointer may be NULL if the
// and stored in sorted order. The 'values' pointer may be NULL if the
...
@@ -72,11 +72,15 @@ type _BTreeItem struct {
...
@@ -72,11 +72,15 @@ type _BTreeItem struct {
type
BTree
struct
{
type
BTree
struct
{
zodb
.
Persistent
zodb
.
Persistent
// https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BTreeModuleTemplate.c#L205:
//
// firstbucket points to the bucket containing the smallest key in
// firstbucket points to the bucket containing the smallest key in
// the BTree. This is found by traversing leftmost child pointers
// the BTree. This is found by traversing leftmost child pointers
// (data[0].child) until reaching a Bucket.
// (data[0].child) until reaching a Bucket.
firstbucket
*
Bucket
firstbucket
*
Bucket
// https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BTreeModuleTemplate.c#L211:
//
// The BTree points to 'len' children, via the "child" fields of the data
// The BTree points to 'len' children, via the "child" fields of the data
// array. There are len-1 keys in the 'key' fields, stored in increasing
// array. There are len-1 keys in the 'key' fields, stored in increasing
// order. data[0].key is unused. For i in 0 .. len-1, all keys reachable
// order. data[0].key is unused. For i in 0 .. len-1, all keys reachable
...
@@ -130,6 +134,9 @@ func (t *BTree) Get(ctx context.Context, key KEY) (_ interface{}, _ bool, err er
...
@@ -130,6 +134,9 @@ func (t *BTree) Get(ctx context.Context, key KEY) (_ interface{}, _ bool, err er
}
}
// Get searches Bucket by key.
// Get searches Bucket by key.
//
// TODO Bucket.Get should not get ctx argument and just require that the bucket
// must be already activated. Correspondingly there should be no error returned.
func
(
b
*
Bucket
)
Get
(
ctx
context
.
Context
,
key
KEY
)
(
_
interface
{},
_
bool
,
err
error
)
{
func
(
b
*
Bucket
)
Get
(
ctx
context
.
Context
,
key
KEY
)
(
_
interface
{},
_
bool
,
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"bucket(%s): get %v"
,
b
.
POid
(),
key
)
defer
xerr
.
Contextf
(
&
err
,
"bucket(%s): get %v"
,
b
.
POid
(),
key
)
err
=
b
.
PActivate
(
ctx
)
err
=
b
.
PActivate
(
ctx
)
...
@@ -163,7 +170,7 @@ func (b *Bucket) get(key KEY) (interface{}, bool) {
...
@@ -163,7 +170,7 @@ func (b *Bucket) get(key KEY) (interface{}, bool) {
// ---- serialization ----
// ---- serialization ----
//
from
https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BucketTemplate.c#L1195:
// https://github.com/zopefoundation/BTrees/blob/4.5.0-1-gc8bf24e/BTrees/BucketTemplate.c#L1195:
//
//
// For a mapping bucket (self->values is not NULL), a one-tuple or two-tuple.
// For a mapping bucket (self->values is not NULL), a one-tuple or two-tuple.
// The first element is a tuple interleaving keys and values, of length
// The first element is a tuple interleaving keys and values, of length
...
@@ -236,7 +243,7 @@ func (b *bucketState) PySetState(pystate interface{}) (err error) {
...
@@ -236,7 +243,7 @@ func (b *bucketState) PySetState(pystate interface{}) (err error) {
}
}
//
from
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/BTreeTemplate.c#L1087:
//
//
// For an empty BTree (self->len == 0), None.
// For an empty BTree (self->len == 0), None.
//
//
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment