Skip to content

Conversation

@ARR4N
Copy link
Collaborator

@ARR4N ARR4N commented Oct 1, 2024

Why this should be merged

Allows types.StateAccount to mirror ava-labs/coreth behaviour w.r.t. RLP encoding (i.e. IsMultiCoin) while maintaining backwards compatibility.

How this works

This is very similar to params.RegisterExtras() except that it's in the types package.

The pseudo.Type.Format() method was necessary to avoid changing upstream formatting verbs.

How this was tested

RLP encodings of vanilla-geth types.StateAccount and types.SlimAccount were first locked in with unit tests, before any libevm modidifcations. Similar test cases were generated from ava-labs/coreth with IsMultiCoin bool to be mirrored with types.RegisterExtras[bool](). Round-trip RLP encoding/decoding demonstrates correct behaviour for both geth and coreth use cases.

ARR4N added a commit that referenced this pull request Oct 1, 2024
All commits except the last two constitute PRs #43 and #44. The last two reverted files such that only changes to the `pseudo` and `ethtest` packages remain; once this is merged into the `libevm` branch then `libevm` will be merged into the branch for #44 too. Cherry-picking commits was not possible as some touched both halves of the changes; the squash-merges will, however, make this convoluted history irrelevant.

* feat: `types.StateAccount` pseudo-generic payload

* feat: registration of `StateAccount` payload type

* chore: mark `eth/tracers/logger` flaky

* chore: copyright header + `gci`

* test: lock default `types.SlimAccount` RLP encoding

* feat: `vm.SlimAccount.Extra` from `StateAccount` equiv

* chore: placate the linter

* test: `pseudo.Type.EncodeRLP()`

* test: `pseudo.Type.DecodeRLP()`

* fix: `pseudo.Type.DecodeRLP()` with non-pointer type

* feat: `pseudo.Type.IsZero()` and `Type.Equal(*Type)`

* feat: `types.StateAccountExtra.DecodeRLP()`

* chore: revert non-pseudo-package modifications

* chore: delete non-pseudo-package additions
Balance: acc.Balance,
CodeHash: acc.CodeHash,
Root: common.BytesToHash(acc.Root),
Extra: acc.Extra, // no need to deep-copy as `acc` is short-lived
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this code is also removed upstream in upcoming revisions, fyi

@ARR4N ARR4N marked this pull request as ready for review October 1, 2024 19:14
@ARR4N
Copy link
Collaborator Author

ARR4N commented Oct 2, 2024

@darioush I added the pseudo.Type.Format() method, reverted the upstream changes from %+v to %#x, and resolved your comment on them.

@ARR4N ARR4N merged commit f0ae9c5 into libevm Oct 2, 2024
3 checks passed
@ARR4N ARR4N deleted the arr4n/state-account-extra-payload branch October 2, 2024 15:00
ARR4N added a commit that referenced this pull request Dec 17, 2024
## Why this should be merged

The `types.Header` fields of both
[`coreth`](https://pkg.go.dev/github.com/ava-labs/coreth/core/types#Header)
and
[`subnet-evm`](https://pkg.go.dev/github.com/ava-labs/subnet-evm/core/types#Header)
have been modified such that their RLP encodings (i.e. block hashes)
aren't compatible with vanilla `geth` nor each other. This PR adds
support for arbitrary RLP encoding coupled with type-safe extra
payloads.

## How this works

Equivalent to #1 (`params`) and #44 (`types.StateAccount`) registration
of pseudo-generic payloads. The only major difference is the guarantee
of a non-nil payload pointer, which means that the payload hooks are
never called on nil pointers as this would make it difficult to decode
RLP into them.

## How this was tested

Round-trip RLP {en,de}coding via a registered stub hook.

---------

Signed-off-by: Arran Schlosberg <[email protected]>
Co-authored-by: Quentin McGaw <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants