2019-02-05 20:15:50 +01:00
|
|
|
import eth/trie/db, ranges
|
2018-12-03 17:54:19 +07:00
|
|
|
|
|
|
|
type
|
|
|
|
CaptureFlags* {.pure.} = enum
|
|
|
|
PersistPut
|
|
|
|
PersistDel
|
|
|
|
|
|
|
|
DB = TrieDatabaseRef
|
|
|
|
BytesRange = Range[byte]
|
|
|
|
|
|
|
|
CaptureDB* = ref object of RootObj
|
|
|
|
srcDb: DB
|
|
|
|
dstDb: DB
|
|
|
|
flags: set[CaptureFlags]
|
|
|
|
|
|
|
|
proc get*(db: CaptureDB, key: openArray[byte]): seq[byte] =
|
|
|
|
result = db.dstDb.get(key)
|
|
|
|
if result.len != 0: return
|
|
|
|
result = db.srcDb.get(key)
|
2018-12-27 10:08:20 +07:00
|
|
|
if result.len != 0:
|
2018-12-27 09:47:34 +07:00
|
|
|
db.dstDb.put(key, result)
|
2018-12-03 17:54:19 +07:00
|
|
|
|
|
|
|
proc put*(db: CaptureDB, key, value: openArray[byte]) =
|
|
|
|
db.dstDb.put(key, value)
|
|
|
|
if CaptureFlags.PersistPut in db.flags:
|
|
|
|
db.srcDb.put(key, value)
|
|
|
|
|
|
|
|
proc contains*(db: CaptureDB, key: openArray[byte]): bool =
|
|
|
|
result = db.srcDb.contains(key)
|
|
|
|
assert(db.dstDb.contains(key) == result)
|
|
|
|
|
|
|
|
proc del*(db: CaptureDB, key: openArray[byte]) =
|
|
|
|
db.dstDb.del(key)
|
|
|
|
if CaptureFlags.PersistDel in db.flags:
|
|
|
|
db.srcDb.del(key)
|
|
|
|
|
|
|
|
proc newCaptureDB*(srcDb, dstDb: DB, flags: set[CaptureFlags] = {}): CaptureDB =
|
|
|
|
result.new()
|
|
|
|
result.srcDb = srcDb
|
|
|
|
result.dstDb = dstDb
|
|
|
|
result.flags = flags
|