Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
B
b
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
b
Commits
6926aba3
Commit
6926aba3
authored
Apr 11, 2017
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
050650f2
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
58 deletions
+40
-58
btree.go
btree.go
+40
-58
No files found.
btree.go
View file @
6926aba3
...
@@ -39,10 +39,8 @@ type btTpool struct{ sync.Pool }
...
@@ -39,10 +39,8 @@ type btTpool struct{ sync.Pool }
func
(
p
*
btTpool
)
get
(
cmp
Cmp
)
*
Tree
{
func
(
p
*
btTpool
)
get
(
cmp
Cmp
)
*
Tree
{
x
:=
p
.
Get
()
.
(
*
Tree
)
x
:=
p
.
Get
()
.
(
*
Tree
)
x
.
cmp
=
cmp
x
.
cmp
=
cmp
//x.hitDi = -1
x
.
hitDi
=
-
1
//x.hitPi = -1
x
.
hitPi
=
-
1
//x.hitMinKMInf = true
//x.hitMaxKInf = true
return
x
return
x
}
}
...
@@ -102,20 +100,14 @@ type (
...
@@ -102,20 +100,14 @@ type (
r
interface
{}
r
interface
{}
ver
int64
ver
int64
// last data page which Set/Put/Delete/XXX recheck modified
// information about last data page which Set/Put/Delete modified
// XXX naming
hitD
*
d
// data page & pos of last write access
hitD
*
d
hitDi
int
hitDi
int
hitKmin
xkey
hitP
*
x
// parent & pos for data page (= -1 if no parent)
hitPi
int
hitKmin
xkey
// data page key range is [hitKmin, hitKmax)
hitKmax
xkey
hitKmax
xkey
hitPKmax
xkey
// Kmax for hit range one level up XXX text
//hitP *x
//hitPi int
//hitMinK interface{} /*K*/
//hitMinKMInf bool // whether hitMinK = -∞
//hitMaxK interface{} /*K*/
//hitMaxKInf bool // whether hitMaxK = +∞
}
}
xe
struct
{
// x element
xe
struct
{
// x element
...
@@ -566,7 +558,7 @@ func (t *Tree) Len() int {
...
@@ -566,7 +558,7 @@ func (t *Tree) Len() int {
return
t
.
c
return
t
.
c
}
}
func
(
t
*
Tree
)
overflow
(
p
*
x
,
q
*
d
,
pi
,
i
int
,
hitKmaxPrev
xkey
,
k
interface
{}
/*K*/
,
v
interface
{}
/*V*/
)
{
func
(
t
*
Tree
)
overflow
(
p
*
x
,
q
*
d
,
pi
,
i
int
,
k
interface
{}
/*K*/
,
v
interface
{}
/*V*/
)
{
t
.
ver
++
t
.
ver
++
l
,
r
:=
p
.
siblings
(
pi
)
l
,
r
:=
p
.
siblings
(
pi
)
...
@@ -575,22 +567,19 @@ func (t *Tree) overflow(p *x, q *d, pi, i int, hitKmaxPrev xkey, k interface{} /
...
@@ -575,22 +567,19 @@ func (t *Tree) overflow(p *x, q *d, pi, i int, hitKmaxPrev xkey, k interface{} /
t
.
insert
(
q
,
i
-
1
,
k
,
v
)
t
.
insert
(
q
,
i
-
1
,
k
,
v
)
p
.
x
[
pi
-
1
]
.
k
=
q
.
d
[
0
]
.
k
p
.
x
[
pi
-
1
]
.
k
=
q
.
d
[
0
]
.
k
t
.
hitKmin
.
set
(
q
.
d
[
0
]
.
k
)
t
.
hitKmin
.
set
(
q
.
d
[
0
]
.
k
)
t
.
hitPi
=
pi
// XXX already pre-set this way
//t.hitP = p // minK = q.d[0].k (= p.x[pi-1].k)
t
.
checkHitP
(
q
)
//t.hitPi = pi
//t.checkHitP(q)
return
return
}
}
if
r
!=
nil
&&
r
.
c
<
2
*
kd
{
if
r
!=
nil
&&
r
.
c
<
2
*
kd
{
//t.hitP = p
if
i
<
2
*
kd
{
if
i
<
2
*
kd
{
q
.
mvR
(
r
,
1
)
q
.
mvR
(
r
,
1
)
t
.
insert
(
q
,
i
,
k
,
v
)
t
.
insert
(
q
,
i
,
k
,
v
)
p
.
x
[
pi
]
.
k
=
r
.
d
[
0
]
.
k
p
.
x
[
pi
]
.
k
=
r
.
d
[
0
]
.
k
t
.
hitKmax
.
set
(
r
.
d
[
0
]
.
k
)
t
.
hitKmax
.
set
(
r
.
d
[
0
]
.
k
)
//t.hitPi = pi // maxK = r.d[0].k (= p.x[pi].k)
t
.
hitPi
=
pi
// XXX already pre-set this way
//
t.checkHitP(q)
t
.
checkHitP
(
q
)
return
return
}
}
...
@@ -598,21 +587,17 @@ func (t *Tree) overflow(p *x, q *d, pi, i int, hitKmaxPrev xkey, k interface{} /
...
@@ -598,21 +587,17 @@ func (t *Tree) overflow(p *x, q *d, pi, i int, hitKmaxPrev xkey, k interface{} /
p
.
x
[
pi
]
.
k
=
k
p
.
x
[
pi
]
.
k
=
k
t
.
hitKmin
.
set
(
k
)
t
.
hitKmin
.
set
(
k
)
kmax
:=
hitKmaxPrev
kmax
:=
t
.
hitPKmax
if
pi
+
1
<
p
.
c
{
// means < ∞
if
pi
+
1
<
p
.
c
{
// means < ∞
kmax
.
set
(
p
.
x
[
pi
+
1
]
.
k
)
kmax
.
set
(
p
.
x
[
pi
+
1
]
.
k
)
}
}
t
.
hitKmax
=
kmax
t
.
hitKmax
=
kmax
t
.
hitPi
=
pi
+
1
//t.hitPi = pi + 1
t
.
checkHitP
(
r
)
//t.checkHitP(r)
//if p.x[t.hitPi].ch != r {
// panic(p.x)
//}
return
return
}
}
t
.
split
(
p
,
q
,
pi
,
i
,
hitKmaxPrev
,
k
,
v
)
t
.
split
(
p
,
q
,
pi
,
i
,
k
,
v
)
}
}
// Seek returns an Enumerator positioned on an item such that k >= item's key.
// Seek returns an Enumerator positioned on an item such that k >= item's key.
...
@@ -672,9 +657,6 @@ func (t *Tree) SeekLast() (e *Enumerator, err error) {
...
@@ -672,9 +657,6 @@ func (t *Tree) SeekLast() (e *Enumerator, err error) {
func
(
t
*
Tree
)
Set
(
k
interface
{}
/*K*/
,
v
interface
{}
/*V*/
)
{
func
(
t
*
Tree
)
Set
(
k
interface
{}
/*K*/
,
v
interface
{}
/*V*/
)
{
//dbg("--- PRE Set(%v, %v)\t(%v @%d, [%v, %v))\n%s", k, v, t.hitD, t.hitDi, t.hitKmin, t.hitKmax, t.dump())
//dbg("--- PRE Set(%v, %v)\t(%v @%d, [%v, %v))\n%s", k, v, t.hitD, t.hitDi, t.hitKmin, t.hitKmax, t.dump())
//defer func() {
//defer func() {
// //if r := recover(); r != nil {
// // panic(r)
// //}
// dbg("--- POST\n%s\n====\n", t.dump())
// dbg("--- POST\n%s\n====\n", t.dump())
//}()
//}()
...
@@ -682,7 +664,6 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
...
@@ -682,7 +664,6 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
i
,
ok
:=
t
.
hitFind
(
k
)
i
,
ok
:=
t
.
hitFind
(
k
)
if
i
>=
0
{
if
i
>=
0
{
//dbg("hit found\t-> %d, %v", i, ok)
//dbg("hit found\t-> %d, %v", i, ok)
//dd, p, pi := t.hitD, t.hitP, t.hitPi
dd
:=
t
.
hitD
dd
:=
t
.
hitD
switch
{
switch
{
...
@@ -697,15 +678,16 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
...
@@ -697,15 +678,16 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
t
.
insert
(
dd
,
i
,
k
,
v
)
t
.
insert
(
dd
,
i
,
k
,
v
)
return
return
// XXX reenable overflow here
// here: need to overflow but we have to check: if overflowing
//case p == nil || p.c <= 2*kx:
// would cause upper lever overflow -> we cannot overflow here -
// dbg("overflow'")
// - need to do the usual scan from root to split index pages.
// t.overflow(p, dd, pi, i, k, v)
// return
default
:
default
:
// here: need to overflow but p.c > 2*kx -> need to do
p
,
pi
:=
t
.
hitP
,
t
.
hitPi
// the usual scan to split index pages
if
p
==
nil
||
p
.
c
<=
2
*
kx
{
//dbg("overflow'")
t
.
overflow
(
p
,
dd
,
pi
,
i
,
k
,
v
)
return
}
}
}
}
}
...
@@ -721,10 +703,10 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
...
@@ -721,10 +703,10 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
}
}
var
hitKmin
,
hitKmax
xkey
// initially [-∞, +∞)
var
hitKmin
,
hitKmax
xkey
// initially [-∞, +∞)
var
hit
KmaxPrev
xkey
// hitKmax state @ prev iter
var
hit
PKmax
xkey
// hitKmax state @ one level up
for
{
for
{
hit
KmaxPrev
=
hitKmax
// XXX here? - recheck
hit
PKmax
=
hitKmax
i
,
ok
=
t
.
find
(
q
,
k
)
i
,
ok
=
t
.
find
(
q
,
k
)
switch
x
:=
q
.
(
type
)
{
switch
x
:=
q
.
(
type
)
{
...
@@ -760,8 +742,11 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
...
@@ -760,8 +742,11 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
case
*
d
:
case
*
d
:
// data page found - perform the update
// data page found - perform the update
t
.
hitP
=
p
t
.
hitPi
=
pi
t
.
hitKmin
=
hitKmin
t
.
hitKmin
=
hitKmin
t
.
hitKmax
=
hitKmax
t
.
hitKmax
=
hitKmax
t
.
hitPKmax
=
hitPKmax
switch
{
switch
{
case
ok
:
case
ok
:
...
@@ -775,8 +760,8 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
...
@@ -775,8 +760,8 @@ func (t *Tree) Set(k interface{} /*K*/, v interface{} /*V*/) {
default
:
default
:
//dbg("overflow")
//dbg("overflow")
// NOTE overflow will correct hit
-range
as needed
// NOTE overflow will correct hit
Kmin, Kmax, P and Pi
as needed
t
.
overflow
(
p
,
x
,
pi
,
i
,
hitKmaxPrev
,
k
,
v
)
t
.
overflow
(
p
,
x
,
pi
,
i
,
k
,
v
)
}
}
return
return
...
@@ -869,7 +854,6 @@ func (t *Tree) Put(k interface{} /*K*/, upd func(oldV interface{} /*V*/, exists
...
@@ -869,7 +854,6 @@ func (t *Tree) Put(k interface{} /*K*/, upd func(oldV interface{} /*V*/, exists
}
}
}
}
/*
func
(
t
*
Tree
)
checkHitP
(
q
*
d
)
{
func
(
t
*
Tree
)
checkHitP
(
q
*
d
)
{
p
:=
t
.
hitP
p
:=
t
.
hitP
pi
:=
t
.
hitPi
pi
:=
t
.
hitPi
...
@@ -882,9 +866,8 @@ func (t *Tree) checkHitP(q *d) {
...
@@ -882,9 +866,8 @@ func (t *Tree) checkHitP(q *d) {
panic
(
0
)
panic
(
0
)
}
}
}
}
*/
func
(
t
*
Tree
)
split
(
p
*
x
,
q
*
d
,
pi
,
i
int
,
hitKmaxPrev
xkey
,
k
interface
{}
/*K*/
,
v
interface
{}
/*V*/
)
{
func
(
t
*
Tree
)
split
(
p
*
x
,
q
*
d
,
pi
,
i
int
,
k
interface
{}
/*K*/
,
v
interface
{}
/*V*/
)
{
t
.
ver
++
t
.
ver
++
r
:=
btDPool
.
Get
()
.
(
*
d
)
r
:=
btDPool
.
Get
()
.
(
*
d
)
if
q
.
n
!=
nil
{
if
q
.
n
!=
nil
{
...
@@ -909,25 +892,24 @@ func (t *Tree) split(p *x, q *d, pi, i int, hitKmaxPrev xkey, k interface{} /*K*
...
@@ -909,25 +892,24 @@ func (t *Tree) split(p *x, q *d, pi, i int, hitKmaxPrev xkey, k interface{} /*K*
p
=
newX
(
q
)
.
insert
(
0
,
r
.
d
[
0
]
.
k
,
r
)
p
=
newX
(
q
)
.
insert
(
0
,
r
.
d
[
0
]
.
k
,
r
)
pi
=
0
pi
=
0
t
.
r
=
p
t
.
r
=
p
t
.
hitP
=
p
}
}
//t.hitP = p
if
i
>
kd
{
if
i
>
kd
{
t
.
insert
(
r
,
i
-
kd
,
k
,
v
)
t
.
insert
(
r
,
i
-
kd
,
k
,
v
)
t
.
hitKmin
.
set
(
p
.
x
[
pi
]
.
k
)
t
.
hitKmin
.
set
(
p
.
x
[
pi
]
.
k
)
kmax
:=
hitKmaxPrev
kmax
:=
t
.
hitPKmax
if
pi
+
1
<
p
.
c
{
if
pi
+
1
<
p
.
c
{
kmax
.
set
(
p
.
x
[
pi
+
1
]
.
k
)
kmax
.
set
(
p
.
x
[
pi
+
1
]
.
k
)
}
}
t
.
hitKmax
=
kmax
t
.
hitKmax
=
kmax
t
.
hitPi
=
pi
+
1
//t.hitPi = pi + 1 // minK = p.x[pi].k; maxK = derive-up(p.x[pi+1].k)
t
.
checkHitP
(
r
)
//t.checkHitP(r)
}
else
{
}
else
{
t
.
insert
(
q
,
i
,
k
,
v
)
t
.
insert
(
q
,
i
,
k
,
v
)
t
.
hitKmax
.
set
(
r
.
d
[
0
]
.
k
)
t
.
hitKmax
.
set
(
r
.
d
[
0
]
.
k
)
//t.hitPi = pi // maxK = r.d[0].k (= p.x[pi].k XXX recheck)
t
.
hitPi
=
pi
// XXX already pre-set so
//
t.checkHitP(q)
t
.
checkHitP
(
q
)
}
}
}
}
...
...
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