mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 20:50:05 +00:00
eb77f56d8a
* add tests and check * lint * Merge refs/heads/master into sortBlocks
40 lines
984 B
Go
40 lines
984 B
Go
package sync
|
|
|
|
import (
|
|
"sort"
|
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
)
|
|
|
|
// A type to represent beacon blocks and roots which have methods
|
|
// which satisfy the Interface in `Sort` so that this type can
|
|
// be sorted in ascending order.
|
|
type sortedObj struct {
|
|
blks []*ethpb.SignedBeaconBlock
|
|
roots [][32]byte
|
|
}
|
|
|
|
func (s sortedObj) Less(i, j int) bool {
|
|
return s.blks[i].Block.Slot < s.blks[j].Block.Slot
|
|
}
|
|
|
|
func (s sortedObj) Swap(i, j int) {
|
|
s.blks[i], s.blks[j] = s.blks[j], s.blks[i]
|
|
s.roots[i], s.roots[j] = s.roots[j], s.roots[i]
|
|
}
|
|
|
|
func (s sortedObj) Len() int {
|
|
return len(s.blks)
|
|
}
|
|
|
|
// sort the provided blocks and roots in ascending order. This method assumes that the size of
|
|
// block slice and root slice is equal.
|
|
func (r *Service) sortBlocksAndRoots(blks []*ethpb.SignedBeaconBlock, roots [][32]byte) ([]*ethpb.SignedBeaconBlock, [][32]byte) {
|
|
obj := sortedObj{
|
|
blks: blks,
|
|
roots: roots,
|
|
}
|
|
sort.Sort(obj)
|
|
return obj.blks, obj.roots
|
|
}
|