mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-09 15:37:56 -05:00
* Ran gopls modernize to fix everything go run golang.org/x/tools/gopls/internal/analysis/modernize/cmd/modernize@latest -fix -test ./... * Override rules_go provided dependency for golang.org/x/tools to v0.38.0. To update this, checked out rules_go, then ran `bazel run //go/tools/releaser -- upgrade-dep -mirror=false org_golang_x_tools` and copied the patches. * Fix buildtag violations and ignore buildtag violations in external * Introduce modernize analyzer package. * Add modernize "any" analyzer. * Fix violations of any analyzer * Add modernize "appendclipped" analyzer. * Fix violations of appendclipped * Add modernize "bloop" analyzer. * Add modernize "fmtappendf" analyzer. * Add modernize "forvar" analyzer. * Add modernize "mapsloop" analyzer. * Add modernize "minmax" analyzer. * Fix violations of minmax analyzer * Add modernize "omitzero" analyzer. * Add modernize "rangeint" analyzer. * Fix violations of rangeint. * Add modernize "reflecttypefor" analyzer. * Fix violations of reflecttypefor analyzer. * Add modernize "slicescontains" analyzer. * Add modernize "slicessort" analyzer. * Add modernize "slicesdelete" analyzer. This is disabled by default for now. See https://go.dev/issue/73686. * Add modernize "stringscutprefix" analyzer. * Add modernize "stringsbuilder" analyzer. * Fix violations of stringsbuilder analyzer. * Add modernize "stringsseq" analyzer. * Add modernize "testingcontext" analyzer. * Add modernize "waitgroup" analyzer. * Changelog fragment * gofmt * gazelle * Add modernize "newexpr" analyzer. * Disable newexpr until go1.26 * Add more details in WORKSPACE on how to update the override * @nalepae feedback on min() * gofmt * Fix violations of forvar
40 lines
1.1 KiB
Go
40 lines
1.1 KiB
Go
package ssz
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/binary"
|
|
"fmt"
|
|
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
// SliceRoot computes the root of a slice of hashable objects.
|
|
func SliceRoot[T Hashable](slice []T, limit uint64) ([32]byte, error) {
|
|
max := limit
|
|
if uint64(len(slice)) > max {
|
|
return [32]byte{}, fmt.Errorf("slice exceeds max length %d", max)
|
|
}
|
|
|
|
roots := make([][32]byte, len(slice))
|
|
for i := range slice {
|
|
r, err := slice[i].HashTreeRoot()
|
|
if err != nil {
|
|
return [32]byte{}, errors.Wrap(err, "could not merkleize object")
|
|
}
|
|
roots[i] = r
|
|
}
|
|
|
|
sliceRoot, err := BitwiseMerkleize(roots, uint64(len(roots)), limit)
|
|
if err != nil {
|
|
return [32]byte{}, errors.Wrap(err, "could not slice merkleization")
|
|
}
|
|
sliceLenBuf := new(bytes.Buffer)
|
|
if err := binary.Write(sliceLenBuf, binary.LittleEndian, uint64(len(slice))); err != nil {
|
|
return [32]byte{}, errors.Wrap(err, "could not marshal slice length")
|
|
}
|
|
// We need to mix in the length of the slice.
|
|
sliceLenRoot := make([]byte, 32)
|
|
copy(sliceLenRoot, sliceLenBuf.Bytes())
|
|
return MixInLength(sliceRoot, sliceLenRoot), nil
|
|
}
|