// Copyright 2015-2018 Parity Technologies (UK) Ltd. // This file is part of Parity. // Parity 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 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. If not, see . use std::collections::HashMap; use ethereum_types::{H256, Bloom}; use header::BlockNumber; use blockchain::block_info::BlockInfo; use blockchain::extras::{BlockDetails, BlockReceipts, TransactionAddress}; use encoded::Block; /// 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: ::engines::ForkChoice, /// Is the inserted block considered finalized. pub is_finalized: bool, }