// 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 . use std::collections::HashMap; use common_types::{encoded::Block, engines::ForkChoice, BlockNumber}; use ethcore_db::keys::{BlockDetails, BlockReceipts, TransactionAddress}; use ethereum_types::{Bloom, H256}; use crate::block_info::BlockInfo; /// Block extras update info. pub struct ExtrasUpdate { /// Block info. pub info: BlockInfo, /// Current block uncompressed rlp bytes pub block: Block, /// Modified block hashes. pub block_hashes: HashMap, /// Modified block details. pub block_details: HashMap, /// Modified block receipts. pub block_receipts: HashMap, /// Modified blocks blooms. pub blocks_blooms: Option<(u64, Vec)>, /// Modified transaction addresses (None signifies removed transactions). pub transactions_addresses: HashMap>, } /// Extra information in block insertion. pub struct ExtrasInsert { /// The primitive fork choice before applying finalization rules. pub fork_choice: ForkChoice, /// Is the inserted block considered finalized. pub is_finalized: bool, }