aboutsummaryrefslogtreecommitdiffstats
path: root/dex/cache.go
diff options
context:
space:
mode:
authorJimmy Hu <jimmy.hu@dexon.org>2018-12-11 18:47:49 +0800
committerWei-Ning Huang <w@byzantine-lab.io>2019-06-12 17:27:19 +0800
commit7b961be2852d89870f44e3f27c9ee13354b12032 (patch)
treefcd45c987e8760dfb1de93fd5e0d3aa10653620c /dex/cache.go
parent208ba67e4ba03298aca32292e4cef11a9e49fea6 (diff)
downloadgo-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.tar
go-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.tar.gz
go-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.tar.bz2
go-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.tar.lz
go-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.tar.xz
go-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.tar.zst
go-tangerine-7b961be2852d89870f44e3f27c9ee13354b12032.zip
dex: Pull blocks from blockdb if cache miss (#84)
Diffstat (limited to 'dex/cache.go')
-rw-r--r--dex/cache.go13
1 files changed, 12 insertions, 1 deletions
diff --git a/dex/cache.go b/dex/cache.go
index 96ba2d765..c95038e1d 100644
--- a/dex/cache.go
+++ b/dex/cache.go
@@ -21,6 +21,7 @@ import (
"sync"
coreCommon "github.com/dexon-foundation/dexon-consensus/common"
+ coreBlockdb "github.com/dexon-foundation/dexon-consensus/core/blockdb"
coreTypes "github.com/dexon-foundation/dexon-consensus/core/types"
)
@@ -47,14 +48,16 @@ type cache struct {
blockCache map[coreCommon.Hash]*coreTypes.Block
voteCache map[coreTypes.Position]map[voteKey]*coreTypes.Vote
votePosition []coreTypes.Position
+ db coreBlockdb.BlockDatabase
voteSize int
size int
}
-func newCache(size int) *cache {
+func newCache(size int, db coreBlockdb.BlockDatabase) *cache {
return &cache{
blockCache: make(map[coreCommon.Hash]*coreTypes.Block),
voteCache: make(map[coreTypes.Position]map[voteKey]*coreTypes.Vote),
+ db: db,
size: size,
}
}
@@ -111,6 +114,14 @@ func (c *cache) blocks(hashes coreCommon.Hashes) []*coreTypes.Block {
for _, hash := range hashes {
if block, exist := c.blockCache[hash]; exist {
cacheBlocks = append(cacheBlocks, block)
+ } else {
+ block, err := c.db.Get(hash)
+ if err != nil {
+ continue
+ }
+ // Blocks request from the cache do not need the finalization info.
+ block.Finalization = coreTypes.FinalizationResult{}
+ cacheBlocks = append(cacheBlocks, &block)
}
}
return cacheBlocks