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
c32f1c78
Commit
c32f1c78
authored
Aug 25, 2017
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
44357788
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
72 additions
and
68 deletions
+72
-68
go/neo/client/cache.go
go/neo/client/cache.go
+72
-68
No files found.
go/neo/client/cache.go
View file @
c32f1c78
...
...
@@ -101,6 +101,12 @@ type revCacheEntry struct {
ready
chan
struct
{}
// closed when loading finished
}
// lock order: Cache.mu > oidCacheEntry > (?) revCacheEntry
// Cache.gcMu > ?
// XXX maintain nhit / nmiss?
// NewCache creates new cache backed up by loader
// XXX +sizeMax
func
NewCache
(
loader
storLoader
)
*
Cache
{
...
...
@@ -112,74 +118,6 @@ func NewCache(loader storLoader) *Cache {
return
c
}
// newRevEntry creates new revCacheEntry with .before and inserts it into .rcev @i.
// (if i == len(oce.rcev) - entry is appended)
func
(
oce
*
oidCacheEntry
)
newRevEntry
(
i
int
,
before
zodb
.
Tid
)
*
revCacheEntry
{
rce
:=
&
revCacheEntry
{
parent
:
oce
,
serial
:
0
,
before
:
before
,
ready
:
make
(
chan
struct
{}),
}
rce
.
inLRU
.
Init
()
oce
.
rcev
=
append
(
oce
.
rcev
,
nil
)
copy
(
oce
.
rcev
[
i
+
1
:
],
oce
.
rcev
[
i
:
])
oce
.
rcev
[
i
]
=
rce
return
rce
}
// find finds rce in .rcev and returns its index
// not found -> -1.
func
(
oce
*
oidCacheEntry
)
find
(
rce
*
revCacheEntry
)
int
{
for
i
,
r
:=
range
oce
.
rcev
{
if
r
==
rce
{
return
i
}
}
return
-
1
}
// deli deletes .rcev[i]
func
(
oce
*
oidCacheEntry
)
deli
(
i
int
)
{
n
:=
len
(
oce
.
rcev
)
-
1
copy
(
oce
.
rcev
[
i
:
],
oce
.
rcev
[
i
+
1
:
])
// release ptr to revCacheEntry so it won't confusingly stay live when
// its turn to be deleted come.
oce
.
rcev
[
n
]
=
nil
oce
.
rcev
=
oce
.
rcev
[
:
n
]
}
// del delets rce from .rcev.
// it panics if rce is not there.
func
(
oce
*
oidCacheEntry
)
del
(
rce
*
revCacheEntry
)
{
i
:=
oce
.
find
(
rce
)
if
i
==
-
1
{
panic
(
"rce not found"
)
}
oce
.
deli
(
i
)
}
// lock order: Cache.mu > oidCacheEntry > (?) revCacheEntry
// Cache.gcMu > ?
// XXX maintain nhit / nmiss?
// isErrNoData returns whether an error is due to "there is no such data in
// database", not e.g. some IO loading error
func
isErrNoData
(
err
error
)
bool
{
switch
err
.
(
type
)
{
default
:
return
false
case
*
zodb
.
ErrOidMissing
:
case
*
zodb
.
ErrXidMissing
:
}
return
true
}
// Load loads data from database via cache.
//
// If data is already in cache cached content is returned.
...
...
@@ -233,6 +171,7 @@ func (c *Cache) Prefetch(xid zodb.Xid) {
}
// lookupRCE returns revCacheEntry corresponding to xid.
//
// If xid indicates loadSerial query (xid.TidBefore=false) then rce will be
...
...
@@ -460,6 +399,8 @@ func tryMerge(prev, next, cur *revCacheEntry, oid zodb.Oid) bool {
return
false
}
// ----------------------------------------
/*
func (c *cache) gc(...) {
c.lruMu.Lock()
...
...
@@ -493,6 +434,69 @@ func (c *cache) cleaner() {
}
*/
// isErrNoData returns whether an error is due to "there is no such data in
// database", not e.g. some IO loading error
func
isErrNoData
(
err
error
)
bool
{
switch
err
.
(
type
)
{
default
:
return
false
case
*
zodb
.
ErrOidMissing
:
case
*
zodb
.
ErrXidMissing
:
}
return
true
}
// newRevEntry creates new revCacheEntry with .before and inserts it into .rcev @i.
// (if i == len(oce.rcev) - entry is appended)
func
(
oce
*
oidCacheEntry
)
newRevEntry
(
i
int
,
before
zodb
.
Tid
)
*
revCacheEntry
{
rce
:=
&
revCacheEntry
{
parent
:
oce
,
serial
:
0
,
before
:
before
,
ready
:
make
(
chan
struct
{}),
}
rce
.
inLRU
.
Init
()
oce
.
rcev
=
append
(
oce
.
rcev
,
nil
)
copy
(
oce
.
rcev
[
i
+
1
:
],
oce
.
rcev
[
i
:
])
oce
.
rcev
[
i
]
=
rce
return
rce
}
// find finds rce in .rcev and returns its index
// not found -> -1.
func
(
oce
*
oidCacheEntry
)
find
(
rce
*
revCacheEntry
)
int
{
for
i
,
r
:=
range
oce
.
rcev
{
if
r
==
rce
{
return
i
}
}
return
-
1
}
// deli deletes .rcev[i]
func
(
oce
*
oidCacheEntry
)
deli
(
i
int
)
{
n
:=
len
(
oce
.
rcev
)
-
1
copy
(
oce
.
rcev
[
i
:
],
oce
.
rcev
[
i
+
1
:
])
// release ptr to revCacheEntry so it won't confusingly stay live when
// its turn to be deleted come.
oce
.
rcev
[
n
]
=
nil
oce
.
rcev
=
oce
.
rcev
[
:
n
]
}
// del delets rce from .rcev.
// it panics if rce is not there.
func
(
oce
*
oidCacheEntry
)
del
(
rce
*
revCacheEntry
)
{
i
:=
oce
.
find
(
rce
)
if
i
==
-
1
{
panic
(
"rce not found"
)
}
oce
.
deli
(
i
)
}
// loaded reports whether rce was already loaded
func
(
rce
*
revCacheEntry
)
loaded
()
bool
{
...
...
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