6a9de9b11e
* Add client-traits crate Move the BlockInfo trait to new crate * New crate `machine` Contains code extracted from ethcore that defines `Machine`, `Externalities` and other execution related code. * Use new machine and client-traits crates in ethcore * Use new crates machine and client-traits instead of ethcore where appropriate * Fix tests * Don't re-export so many types from ethcore::client * Fixing more fallout from removing re-export * fix test * More fallout from not re-exporting types * Add some docs * cleanup * import the macro edition style * Tweak docs * Add missing import * remove unused ethabi_derive imports * Use latest ethabi-contract * Move many traits from ethcore/client/traits to client-traits crate Initial version of extracted Engine trait * Move snapshot related traits to the engine crate (eew) * Move a few snapshot related types to common_types Cleanup Executed as exported from machine crate * fix warning * Gradually introduce new engine crate: snapshot * ethcore typechecks with new engine crate * Sort out types outside ethcore * Add an EpochVerifier to ethash and use that in Engine.epoch_verifier() Cleanup * Document pub members * Sort out tests Sort out default impls for EpochVerifier * Add test-helpers feature and move EngineSigner impl to the right place * Sort out tests * Sort out tests and refactor verification types * Fix missing traits * More missing traits Fix Histogram * Fix tests and cleanup * cleanup * Put back needed logger import * Don't rexport common_types from ethcore/src/client Don't export ethcore::client::* * Remove files no longer used Use types from the engine crate Explicit exports from engine::engine * Get rid of itertools * Move a few more traits from ethcore to client-traits: BlockChainReset, ScheduleInfo, StateClient * Move ProvingBlockChainClient to client-traits * Don't re-export ForkChoice and Transition from ethcore * Address grumbles: sort imports, remove commented out code * Fix merge resolution error * merge failure
147 lines
4.3 KiB
Rust
147 lines
4.3 KiB
Rust
// Copyright 2015-2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity Ethereum.
|
|
|
|
// Parity Ethereum is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Parity Ethereum is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Parity Ethereum. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use std::str::FromStr;
|
|
|
|
use verification::{VerifierType, QueueConfig};
|
|
use journaldb;
|
|
use snapshot::SnapshotConfiguration;
|
|
use types::client_types::Mode;
|
|
|
|
pub use std::time::Duration;
|
|
pub use blockchain::Config as BlockChainConfig;
|
|
pub use trace::Config as TraceConfig;
|
|
pub use evm::VMType;
|
|
|
|
/// Client state db compaction profile
|
|
#[derive(Debug, PartialEq, Clone)]
|
|
pub enum DatabaseCompactionProfile {
|
|
/// Try to determine compaction profile automatically
|
|
Auto,
|
|
/// SSD compaction profile
|
|
SSD,
|
|
/// HDD or other slow storage io compaction profile
|
|
HDD,
|
|
}
|
|
|
|
impl Default for DatabaseCompactionProfile {
|
|
fn default() -> Self {
|
|
DatabaseCompactionProfile::Auto
|
|
}
|
|
}
|
|
|
|
impl FromStr for DatabaseCompactionProfile {
|
|
type Err = String;
|
|
|
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
|
match s {
|
|
"auto" => Ok(DatabaseCompactionProfile::Auto),
|
|
"ssd" => Ok(DatabaseCompactionProfile::SSD),
|
|
"hdd" => Ok(DatabaseCompactionProfile::HDD),
|
|
_ => Err("Invalid compaction profile given. Expected default/hdd/ssd.".into()),
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Client configuration. Includes configs for all sub-systems.
|
|
#[derive(Debug, PartialEq, Clone)]
|
|
pub struct ClientConfig {
|
|
/// Block queue configuration.
|
|
pub queue: QueueConfig,
|
|
/// Blockchain configuration.
|
|
pub blockchain: BlockChainConfig,
|
|
/// Trace configuration.
|
|
pub tracing: TraceConfig,
|
|
/// VM type.
|
|
pub vm_type: VMType,
|
|
/// Fat DB enabled?
|
|
pub fat_db: bool,
|
|
/// The JournalDB ("pruning") algorithm to use.
|
|
pub pruning: journaldb::Algorithm,
|
|
/// The name of the client instance.
|
|
pub name: String,
|
|
/// RocksDB column cache-size if not default
|
|
pub db_cache_size: Option<usize>,
|
|
/// State db compaction profile
|
|
pub db_compaction: DatabaseCompactionProfile,
|
|
/// Operating mode
|
|
pub mode: Mode,
|
|
/// The chain spec name
|
|
pub spec_name: String,
|
|
/// Type of block verifier used by client.
|
|
pub verifier_type: VerifierType,
|
|
/// State db cache-size.
|
|
pub state_cache_size: usize,
|
|
/// EVM jump-tables cache size.
|
|
pub jump_table_size: usize,
|
|
/// Minimum state pruning history size.
|
|
pub history: u64,
|
|
/// Ideal memory usage for state pruning history.
|
|
pub history_mem: usize,
|
|
/// Check seal valididity on block import
|
|
pub check_seal: bool,
|
|
/// Maximal number of transactions queued for verification in a separate thread.
|
|
pub transaction_verification_queue_size: usize,
|
|
/// Maximal number of blocks to import at each round.
|
|
pub max_round_blocks_to_import: usize,
|
|
/// Snapshot configuration
|
|
pub snapshot: SnapshotConfiguration,
|
|
}
|
|
|
|
impl Default for ClientConfig {
|
|
fn default() -> Self {
|
|
let mb = 1024 * 1024;
|
|
ClientConfig {
|
|
queue: Default::default(),
|
|
blockchain: Default::default(),
|
|
tracing: Default::default(),
|
|
vm_type: Default::default(),
|
|
fat_db: false,
|
|
pruning: journaldb::Algorithm::OverlayRecent,
|
|
name: "default".into(),
|
|
db_cache_size: None,
|
|
db_compaction: Default::default(),
|
|
mode: Mode::Active,
|
|
spec_name: "".into(),
|
|
verifier_type: VerifierType::Canon,
|
|
state_cache_size: 1 * mb,
|
|
jump_table_size: 1 * mb,
|
|
history: 64,
|
|
history_mem: 32 * mb,
|
|
check_seal: true,
|
|
transaction_verification_queue_size: 8192,
|
|
max_round_blocks_to_import: 12,
|
|
snapshot: Default::default(),
|
|
}
|
|
}
|
|
}
|
|
#[cfg(test)]
|
|
mod test {
|
|
use super::DatabaseCompactionProfile;
|
|
|
|
#[test]
|
|
fn test_default_compaction_profile() {
|
|
assert_eq!(DatabaseCompactionProfile::default(), DatabaseCompactionProfile::Auto);
|
|
}
|
|
|
|
#[test]
|
|
fn test_parsing_compaction_profile() {
|
|
assert_eq!(DatabaseCompactionProfile::Auto, "auto".parse().unwrap());
|
|
assert_eq!(DatabaseCompactionProfile::SSD, "ssd".parse().unwrap());
|
|
assert_eq!(DatabaseCompactionProfile::HDD, "hdd".parse().unwrap());
|
|
}
|
|
}
|