mirror of
https://github.com/paradigmxyz/reth.git
synced 2026-02-04 03:55:22 -05:00
57 lines
1.7 KiB
Rust
57 lines
1.7 KiB
Rust
#![cfg_attr(docsrs, feature(doc_cfg))]
|
|
#![doc(
|
|
html_logo_url = "https://raw.githubusercontent.com/paradigmxyz/reth/main/assets/reth-docs.png",
|
|
html_favicon_url = "https://avatars0.githubusercontent.com/u/97369466?s=256",
|
|
issue_tracker_base_url = "https://github.com/paradigmxzy/reth/issues/"
|
|
)]
|
|
#![warn(missing_docs, unreachable_pub)]
|
|
#![deny(unused_must_use, rust_2018_idioms)]
|
|
#![doc(test(
|
|
no_crate_inject,
|
|
attr(deny(warnings, rust_2018_idioms), allow(dead_code, unused_variables))
|
|
))]
|
|
//! Implementation of a tree-like structure for blockchains.
|
|
//!
|
|
//! The [BlockchainTree] can validate, execute, and revert blocks in multiple competing sidechains.
|
|
//! This structure is used for Reth's sync mode at the tip instead of the pipeline, and is the
|
|
//! primary executor and validator of payloads sent from the consensus layer.
|
|
//!
|
|
//! Blocks and their resulting state transitions are kept in-memory until they are persisted.
|
|
//!
|
|
//! ## Feature Flags
|
|
//!
|
|
//! - `test-utils`: Export utilities for testing
|
|
|
|
/// Execution result types.
|
|
pub use reth_provider::post_state;
|
|
|
|
pub mod blockchain_tree;
|
|
pub use blockchain_tree::{BlockHashes, BlockchainTree};
|
|
|
|
pub mod block_indices;
|
|
pub use block_indices::BlockIndices;
|
|
|
|
pub mod chain;
|
|
pub use chain::AppendableChain;
|
|
|
|
pub mod config;
|
|
pub use config::BlockchainTreeConfig;
|
|
|
|
pub mod externals;
|
|
pub use externals::TreeExternals;
|
|
|
|
pub mod shareable;
|
|
pub use shareable::ShareableBlockchainTree;
|
|
|
|
pub mod post_state_data;
|
|
pub use post_state_data::{PostStateData, PostStateDataRef};
|
|
|
|
/// Buffer of not executed blocks.
|
|
pub mod block_buffer;
|
|
mod canonical_chain;
|
|
|
|
/// Common blockchain tree metrics.
|
|
pub mod metrics;
|
|
|
|
pub use block_buffer::BlockBuffer;
|