1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
use crate as shared;
use crate::{u256, CompactInt};
use serde_derive::{Deserializable, Serializable};
#[derive(Deserializable, Serializable, Debug)]
pub struct Transaction {
version: i32,
inputs: Vec<TxInput>,
outputs: Vec<TxOutput>,
}
impl Transaction {
pub fn len(&self) -> usize {
let mut size = 0;
size += 4 + CompactInt::size(self.inputs.len());
for input in self.inputs.iter() {
size += input.len();
}
size += CompactInt::size(self.outputs.len());
for output in self.outputs.iter() {
size += output.len();
}
size
}
pub fn new(version: i32, inputs: Vec<TxInput>, outputs: Vec<TxOutput>) -> Transaction {
Transaction {
version,
inputs,
outputs,
}
}
}
#[derive(Deserializable, Serializable, Debug)]
pub struct TxInput {
previous_outpoint: TxOutpoint,
signature_script: Vec<u8>,
sequence: u32,
}
impl TxInput {
pub fn len(&self) -> usize {
self.previous_outpoint.len()
+ CompactInt::size(self.signature_script.len())
+ self.signature_script.len()
+ 4
}
pub fn new(previous_outpoint: TxOutpoint, signature_script: Vec<u8>, sequence: u32) -> TxInput {
TxInput {
previous_outpoint,
signature_script,
sequence,
}
}
}
#[derive(Deserializable, Serializable, Debug)]
pub struct TxOutput {
value: i64,
pk_script: Vec<u8>,
}
impl TxOutput {
pub fn len(&self) -> usize {
8 + CompactInt::size(self.pk_script.len()) + self.pk_script.len()
}
pub fn new(value: i64, pk_script: Vec<u8>) -> TxOutput {
TxOutput { value, pk_script }
}
}
#[derive(Deserializable, Serializable, Debug)]
pub struct TxOutpoint {
hash: u256,
index: u32,
}
impl TxOutpoint {
pub fn len(&self) -> usize {
32 + 4
}
pub fn new(hash: u256, index: u32) -> TxOutpoint {
TxOutpoint { hash, index }
}
}
#[derive(Deserializable, Serializable)]
pub struct CoinbaseInput {}