2017-12-01 08:52:54 -08:00
|
|
|
package store
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
import (
|
2018-07-12 16:58:51 -07:00
|
|
|
"io"
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
)
|
|
|
|
|
2017-12-01 08:52:54 -08:00
|
|
|
//----------------------------------------
|
|
|
|
// cacheMultiStore
|
|
|
|
|
2017-12-03 22:55:15 -08:00
|
|
|
// cacheMultiStore holds many cache-wrapped stores.
|
2017-12-01 08:52:54 -08:00
|
|
|
// Implements MultiStore.
|
|
|
|
type cacheMultiStore struct {
|
2018-01-30 05:59:28 -08:00
|
|
|
db CacheKVStore
|
|
|
|
stores map[StoreKey]CacheWrap
|
|
|
|
keysByName map[string]StoreKey
|
2018-07-12 16:58:51 -07:00
|
|
|
|
|
|
|
traceWriter io.Writer
|
|
|
|
traceContext TraceContext
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
|
|
|
|
2018-01-30 05:59:28 -08:00
|
|
|
var _ CacheMultiStore = cacheMultiStore{}
|
|
|
|
|
2017-12-04 00:23:10 -08:00
|
|
|
func newCacheMultiStoreFromRMS(rms *rootMultiStore) cacheMultiStore {
|
2017-12-01 08:52:54 -08:00
|
|
|
cms := cacheMultiStore{
|
2018-07-12 16:58:51 -07:00
|
|
|
db: NewCacheKVStore(dbStoreAdapter{rms.db}),
|
|
|
|
stores: make(map[StoreKey]CacheWrap, len(rms.stores)),
|
|
|
|
keysByName: rms.keysByName,
|
|
|
|
traceWriter: rms.traceWriter,
|
|
|
|
traceContext: rms.traceContext,
|
2017-12-04 00:23:10 -08:00
|
|
|
}
|
2018-07-12 16:58:51 -07:00
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
for key, store := range rms.stores {
|
2018-07-12 16:58:51 -07:00
|
|
|
if cms.TracingEnabled() {
|
|
|
|
cms.stores[key] = store.CacheWrapWithTrace(cms.traceWriter, cms.traceContext)
|
|
|
|
} else {
|
|
|
|
cms.stores[key] = store.CacheWrap()
|
|
|
|
}
|
2017-12-04 00:23:10 -08:00
|
|
|
}
|
2018-07-12 16:58:51 -07:00
|
|
|
|
2017-12-04 00:23:10 -08:00
|
|
|
return cms
|
|
|
|
}
|
|
|
|
|
|
|
|
func newCacheMultiStoreFromCMS(cms cacheMultiStore) cacheMultiStore {
|
2017-12-04 00:56:25 -08:00
|
|
|
cms2 := cacheMultiStore{
|
2018-07-12 16:58:51 -07:00
|
|
|
db: NewCacheKVStore(cms.db),
|
|
|
|
stores: make(map[StoreKey]CacheWrap, len(cms.stores)),
|
|
|
|
traceWriter: cms.traceWriter,
|
|
|
|
traceContext: cms.traceContext,
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
2018-07-12 16:58:51 -07:00
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
for key, store := range cms.stores {
|
2018-07-12 16:58:51 -07:00
|
|
|
if cms2.TracingEnabled() {
|
|
|
|
cms2.stores[key] = store.CacheWrapWithTrace(cms2.traceWriter, cms2.traceContext)
|
|
|
|
} else {
|
|
|
|
cms2.stores[key] = store.CacheWrap()
|
|
|
|
}
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
2018-07-12 16:58:51 -07:00
|
|
|
|
2017-12-04 00:56:25 -08:00
|
|
|
return cms2
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
|
|
|
|
2018-07-12 16:58:51 -07:00
|
|
|
// WithTracer sets the tracer for the MultiStore that the underlying
|
|
|
|
// stores will utilize to trace operations. A MultiStore is returned.
|
|
|
|
func (cms cacheMultiStore) WithTracer(w io.Writer) MultiStore {
|
|
|
|
cms.traceWriter = w
|
|
|
|
return cms
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithTracingContext updates the tracing context for the MultiStore by merging
|
|
|
|
// the given context with the existing context by key. Any existing keys will
|
|
|
|
// be overwritten. It is implied that the caller should update the context when
|
|
|
|
// necessary between tracing operations. It returns a modified MultiStore.
|
|
|
|
func (cms cacheMultiStore) WithTracingContext(tc TraceContext) MultiStore {
|
|
|
|
if cms.traceContext != nil {
|
|
|
|
for k, v := range tc {
|
|
|
|
cms.traceContext[k] = v
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
cms.traceContext = tc
|
|
|
|
}
|
|
|
|
|
|
|
|
return cms
|
|
|
|
}
|
|
|
|
|
|
|
|
// TracingEnabled returns if tracing is enabled for the MultiStore.
|
|
|
|
func (cms cacheMultiStore) TracingEnabled() bool {
|
|
|
|
return cms.traceWriter != nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ResetTraceContext resets the current tracing context.
|
|
|
|
func (cms cacheMultiStore) ResetTraceContext() MultiStore {
|
|
|
|
cms.traceContext = nil
|
|
|
|
return cms
|
|
|
|
}
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
// Implements Store.
|
|
|
|
func (cms cacheMultiStore) GetStoreType() StoreType {
|
|
|
|
return sdk.StoreTypeMulti
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
// Implements CacheMultiStore.
|
2017-12-01 08:52:54 -08:00
|
|
|
func (cms cacheMultiStore) Write() {
|
|
|
|
cms.db.Write()
|
2018-01-22 05:44:24 -08:00
|
|
|
for _, store := range cms.stores {
|
|
|
|
store.Write()
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
// Implements CacheWrapper.
|
2017-12-04 00:56:25 -08:00
|
|
|
func (cms cacheMultiStore) CacheWrap() CacheWrap {
|
2017-12-12 20:13:51 -08:00
|
|
|
return cms.CacheMultiStore().(CacheWrap)
|
2017-12-04 00:56:25 -08:00
|
|
|
}
|
|
|
|
|
2018-07-12 16:58:51 -07:00
|
|
|
// CacheWrapWithTrace implements the CacheWrapper interface.
|
|
|
|
func (cms cacheMultiStore) CacheWrapWithTrace(_ io.Writer, _ TraceContext) CacheWrap {
|
|
|
|
return cms.CacheWrap()
|
|
|
|
}
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
// Implements MultiStore.
|
2017-12-04 00:23:10 -08:00
|
|
|
func (cms cacheMultiStore) CacheMultiStore() CacheMultiStore {
|
|
|
|
return newCacheMultiStoreFromCMS(cms)
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
// Implements MultiStore.
|
|
|
|
func (cms cacheMultiStore) GetStore(key StoreKey) Store {
|
|
|
|
return cms.stores[key].(Store)
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
|
|
|
|
2018-01-22 05:44:24 -08:00
|
|
|
// Implements MultiStore.
|
|
|
|
func (cms cacheMultiStore) GetKVStore(key StoreKey) KVStore {
|
|
|
|
return cms.stores[key].(KVStore)
|
2017-12-01 08:52:54 -08:00
|
|
|
}
|
2018-05-11 08:46:50 -07:00
|
|
|
|
|
|
|
// Implements MultiStore.
|
|
|
|
func (cms cacheMultiStore) GetKVStoreWithGas(meter sdk.GasMeter, key StoreKey) KVStore {
|
|
|
|
return NewGasKVStore(meter, cms.GetKVStore(key))
|
|
|
|
}
|