mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-06 18:21:45 +00:00
Added Execution Payload from Rayonism Fork Updated new Containers to match Merge Spec Updated BeaconBlockBody for Merge Spec Completed updating BeaconState and BeaconBlockBody Modified ExecutionPayload<T> to use Transaction<T> Mostly Finished Changes for beacon-chain.md Added some things for fork-choice.md Update to match new fork-choice.md/fork.md changes ran cargo fmt Added Missing Pieces in eth2_libp2p for Merge fix ef test Various Changes to Conform Closer to Merge Spec
83 lines
2.5 KiB
Rust
83 lines
2.5 KiB
Rust
use crate::cases::LoadCase;
|
|
use crate::decode::yaml_decode_file;
|
|
use crate::error::Error;
|
|
use serde_derive::Deserialize;
|
|
use ssz::Encode;
|
|
use ssz_derive::{Decode, Encode};
|
|
use std::convert::TryFrom;
|
|
use std::fmt::Debug;
|
|
use std::path::Path;
|
|
use tree_hash::TreeHash;
|
|
use types::ForkName;
|
|
|
|
/// Trait for all BLS cases to eliminate some boilerplate.
|
|
pub trait BlsCase: serde::de::DeserializeOwned {}
|
|
|
|
impl<T: BlsCase> LoadCase for T {
|
|
fn load_from_dir(path: &Path, _fork_name: ForkName) -> Result<Self, Error> {
|
|
yaml_decode_file(&path.join("data.yaml"))
|
|
}
|
|
}
|
|
|
|
/// Macro to wrap U128 and U256 so they deserialize correctly.
|
|
macro_rules! uint_wrapper {
|
|
($wrapper_name:ident, $wrapped_type:ty) => {
|
|
#[derive(Debug, Clone, Copy, Default, PartialEq, Decode, Encode, Deserialize)]
|
|
#[serde(try_from = "String")]
|
|
pub struct $wrapper_name {
|
|
pub x: $wrapped_type,
|
|
}
|
|
|
|
impl TryFrom<String> for $wrapper_name {
|
|
type Error = String;
|
|
|
|
fn try_from(s: String) -> Result<Self, Self::Error> {
|
|
<$wrapped_type>::from_dec_str(&s)
|
|
.map(|x| Self { x })
|
|
.map_err(|e| format!("{:?}", e))
|
|
}
|
|
}
|
|
|
|
impl tree_hash::TreeHash for $wrapper_name {
|
|
fn tree_hash_type() -> tree_hash::TreeHashType {
|
|
<$wrapped_type>::tree_hash_type()
|
|
}
|
|
|
|
fn tree_hash_packed_encoding(&self) -> Vec<u8> {
|
|
self.x.tree_hash_packed_encoding()
|
|
}
|
|
|
|
fn tree_hash_packing_factor() -> usize {
|
|
<$wrapped_type>::tree_hash_packing_factor()
|
|
}
|
|
|
|
fn tree_hash_root(&self) -> tree_hash::Hash256 {
|
|
self.x.tree_hash_root()
|
|
}
|
|
}
|
|
};
|
|
}
|
|
|
|
uint_wrapper!(TestU128, ethereum_types::U128);
|
|
uint_wrapper!(TestU256, ethereum_types::U256);
|
|
|
|
/// Trait for types that can be used in SSZ static tests.
|
|
pub trait SszStaticType:
|
|
serde::de::DeserializeOwned + Encode + TreeHash + Clone + PartialEq + Debug + Sync
|
|
{
|
|
}
|
|
|
|
impl<T> SszStaticType for T where
|
|
T: serde::de::DeserializeOwned + Encode + TreeHash + Clone + PartialEq + Debug + Sync
|
|
{
|
|
}
|
|
|
|
/// Return the fork immediately prior to a fork.
|
|
pub fn previous_fork(fork_name: ForkName) -> ForkName {
|
|
match fork_name {
|
|
ForkName::Base => ForkName::Base,
|
|
ForkName::Altair => ForkName::Base,
|
|
ForkName::Merge => ForkName::Altair, // TODO: Check this when tests are released..
|
|
}
|
|
}
|