move basic_account to types module
This commit is contained in:
parent
7c715aeec3
commit
eb2b1ad5da
@ -20,46 +20,12 @@ use util::*;
|
|||||||
use pod_account::*;
|
use pod_account::*;
|
||||||
use rlp::*;
|
use rlp::*;
|
||||||
use lru_cache::LruCache;
|
use lru_cache::LruCache;
|
||||||
|
use basic_account::BasicAccount;
|
||||||
|
|
||||||
use std::cell::{RefCell, Cell};
|
use std::cell::{RefCell, Cell};
|
||||||
|
|
||||||
const STORAGE_CACHE_ITEMS: usize = 8192;
|
const STORAGE_CACHE_ITEMS: usize = 8192;
|
||||||
|
|
||||||
/// Basic account type.
|
|
||||||
#[derive(Debug, Clone, PartialEq, Eq)]
|
|
||||||
pub struct BasicAccount {
|
|
||||||
/// Nonce of the account.
|
|
||||||
pub nonce: U256,
|
|
||||||
/// Balance of the account.
|
|
||||||
pub balance: U256,
|
|
||||||
/// Storage root of the account.
|
|
||||||
pub storage_root: H256,
|
|
||||||
/// Code hash of the account.
|
|
||||||
pub code_hash: H256,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Encodable for BasicAccount {
|
|
||||||
fn rlp_append(&self, s: &mut RlpStream) {
|
|
||||||
s.begin_list(4)
|
|
||||||
.append(&self.nonce)
|
|
||||||
.append(&self.balance)
|
|
||||||
.append(&self.storage_root)
|
|
||||||
.append(&self.code_hash);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Decodable for BasicAccount {
|
|
||||||
fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
|
|
||||||
let rlp = decoder.as_rlp();
|
|
||||||
Ok(BasicAccount {
|
|
||||||
nonce: rlp.val_at(0)?,
|
|
||||||
balance: rlp.val_at(1)?,
|
|
||||||
storage_root: rlp.val_at(2)?,
|
|
||||||
code_hash: rlp.val_at(3)?,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Single account in the system.
|
/// Single account in the system.
|
||||||
/// Keeps track of changes to the code and storage.
|
/// Keeps track of changes to the code and storage.
|
||||||
/// The changes are applied in `commit_storage` and `commit_code`
|
/// The changes are applied in `commit_storage` and `commit_code`
|
||||||
|
@ -37,7 +37,7 @@ use util::trie::recorder::{Recorder, BasicRecorder as TrieRecorder};
|
|||||||
mod account;
|
mod account;
|
||||||
mod substate;
|
mod substate;
|
||||||
|
|
||||||
pub use self::account::{BasicAccount, Account};
|
pub use self::account::Account;
|
||||||
pub use self::substate::Substate;
|
pub use self::substate::Substate;
|
||||||
|
|
||||||
/// Used to return information about an `State::apply` operation.
|
/// Used to return information about an `State::apply` operation.
|
||||||
|
55
ethcore/src/types/basic_account.rs
Normal file
55
ethcore/src/types/basic_account.rs
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
// Copyright 2015, 2016 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 <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
//! Basic account type -- the decoded RLP from the state trie.
|
||||||
|
|
||||||
|
use rlp::*;
|
||||||
|
use util::{U256, H256};
|
||||||
|
|
||||||
|
/// Basic account type.
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq)]
|
||||||
|
pub struct BasicAccount {
|
||||||
|
/// Nonce of the account.
|
||||||
|
pub nonce: U256,
|
||||||
|
/// Balance of the account.
|
||||||
|
pub balance: U256,
|
||||||
|
/// Storage root of the account.
|
||||||
|
pub storage_root: H256,
|
||||||
|
/// Code hash of the account.
|
||||||
|
pub code_hash: H256,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Encodable for BasicAccount {
|
||||||
|
fn rlp_append(&self, s: &mut RlpStream) {
|
||||||
|
s.begin_list(4)
|
||||||
|
.append(&self.nonce)
|
||||||
|
.append(&self.balance)
|
||||||
|
.append(&self.storage_root)
|
||||||
|
.append(&self.code_hash);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Decodable for BasicAccount {
|
||||||
|
fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
|
||||||
|
let rlp = decoder.as_rlp();
|
||||||
|
Ok(BasicAccount {
|
||||||
|
nonce: rlp.val_at(0)?,
|
||||||
|
balance: rlp.val_at(1)?,
|
||||||
|
storage_root: rlp.val_at(2)?,
|
||||||
|
code_hash: rlp.val_at(3)?,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
@ -37,3 +37,4 @@ pub mod mode;
|
|||||||
pub mod pruning_info;
|
pub mod pruning_info;
|
||||||
pub mod security_level;
|
pub mod security_level;
|
||||||
pub mod encoded;
|
pub mod encoded;
|
||||||
|
pub mod basic_account;
|
||||||
|
Loading…
Reference in New Issue
Block a user