Merge branch 'broken' into state
This commit is contained in:
commit
6ca78f8577
@ -11,6 +11,7 @@ log = "0.3"
|
|||||||
env_logger = "0.3"
|
env_logger = "0.3"
|
||||||
ethcore-util = "0.1.0"
|
ethcore-util = "0.1.0"
|
||||||
evmjit = { path = "rust-evmjit", optional = true }
|
evmjit = { path = "rust-evmjit", optional = true }
|
||||||
|
rustc-serialize = "0.3"
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
jit = ["evmjit"]
|
jit = ["evmjit"]
|
||||||
|
@ -96,7 +96,7 @@ impl Account {
|
|||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
// fetch - cannot be done in match because of the borrow rules.
|
// fetch - cannot be done in match because of the borrow rules.
|
||||||
let t = TrieDBMut::new_existing(db, &mut self.storage_root);
|
let t = TrieDB::new(db, &self.storage_root);
|
||||||
let r = H256::from_slice(t.get(key.bytes()).unwrap_or(&[0u8;32][..]));
|
let r = H256::from_slice(t.get(key.bytes()).unwrap_or(&[0u8;32][..]));
|
||||||
self.storage_overlay.insert(key, r.clone());
|
self.storage_overlay.insert(key, r.clone());
|
||||||
r
|
r
|
||||||
@ -286,6 +286,8 @@ fn rlpio() {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn new_account() {
|
fn new_account() {
|
||||||
|
use rustc_serialize::hex::ToHex;
|
||||||
|
|
||||||
let a = Account::new(U256::from(69u8), U256::from(0u8), HashMap::new(), Bytes::new());
|
let a = Account::new(U256::from(69u8), U256::from(0u8), HashMap::new(), Bytes::new());
|
||||||
assert_eq!(a.rlp().to_hex(), "f8448045a056e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421a0c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470");
|
assert_eq!(a.rlp().to_hex(), "f8448045a056e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421a0c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470");
|
||||||
assert_eq!(a.balance(), &U256::from(69u8));
|
assert_eq!(a.balance(), &U256::from(69u8));
|
||||||
@ -296,6 +298,8 @@ fn new_account() {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn create_account() {
|
fn create_account() {
|
||||||
|
use rustc_serialize::hex::ToHex;
|
||||||
|
|
||||||
let a = Account::new(U256::from(69u8), U256::from(0u8), HashMap::new(), Bytes::new());
|
let a = Account::new(U256::from(69u8), U256::from(0u8), HashMap::new(), Bytes::new());
|
||||||
assert_eq!(a.rlp().to_hex(), "f8448045a056e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421a0c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470");
|
assert_eq!(a.rlp().to_hex(), "f8448045a056e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421a0c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470");
|
||||||
}
|
}
|
||||||
|
@ -56,8 +56,9 @@ impl Header {
|
|||||||
|
|
||||||
impl Decodable for Header {
|
impl Decodable for Header {
|
||||||
fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
|
fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
|
||||||
decoder.read_list(| d | {
|
let d = try!(decoder.as_list());
|
||||||
let blockheader = Header {
|
|
||||||
|
let mut blockheader = Header {
|
||||||
parent_hash: try!(Decodable::decode(&d[0])),
|
parent_hash: try!(Decodable::decode(&d[0])),
|
||||||
uncles_hash: try!(Decodable::decode(&d[1])),
|
uncles_hash: try!(Decodable::decode(&d[1])),
|
||||||
author: try!(Decodable::decode(&d[2])),
|
author: try!(Decodable::decode(&d[2])),
|
||||||
@ -73,9 +74,12 @@ impl Decodable for Header {
|
|||||||
extra_data: try!(Decodable::decode(&d[12])),
|
extra_data: try!(Decodable::decode(&d[12])),
|
||||||
seal: vec![],
|
seal: vec![],
|
||||||
};
|
};
|
||||||
// TODO: fill blockheader.seal with (raw) list items index 12..)
|
|
||||||
|
for i in 13..d.len() {
|
||||||
|
blockheader.seal.push(try!(Decodable::decode(&d[i])));
|
||||||
|
}
|
||||||
|
|
||||||
Ok(blockheader)
|
Ok(blockheader)
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,7 +99,10 @@ impl Encodable for Header {
|
|||||||
self.gas_used.encode(e);
|
self.gas_used.encode(e);
|
||||||
self.timestamp.encode(e);
|
self.timestamp.encode(e);
|
||||||
self.extra_data.encode(e);
|
self.extra_data.encode(e);
|
||||||
// TODO: emit raw seal items.
|
|
||||||
|
for b in self.seal.iter() {
|
||||||
|
b.encode(e);
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -72,6 +72,7 @@
|
|||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate log;
|
extern crate log;
|
||||||
extern crate env_logger;
|
extern crate env_logger;
|
||||||
|
extern crate rustc_serialize;
|
||||||
#[cfg(feature = "jit" )]
|
#[cfg(feature = "jit" )]
|
||||||
extern crate evmjit;
|
extern crate evmjit;
|
||||||
extern crate ethcore_util as util;
|
extern crate ethcore_util as util;
|
||||||
|
@ -61,7 +61,7 @@ impl State {
|
|||||||
pub fn new_existing(mut db: OverlayDB, mut root: H256, account_start_nonce: U256) -> State {
|
pub fn new_existing(mut db: OverlayDB, mut root: H256, account_start_nonce: U256) -> State {
|
||||||
{
|
{
|
||||||
// trie should panic! if root does not exist
|
// trie should panic! if root does not exist
|
||||||
let _ = TrieDBMut::new_existing(&mut db, &mut root);
|
let _ = TrieDB::new(&mut db, &mut root);
|
||||||
}
|
}
|
||||||
|
|
||||||
State {
|
State {
|
||||||
@ -164,8 +164,7 @@ impl State {
|
|||||||
fn get(&mut self, a: &Address, require_code: bool) -> Option<&Account> {
|
fn get(&mut self, a: &Address, require_code: bool) -> Option<&Account> {
|
||||||
if self.cache.get(a).is_none() {
|
if self.cache.get(a).is_none() {
|
||||||
// load from trie.
|
// load from trie.
|
||||||
let t = TrieDBMut::new_existing(&mut self.db, &mut self.root);
|
self.cache.insert(a.clone(), TrieDB::new(&self.db, &self.root).get(&a).map(|rlp| Account::from_rlp(rlp)));
|
||||||
self.cache.insert(a.clone(), t.get(&a).map(|rlp| { println!("RLP: {:?}", rlp); Account::from_rlp(rlp) }));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let db = &self.db;
|
let db = &self.db;
|
||||||
@ -182,7 +181,7 @@ impl State {
|
|||||||
fn require(&mut self, a: &Address, require_code: bool) -> &mut Account {
|
fn require(&mut self, a: &Address, require_code: bool) -> &mut Account {
|
||||||
if self.cache.get(a).is_none() {
|
if self.cache.get(a).is_none() {
|
||||||
// load from trie.
|
// load from trie.
|
||||||
self.cache.insert(a.clone(), TrieDBMut::new(&mut self.db, &mut self.root).get(&a).map(|rlp| Account::from_rlp(rlp)));
|
self.cache.insert(a.clone(), TrieDB::new(&self.db, &self.root).get(&a).map(|rlp| Account::from_rlp(rlp)));
|
||||||
}
|
}
|
||||||
|
|
||||||
if self.cache.get(a).unwrap().is_none() {
|
if self.cache.get(a).unwrap().is_none() {
|
||||||
|
@ -37,7 +37,8 @@ impl Encodable for Transaction {
|
|||||||
|
|
||||||
impl Decodable for Transaction {
|
impl Decodable for Transaction {
|
||||||
fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
|
fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
|
||||||
decoder.read_list(| d | {
|
let d = try!(decoder.as_list());
|
||||||
|
|
||||||
let transaction = Transaction {
|
let transaction = Transaction {
|
||||||
nonce: try!(Decodable::decode(&d[0])),
|
nonce: try!(Decodable::decode(&d[0])),
|
||||||
gas_price: try!(Decodable::decode(&d[1])),
|
gas_price: try!(Decodable::decode(&d[1])),
|
||||||
@ -46,8 +47,8 @@ impl Decodable for Transaction {
|
|||||||
value: try!(Decodable::decode(&d[4])),
|
value: try!(Decodable::decode(&d[4])),
|
||||||
data: try!(Decodable::decode(&d[5])),
|
data: try!(Decodable::decode(&d[5])),
|
||||||
};
|
};
|
||||||
|
|
||||||
Ok(transaction)
|
Ok(transaction)
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user