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
81
82
83
84
85
86
87
88
89
90
91
92
use crate::backtrace::Backtrace;
use crate::transactor::Transactor;
use fuel_tx::{Receipt, Transaction};
mod storage;
pub use storage::MemoryStorage;
#[derive(Debug, Default)]
pub struct MemoryClient<'a> {
transactor: Transactor<'a, MemoryStorage>,
}
impl<'a> AsRef<MemoryStorage> for MemoryClient<'a> {
fn as_ref(&self) -> &MemoryStorage {
self.transactor.as_ref()
}
}
impl<'a> AsMut<MemoryStorage> for MemoryClient<'a> {
fn as_mut(&mut self) -> &mut MemoryStorage {
self.transactor.as_mut()
}
}
impl<'a> MemoryClient<'a> {
pub fn new(storage: MemoryStorage) -> Self {
Self {
transactor: Transactor::new(storage),
}
}
pub fn from_txtor(transactor: Transactor<'a, MemoryStorage>) -> Self {
Self { transactor }
}
pub fn backtrace(&self) -> Option<Backtrace> {
self.transactor.backtrace()
}
pub fn receipts(&self) -> Option<&[Receipt]> {
self.transactor.receipts()
}
pub fn transact(&mut self, tx: Transaction) -> &[Receipt] {
self.transactor.transact(tx);
let state = self
.transactor
.result()
.expect("MemoryStorage implements `Infallible` as storage error. This means panic should be unreachable.");
if state.should_revert() {
self.transactor.as_mut().revert();
} else {
self.transactor.as_mut().commit();
}
self.transactor
.receipts()
.expect("The transaction was provided to the transactor.")
}
pub fn persist(&mut self) {
self.as_mut().persist();
}
}
impl<'a> From<MemoryStorage> for MemoryClient<'a> {
fn from(s: MemoryStorage) -> Self {
Self::new(s)
}
}