2023-09-25 16:36:43 +00:00
|
|
|
package doublylinkedtree
|
|
|
|
|
|
|
|
import (
|
2024-02-15 05:46:47 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/primitives"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/time/slots"
|
2023-09-25 16:36:43 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// LastRoot returns the last canonical block root in the given epoch
|
|
|
|
func (f *ForkChoice) LastRoot(epoch primitives.Epoch) [32]byte {
|
|
|
|
head := f.store.headNode
|
|
|
|
headEpoch := slots.ToEpoch(head.slot)
|
|
|
|
epochEnd, err := slots.EpochEnd(epoch)
|
|
|
|
if err != nil {
|
|
|
|
return [32]byte{}
|
|
|
|
}
|
2023-10-03 02:22:52 +00:00
|
|
|
if headEpoch <= epoch {
|
2023-09-25 16:36:43 +00:00
|
|
|
return head.root
|
|
|
|
}
|
|
|
|
for head != nil && head.slot > epochEnd {
|
|
|
|
head = head.parent
|
|
|
|
}
|
|
|
|
if head == nil {
|
|
|
|
return [32]byte{}
|
|
|
|
}
|
|
|
|
return head.root
|
|
|
|
}
|