feat: state-key transformation w/ override #205
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Why this should be merged
ava-labs/corethhas a partitioned state-address space, achieved by setting or clearing a specific bit in the hash used to key the space. This change allows such behaviour to be achieved with purelibevminstead of theStateDBwrapping thatcorethcurrently uses.How this works
Introduction of
state.StateDBHooksinterface, including aTransformStateKey()method that allows for arbitrary change of state key. If registered, this hook will be honoured byStateDB.{Get,GetCommitted,State}Key()methods unless they receive astateconf.SkipStateKeyTransformationoption.How this was tested
Unit test of
SetState() -> GetState() + GetCommittedState()round trip with and without options to skip.