error sorting out
This commit is contained in:
		
							parent
							
								
									2891b7b4ea
								
							
						
					
					
						commit
						3c061857c4
					
				| @ -61,7 +61,9 @@ use types::filter::Filter; | |||||||
| use log_entry::LocalizedLogEntry; | use log_entry::LocalizedLogEntry; | ||||||
| use block_queue::{BlockQueue, BlockQueueInfo}; | use block_queue::{BlockQueue, BlockQueueInfo}; | ||||||
| use blockchain::{BlockChain, BlockProvider, TreeRoute, ImportRoute}; | use blockchain::{BlockChain, BlockProvider, TreeRoute, ImportRoute}; | ||||||
| use client::{BlockID, TransactionID, UncleID, TraceId, ClientConfig, DatabaseCompactionProfile, BlockChainClient, MiningBlockChainClient, TraceFilter, CallAnalytics}; | use client::{BlockID, TransactionID, UncleID, TraceId, ClientConfig, | ||||||
|  | 	DatabaseCompactionProfile, BlockChainClient, MiningBlockChainClient, | ||||||
|  | 	TraceFilter, CallAnalytics, BlockImportError}; | ||||||
| use client::Error as ClientError; | use client::Error as ClientError; | ||||||
| use env_info::EnvInfo; | use env_info::EnvInfo; | ||||||
| use executive::{Executive, Executed, TransactOptions, contract_address}; | use executive::{Executive, Executed, TransactOptions, contract_address}; | ||||||
| @ -671,17 +673,17 @@ impl BlockChainClient for Client { | |||||||
| 		self.chain.block_receipts(hash).map(|receipts| rlp::encode(&receipts).to_vec()) | 		self.chain.block_receipts(hash).map(|receipts| rlp::encode(&receipts).to_vec()) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn import_block(&self, bytes: Bytes) -> ImportResult { | 	fn import_block(&self, bytes: Bytes) -> Result<H256, BlockImportError> { | ||||||
| 		{ | 		{ | ||||||
| 			let header = BlockView::new(&bytes).header_view(); | 			let header = BlockView::new(&bytes).header_view(); | ||||||
| 			if self.chain.is_known(&header.sha3()) { | 			if self.chain.is_known(&header.sha3()) { | ||||||
| 				return Err(ImportError::AlreadyInChain.into()); | 				return Err(BlockImportError::Import(ImportError::AlreadyInChain)); | ||||||
| 			} | 			} | ||||||
| 			if self.block_status(BlockID::Hash(header.parent_hash())) == BlockStatus::Unknown { | 			if self.block_status(BlockID::Hash(header.parent_hash())) == BlockStatus::Unknown { | ||||||
| 				return Err(BlockError::UnknownParent(header.parent_hash()).into()); | 				return Err(BlockImportError::Block(BlockError::UnknownParent(header.parent_hash())); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		self.block_queue.import_block(bytes) | 		Ok(try!(self.block_queue.import_block(bytes))) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn queue_info(&self) -> BlockQueueInfo { | 	fn queue_info(&self) -> BlockQueueInfo { | ||||||
|  | |||||||
| @ -49,17 +49,8 @@ use trace::LocalizedTrace; | |||||||
| use evm::Factory as EvmFactory; | use evm::Factory as EvmFactory; | ||||||
| use miner::{TransactionImportResult}; | use miner::{TransactionImportResult}; | ||||||
| use error::Error as EthError; | use error::Error as EthError; | ||||||
| 
 | pub use types::call_analytics::CallAnalytics; | ||||||
| /// Options concerning what analytics we run on the call.
 | pub use types::block_import_error::BlockImportError; | ||||||
| #[derive(Eq, PartialEq, Default, Clone, Copy, Debug)] |  | ||||||
| pub struct CallAnalytics { |  | ||||||
| 	/// Make a transaction trace.
 |  | ||||||
| 	pub transaction_tracing: bool, |  | ||||||
| 	/// Make a VM trace.
 |  | ||||||
| 	pub vm_tracing: bool, |  | ||||||
| 	/// Make a diff.
 |  | ||||||
| 	pub state_diffing: bool, |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| /// Blockchain database client. Owns and manages a blockchain and a block queue.
 | /// Blockchain database client. Owns and manages a blockchain and a block queue.
 | ||||||
| pub trait BlockChainClient : Sync + Send { | pub trait BlockChainClient : Sync + Send { | ||||||
| @ -145,7 +136,7 @@ pub trait BlockChainClient : Sync + Send { | |||||||
| 	fn block_receipts(&self, hash: &H256) -> Option<Bytes>; | 	fn block_receipts(&self, hash: &H256) -> Option<Bytes>; | ||||||
| 
 | 
 | ||||||
| 	/// Import a block into the blockchain.
 | 	/// Import a block into the blockchain.
 | ||||||
| 	fn import_block(&self, bytes: Bytes) -> ImportResult; | 	fn import_block(&self, bytes: Bytes) -> Result<H256, BlockImportError>; | ||||||
| 
 | 
 | ||||||
| 	/// Get block queue information.
 | 	/// Get block queue information.
 | ||||||
| 	fn queue_info(&self) -> BlockQueueInfo; | 	fn queue_info(&self) -> BlockQueueInfo; | ||||||
|  | |||||||
| @ -20,7 +20,8 @@ use std::sync::atomic::{AtomicUsize, Ordering as AtomicOrder}; | |||||||
| use util::*; | use util::*; | ||||||
| use transaction::{Transaction, LocalizedTransaction, SignedTransaction, Action}; | use transaction::{Transaction, LocalizedTransaction, SignedTransaction, Action}; | ||||||
| use blockchain::TreeRoute; | use blockchain::TreeRoute; | ||||||
| use client::{BlockChainClient, MiningBlockChainClient, BlockChainInfo, BlockStatus, BlockID, TransactionID, UncleID, TraceId, TraceFilter, LastHashes, CallAnalytics}; | use client::{BlockChainClient, MiningBlockChainClient, BlockChainInfo, BlockStatus, BlockID, | ||||||
|  | 	TransactionID, UncleID, TraceId, TraceFilter, LastHashes, CallAnalytics, BlockImportError}; | ||||||
| use header::{Header as BlockHeader, BlockNumber}; | use header::{Header as BlockHeader, BlockNumber}; | ||||||
| use filter::Filter; | use filter::Filter; | ||||||
| use log_entry::LocalizedLogEntry; | use log_entry::LocalizedLogEntry; | ||||||
| @ -398,7 +399,7 @@ impl BlockChainClient for TestBlockChainClient { | |||||||
| 		None | 		None | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn import_block(&self, b: Bytes) -> ImportResult { | 	fn import_block(&self, b: Bytes) -> Result<H256, BlockImportError> { | ||||||
| 		let header = Rlp::new(&b).val_at::<BlockHeader>(0); | 		let header = Rlp::new(&b).val_at::<BlockHeader>(0); | ||||||
| 		let h = header.hash(); | 		let h = header.hash(); | ||||||
| 		let number: usize = header.number as usize; | 		let number: usize = header.number as usize; | ||||||
|  | |||||||
| @ -20,6 +20,8 @@ use util::*; | |||||||
| use header::BlockNumber; | use header::BlockNumber; | ||||||
| use basic_types::LogBloom; | use basic_types::LogBloom; | ||||||
| use client::Error as ClientError; | use client::Error as ClientError; | ||||||
|  | use client::BlockImportError; | ||||||
|  | use ipc::binary::{BinaryConvertable, BinaryConvertError}; | ||||||
| 
 | 
 | ||||||
| pub use types::executed::ExecutionError; | pub use types::executed::ExecutionError; | ||||||
| 
 | 
 | ||||||
| @ -194,6 +196,9 @@ pub enum ImportError { | |||||||
| 	KnownBad, | 	KnownBad, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | binary_fixed_size!(BlockError); | ||||||
|  | binary_fixed_size!(ImportError); | ||||||
|  | 
 | ||||||
| impl fmt::Display for ImportError { | impl fmt::Display for ImportError { | ||||||
| 	fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { | 	fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { | ||||||
| 		let msg = match *self { | 		let msg = match *self { | ||||||
| @ -312,6 +317,16 @@ impl From<TrieError> for Error { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl From<BlockImportError> for Error { | ||||||
|  | 	fn from(err: BlockImportError) -> Error { | ||||||
|  | 		match err { | ||||||
|  | 			BlockImportError::Block(e) => Error::Block(e), | ||||||
|  | 			BlockImportError::Import(e) => Error::Import(e), | ||||||
|  | 			BlockImportError::Other(s) => Error::Util(UtilError::SimpleString(s)), | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // TODO: uncomment below once https://github.com/rust-lang/rust/issues/27336 sorted.
 | // TODO: uncomment below once https://github.com/rust-lang/rust/issues/27336 sorted.
 | ||||||
| /*#![feature(concat_idents)]
 | /*#![feature(concat_idents)]
 | ||||||
| macro_rules! assimilate { | macro_rules! assimilate { | ||||||
|  | |||||||
							
								
								
									
										38
									
								
								ethcore/src/types/block_import_error.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								ethcore/src/types/block_import_error.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (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 <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | use std::mem; | ||||||
|  | use ipc::binary::BinaryConvertError; | ||||||
|  | use std::collections::VecDeque; | ||||||
|  | use error::{ImportError, BlockError, Error}; | ||||||
|  | use std::convert::From; | ||||||
|  | 
 | ||||||
|  | #[derive(Binary, Debug)] | ||||||
|  | pub enum BlockImportError { | ||||||
|  | 	Import(ImportError), | ||||||
|  | 	Block(BlockError), | ||||||
|  | 	Other(String), | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl From<Error> for BlockImportError { | ||||||
|  | 	fn from(e: Error) -> Self { | ||||||
|  | 		match e { | ||||||
|  | 			Error::Block(block_error) => BlockImportError::Block(block_error), | ||||||
|  | 			Error::Import(import_error) => BlockImportError::Import(import_error), | ||||||
|  | 			_ => BlockImportError::Other(format!("other block import error: {:?}", e)), | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								ethcore/src/types/call_analytics.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								ethcore/src/types/call_analytics.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (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 <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | use std::mem; | ||||||
|  | use ipc::binary::{BinaryConvertError, BinaryConvertable}; | ||||||
|  | use std::collections::VecDeque; | ||||||
|  | 
 | ||||||
|  | /// Options concerning what analytics we run on the call.
 | ||||||
|  | #[derive(Eq, PartialEq, Default, Clone, Copy, Debug, Binary)] | ||||||
|  | pub struct CallAnalytics { | ||||||
|  | 	/// Make a transaction trace.
 | ||||||
|  | 	pub transaction_tracing: bool, | ||||||
|  | 	/// Make a VM trace.
 | ||||||
|  | 	pub vm_tracing: bool, | ||||||
|  | 	/// Make a diff.
 | ||||||
|  | 	pub state_diffing: bool, | ||||||
|  | } | ||||||
| @ -25,6 +25,7 @@ use std::mem; | |||||||
| use std::collections::VecDeque; | use std::collections::VecDeque; | ||||||
| 
 | 
 | ||||||
| /// Blockchain Filter.
 | /// Blockchain Filter.
 | ||||||
|  | #[derive(Binary)] | ||||||
| pub struct Filter { | pub struct Filter { | ||||||
| 	/// Blockchain will be searched from this block.
 | 	/// Blockchain will be searched from this block.
 | ||||||
| 	pub from_block: BlockID, | 	pub from_block: BlockID, | ||||||
|  | |||||||
| @ -29,3 +29,5 @@ pub mod block_queue_info; | |||||||
| pub mod transaction_import_result; | pub mod transaction_import_result; | ||||||
| pub mod filter; | pub mod filter; | ||||||
| pub mod trace_filter; | pub mod trace_filter; | ||||||
|  | pub mod call_analytics; | ||||||
|  | pub mod block_import_error; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user