go-ethereum/libevm/pseudo/fmt.go
Arran Schlosberg f0ae9c50eb
feat: types.StateAccount pseudo-generic payload (#44)
Some of the changes in the full commit history were merged into `libevm` as part of #43 in `336a289` and then merged back into this branch as `5b15698`. 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()`

* fix: remove unnecessary `StateAccountExtra.clone()`

* refactor: readability

* feat: `pseudo.Type.Format()` implements `fmt.Formatter`
2024-10-02 16:00:13 +01:00

56 lines
1.7 KiB
Go

// Copyright 2024 the libevm authors.
//
// The libevm additions to go-ethereum are free software: you can redistribute
// them and/or modify them under the terms of the GNU Lesser General Public License
// as published by the Free Software Foundation, either version 3 of the License,
// or (at your option) any later version.
//
// The libevm additions are distributed in the hope that they will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
// General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the go-ethereum library. If not, see
// <http://www.gnu.org/licenses/>.
package pseudo
import (
"fmt"
)
var _ = []fmt.Formatter{
(*Type)(nil),
(*Value[struct{}])(nil),
(*concrete[struct{}])(nil),
}
// Format implements the [fmt.Formatter] interface.
func (t *Type) Format(s fmt.State, verb rune) {
switch {
case t == nil, t.val == nil:
writeToFmtState(s, "<nil>[pseudo.Type[unknown]]")
default:
t.val.Format(s, verb)
}
}
// Format implements the [fmt.Formatter] interface.
func (v *Value[T]) Format(s fmt.State, verb rune) { v.t.Format(s, verb) }
func (c *concrete[T]) Format(s fmt.State, verb rune) {
switch {
case c == nil:
writeToFmtState(s, "<nil>[pseudo.Type[%T]]", concrete[T]{}.val)
default:
// Respects the original formatting directive. fmt all the way down!
format := fmt.Sprintf("pseudo.Type[%%T]{%s}", fmt.FormatString(s, verb))
writeToFmtState(s, format, c.val, c.val)
}
}
func writeToFmtState(s fmt.State, format string, a ...any) {
// There is no way to bubble errors out from a `fmt.Formatter`.
_, _ = s.Write([]byte(fmt.Sprintf(format, a...)))
}