Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
W
wendelin.core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
Kirill Smelkov
wendelin.core
Commits
27e68642
Commit
27e68642
authored
Jun 07, 2021
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
0fa06cbd
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
0 additions
and
85 deletions
+0
-85
wcfs/internal/xbtree/treediff.go
wcfs/internal/xbtree/treediff.go
+0
-85
No files found.
wcfs/internal/xbtree/treediff.go
View file @
27e68642
...
@@ -89,27 +89,6 @@ type ΔValue struct {
...
@@ -89,27 +89,6 @@ type ΔValue struct {
}
}
/* XXX kill
// treeSetKey represents ordered set of keys.
// it can be point-queried and range-accessed.
// TODO -> btree
type treeSetKey struct {
SetKey
}
// InRange returns
func (hi treeSetKey) GetInRange(lo, hi_ Key) SetKey {
// FIXME dumb O(n) -> TODO use cznic/b
ret := SetKey{}
for k := range hi.SetKey {
if lo <= k && k <= hi_ {
ret.Add(k)
}
}
return ret
}
*/
// δZConnectTracked computes connected closure of δZ/T.
// δZConnectTracked computes connected closure of δZ/T.
//
//
// δZ - all changes in a ZODB transaction.
// δZ - all changes in a ZODB transaction.
...
@@ -380,18 +359,6 @@ func treediff(ctx context.Context, root zodb.Oid, δtops SetOid, δZTC SetOid, t
...
@@ -380,18 +359,6 @@ func treediff(ctx context.Context, root zodb.Oid, δtops SetOid, δZTC SetOid, t
δtrackv
=
append
(
δtrackv
,
δtrackTop
)
δtrackv
=
append
(
δtrackv
,
δtrackTop
)
}
}
/* XXX kill
// adjust holeIdx
for k, δv := range δT {
if δv.Old == VDEL {
holeIdx.Del(k)
}
if δv.New == VDEL {
holeIdx.Add(k)
}
}
*/
// adjust trackSet by merge(δtrackTops)
// adjust trackSet by merge(δtrackTops)
δtrack
=
&
ΔPPTreeSubSet
{
Del
:
PPTreeSubSet
{},
Add
:
PPTreeSubSet
{},
δnchildNonLeafs
:
map
[
zodb
.
Oid
]
int
{}}
δtrack
=
&
ΔPPTreeSubSet
{
Del
:
PPTreeSubSet
{},
Add
:
PPTreeSubSet
{},
δnchildNonLeafs
:
map
[
zodb
.
Oid
]
int
{}}
for
_
,
δ
:=
range
δtrackv
{
for
_
,
δ
:=
range
δtrackv
{
...
@@ -463,7 +430,6 @@ func diffX(ctx context.Context, a, b Node, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -463,7 +430,6 @@ func diffX(ctx context.Context, a, b Node, δZTC SetOid, trackSet PPTreeSubSet)
// a, b point to top of subtrees @old and @new revisions.
// a, b point to top of subtrees @old and @new revisions.
// δZTC is connected set of objects covering δZT (objects changed in this tree in old..new).
// δZTC is connected set of objects covering δZT (objects changed in this tree in old..new).
func
diffT
(
ctx
context
.
Context
,
A
,
B
*
Tree
,
δZTC
SetOid
,
trackSet
PPTreeSubSet
)
(
δ
map
[
Key
]
ΔValue
,
δtrack
*
ΔPPTreeSubSet
,
err
error
)
{
func
diffT
(
ctx
context
.
Context
,
A
,
B
*
Tree
,
δZTC
SetOid
,
trackSet
PPTreeSubSet
)
(
δ
map
[
Key
]
ΔValue
,
δtrack
*
ΔPPTreeSubSet
,
err
error
)
{
// var holeIdx treeSetKey XXX kill
tracef
(
" diffT %s %s
\n
"
,
xidOf
(
A
),
xidOf
(
B
))
tracef
(
" diffT %s %s
\n
"
,
xidOf
(
A
),
xidOf
(
B
))
defer
xerr
.
Contextf
(
&
err
,
"diffT %s %s"
,
xidOf
(
A
),
xidOf
(
B
))
defer
xerr
.
Contextf
(
&
err
,
"diffT %s %s"
,
xidOf
(
A
),
xidOf
(
B
))
...
@@ -533,12 +499,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -533,12 +499,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
tracef
(
" Akq <- %s
\n
"
,
δtodo
)
tracef
(
" Akq <- %s
\n
"
,
δtodo
)
Akqueue
.
UnionInplace
(
δtodo
)
Akqueue
.
UnionInplace
(
δtodo
)
}
}
/* XXX kill
if !Akdone.Has(k) {
tracef(" Akq <- %d\n", k)
Akqueue.Add(k)
}
*/
}
}
Bktodo
:=
func
(
r
KeyRange
)
{
Bktodo
:=
func
(
r
KeyRange
)
{
if
!
Bkdone
.
HasRange
(
r
)
{
if
!
Bkdone
.
HasRange
(
r
)
{
...
@@ -548,12 +508,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -548,12 +508,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
tracef
(
" Bkq <- %s
\n
"
,
δtodo
)
tracef
(
" Bkq <- %s
\n
"
,
δtodo
)
Bkqueue
.
UnionInplace
(
δtodo
)
Bkqueue
.
UnionInplace
(
δtodo
)
}
}
/* XXX kill
if !Bkdone.Has(k) {
tracef(" Bkq <- %d\n", k)
Bkqueue.Add(k)
}
*/
}
}
// {} oid -> parent for all nodes in Bv: current and previously expanded - up till top B
// {} oid -> parent for all nodes in Bv: current and previously expanded - up till top B
...
@@ -585,17 +539,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -585,17 +539,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
err
=
δMerge
(
δ
,
δA
);
/*X*/
if
err
!=
nil
{
return
nil
,
nil
,
err
}
err
=
δMerge
(
δ
,
δA
);
/*X*/
if
err
!=
nil
{
return
nil
,
nil
,
err
}
δtrack
.
Del
.
AddPath
(
ra
.
Path
())
δtrack
.
Del
.
AddPath
(
ra
.
Path
())
/*
// Bkqueue <- δA
for k := range δA {
Akdone.Add(k)
Bktodo(k)
}
// Bkqueue <- holes(ra.range) XXX -> Bktodo(ra.range)
for k := range holeIdx.GetInRange(ra.lo, ra.hi_) {
Bktodo(k)
}
*/
// Bkqueue <- ra.range
// Bkqueue <- ra.range
Bktodo
(
KeyRange
{
ra
.
lo
,
ra
.
hi_
})
Bktodo
(
KeyRange
{
ra
.
lo
,
ra
.
hi_
})
ra
.
done
=
true
ra
.
done
=
true
...
@@ -604,11 +547,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -604,11 +547,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
// empty tree - only queue holes covered by it
// empty tree - only queue holes covered by it
if
len
(
a
.
Entryv
())
==
0
{
if
len
(
a
.
Entryv
())
==
0
{
Bktodo
(
KeyRange
{
ra
.
lo
,
ra
.
hi_
})
Bktodo
(
KeyRange
{
ra
.
lo
,
ra
.
hi_
})
/* XXX kill
for k := range holeIdx.GetInRange(ra.lo, ra.hi_) {
Bktodo(k)
}
*/
continue
continue
}
}
...
@@ -662,8 +600,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -662,8 +600,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
}
}
if
found
{
if
found
{
// ac can be skipped
// ac can be skipped
// XXX Bkqueue <- holes(ac.range \ bc.range) XXX test for this
// adjust trackSet since path to the node could have changed
// adjust trackSet since path to the node could have changed
apath
:=
trackSet
.
Path
(
acOid
)
apath
:=
trackSet
.
Path
(
acOid
)
bpath
:=
BtrackSet
.
Path
(
acOid
)
bpath
:=
BtrackSet
.
Path
(
acOid
)
...
@@ -712,7 +648,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -712,7 +648,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
break
break
}
}
// for k := range Bkqueue {
for
_
,
r
:=
range
Bkqueue
.
AllRanges
()
{
for
_
,
r
:=
range
Bkqueue
.
AllRanges
()
{
lo
:=
r
.
lo
lo
:=
r
.
lo
for
{
for
{
...
@@ -734,12 +669,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -734,12 +669,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
br
:=
KeyRange
{
b
.
lo
,
b
.
hi_
}
br
:=
KeyRange
{
b
.
lo
,
b
.
hi_
}
Bkdone
.
AddRange
(
br
)
Bkdone
.
AddRange
(
br
)
Aktodo
(
br
)
Aktodo
(
br
)
/*
for k_ := range δB {
Bkdone.Add(k_)
Aktodo(k_)
}
*/
b
.
done
=
true
b
.
done
=
true
}
}
...
@@ -751,14 +680,11 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -751,14 +680,11 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
// continue with next right bucket
// continue with next right bucket
lo
=
b
.
hi_
+
1
lo
=
b
.
hi_
+
1
}
}
// XXX k is not there -> hole XXX test XXX <- kill?
}
}
Bkqueue
.
Clear
()
Bkqueue
.
Clear
()
tracef
(
"
\n
"
)
tracef
(
"
\n
"
)
tracef
(
" Akq: %s
\n
"
,
Akqueue
)
tracef
(
" Akq: %s
\n
"
,
Akqueue
)
// for k := range Akqueue {
for
_
,
r
:=
range
Akqueue
.
AllRanges
()
{
for
_
,
r
:=
range
Akqueue
.
AllRanges
()
{
lo
:=
r
.
lo
lo
:=
r
.
lo
for
{
for
{
...
@@ -780,17 +706,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
...
@@ -780,17 +706,6 @@ func diffT(ctx context.Context, A, B *Tree, δZTC SetOid, trackSet PPTreeSubSet)
ar
:=
KeyRange
{
a
.
lo
,
a
.
hi_
}
ar
:=
KeyRange
{
a
.
lo
,
a
.
hi_
}
Akdone
.
AddRange
(
ar
)
Akdone
.
AddRange
(
ar
)
Bktodo
(
ar
)
Bktodo
(
ar
)
/* XXX kill
// Bkqueue <- δA
for k_ := range δA {
Akdone.Add(k_)
Bktodo(k_)
}
// Bkqueue <- holes(a.range)
for k_ := range holeIdx.GetInRange(a.lo, a.hi_) {
Bktodo(k_)
}
*/
a
.
done
=
true
a
.
done
=
true
}
}
...
...
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