77fdef4fb0
Conflicts: ethcore/src/receipt.rs
55 lines
2.0 KiB
Rust
55 lines
2.0 KiB
Rust
use util::*;
|
|
use basic_types::LogBloom;
|
|
use log_entry::LogEntry;
|
|
|
|
/// Information describing execution of a transaction.
|
|
#[derive(Default, Debug, Clone)]
|
|
pub struct Receipt {
|
|
/// TODO [Gav Wood] Please document me
|
|
pub state_root: H256,
|
|
/// TODO [Gav Wood] Please document me
|
|
pub gas_used: U256,
|
|
/// TODO [Gav Wood] Please document me
|
|
pub log_bloom: LogBloom,
|
|
/// TODO [Gav Wood] Please document me
|
|
pub logs: Vec<LogEntry>,
|
|
}
|
|
|
|
impl Receipt {
|
|
/// TODO [Gav Wood] Please document me
|
|
pub fn new(state_root: H256, gas_used: U256, logs: Vec<LogEntry>) -> Receipt {
|
|
Receipt {
|
|
state_root: state_root,
|
|
gas_used: gas_used,
|
|
log_bloom: logs.iter().fold(LogBloom::new(), |mut b, l| { b |= &l.bloom(); b }),
|
|
logs: logs,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Encodable for Receipt {
|
|
fn rlp_append(&self, s: &mut RlpStream) {
|
|
s.begin_list(4);
|
|
s.append(&self.state_root);
|
|
s.append(&self.gas_used);
|
|
s.append(&self.log_bloom);
|
|
s.append(&self.logs);
|
|
}
|
|
}
|
|
|
|
|
|
#[test]
|
|
fn test_basic() {
|
|
let expected = FromHex::from_hex("f90162a02f697d671e9ae4ee24a43c4b0d7e15f1cb4ba6de1561120d43b9a4e8c4a8a6ee83040caeb9010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000f838f794dcf421d093428b096ca501a7cd1a740855a7976fc0a00000000000000000000000000000000000000000000000000000000000000000").unwrap();
|
|
let r = Receipt::new(
|
|
x!("2f697d671e9ae4ee24a43c4b0d7e15f1cb4ba6de1561120d43b9a4e8c4a8a6ee"),
|
|
x!(0x40cae),
|
|
vec![LogEntry::new(
|
|
x!("dcf421d093428b096ca501a7cd1a740855a7976f"),
|
|
vec![],
|
|
vec![0u8; 32]
|
|
)]
|
|
);
|
|
assert_eq!(&encode(&r)[..], &expected[..]);
|
|
}
|