ethereumjs-monorepo

@ethereumjs/statemanager


@ethereumjs/statemanager / StorageCache

Class: StorageCache

Defined in: cache/storage.ts:20

Extends

Constructors

Constructor

new StorageCache(opts): StorageCache

Defined in: cache/storage.ts:35

Parameters

opts

CacheOpts

Returns

StorageCache

Overrides

Cache.constructor

Properties

_checkpoints

_checkpoints: number = 0

Defined in: cache/cache.ts:8

Inherited from

Cache._checkpoints


_debug

_debug: Debugger

Defined in: cache/cache.ts:6

Inherited from

Cache._debug


_diffCache

_diffCache: Map<string, DiffStorageCacheMap>[] = []

Defined in: cache/storage.ts:33

Diff cache collecting the state of the cache at the beginning of checkpoint height (respectively: before a first modification)

If the whole cache element is undefined (in contrast to the account), the element didn’t exist in the cache before.


_lruCache

_lruCache: undefined | LRUCache<string, StorageCacheMap, unknown>

Defined in: cache/storage.ts:21


_orderedMapCache

_orderedMapCache: undefined | OrderedMap<string, StorageCacheMap>

Defined in: cache/storage.ts:22


_stats

_stats: object

Defined in: cache/cache.ts:10

deletions

deletions: number = 0

hits

hits: number = 0

reads

reads: number = 0

size

size: number = 0

writes

writes: number = 0

Inherited from

Cache._stats

Methods

_saveCachePreState()

_saveCachePreState(addressHex, keyHex): void

Defined in: cache/storage.ts:53

Parameters

addressHex

string

keyHex

string

Returns

void


checkpoint()

checkpoint(): void

Defined in: cache/storage.ts:301

Marks current state of cache as checkpoint, which can later on be reverted or committed.

Returns

void


clear()

clear(): void

Defined in: cache/storage.ts:343

Clears cache.

Returns

void


clearStorage()

clearStorage(address): void

Defined in: cache/storage.ts:175

Deletes all storage slots for address from the cache

Parameters

address

Address

Returns

void


commit()

commit(): void

Defined in: cache/storage.ts:268

Commits to current state of cache (no effect on trie).

Returns

void


del()

del(address, key): void

Defined in: cache/storage.ts:145

Marks storage key for address as deleted in cache.

Parameters

address

Address

Address

key

Uint8Array

Storage key

Returns

void


dump()

dump(address): undefined | StorageCacheMap

Defined in: cache/storage.ts:359

Dumps the RLP-encoded storage values for an account specified by address.

Parameters

address

Address

The address of the account to return storage for

Returns

undefined | StorageCacheMap


flush()

flush(): [string, string, undefined | Uint8Array<ArrayBufferLike>][]

Defined in: cache/storage.ts:188

Flushes cache by returning storage slots that have been modified or deleted and resetting the diff cache (at checkpoint height).

Returns

[string, string, undefined | Uint8Array<ArrayBufferLike>][]


get()

get(address, key): undefined | Uint8Array<ArrayBufferLike>

Defined in: cache/storage.ts:120

Returns the queried slot as the RLP encoded storage value hexToBytes(‘0x80’): slot is known to be empty undefined: slot is not in cache

Parameters

address

Address

Address of account

key

Uint8Array

Storage key

Returns

undefined | Uint8Array<ArrayBufferLike>

Storage value or undefined


put()

put(address, key, value): void

Defined in: cache/storage.ts:82

Puts storage value to cache under address_key cache key.

Parameters

address

Address

Account address

key

Uint8Array

Storage key

value

Uint8Array

Returns

void


revert()

revert(): void

Defined in: cache/storage.ts:226

Revert changes to cache last checkpoint (no effect on trie).

Returns

void


size()

size(): number

Defined in: cache/storage.ts:313

Returns the size of the cache

Returns

number


stats()

stats(reset): object

Defined in: cache/storage.ts:325

Returns a dict with cache stats

Parameters

reset

boolean = true

Returns

object

deletions

deletions: number = 0

hits

hits: number = 0

reads

reads: number = 0

size

size: number = 0

writes

writes: number = 0