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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
use elrond_wasm::{
api::{Handle, InvalidSliceError, ManagedBufferApi},
types::BoxedBytes,
};
use crate::DebugApi;
impl DebugApi {
fn mb_get_slice(
&self,
source_handle: Handle,
starting_position: usize,
slice_len: usize,
) -> Option<Vec<u8>> {
let managed_types = self.m_types_borrow();
let all_bytes = managed_types.managed_buffer_map.get(source_handle);
if starting_position + slice_len <= all_bytes.len() {
Some(all_bytes[starting_position..starting_position + slice_len].to_vec())
} else {
None
}
}
}
impl ManagedBufferApi for DebugApi {
fn mb_new_empty(&self) -> Handle {
let mut managed_types = self.m_types_borrow_mut();
managed_types
.managed_buffer_map
.insert_new_handle(Vec::new())
}
fn mb_new_from_bytes(&self, bytes: &[u8]) -> Handle {
let mut managed_types = self.m_types_borrow_mut();
managed_types
.managed_buffer_map
.insert_new_handle(Vec::from(bytes))
}
fn mb_len(&self, handle: Handle) -> usize {
let managed_types = self.m_types_borrow();
let data = managed_types.managed_buffer_map.get(handle);
data.len()
}
fn mb_to_boxed_bytes(&self, handle: Handle) -> BoxedBytes {
let managed_types = self.m_types_borrow();
let data = managed_types.managed_buffer_map.get(handle);
data.into()
}
fn mb_load_slice(
&self,
source_handle: Handle,
starting_position: usize,
dest_slice: &mut [u8],
) -> Result<(), InvalidSliceError> {
let opt_slice = self.mb_get_slice(source_handle, starting_position, dest_slice.len());
if let Some(slice) = opt_slice {
dest_slice.copy_from_slice(slice.as_slice());
Ok(())
} else {
Err(InvalidSliceError)
}
}
fn mb_copy_slice(
&self,
source_handle: Handle,
starting_position: usize,
slice_len: usize,
dest_handle: Handle,
) -> Result<(), InvalidSliceError> {
let opt_slice = self.mb_get_slice(source_handle, starting_position, slice_len);
if let Some(slice) = opt_slice {
let mut managed_types = self.m_types_borrow_mut();
managed_types.managed_buffer_map.insert(dest_handle, slice);
Ok(())
} else {
Err(InvalidSliceError)
}
}
fn mb_copy_to_slice_pad_right(&self, handle: Handle, destination: &mut [u8]) {
let bytes = self.mb_to_boxed_bytes(handle);
let offset = 32 - bytes.len();
destination[offset..].clone_from_slice(bytes.as_slice());
}
fn mb_overwrite(&self, handle: Handle, value: &[u8]) {
let mut managed_types = self.m_types_borrow_mut();
managed_types
.managed_buffer_map
.insert(handle, value.into());
}
fn mb_append(&self, accumulator_handle: Handle, data_handle: Handle) {
let mut managed_types = self.m_types_borrow_mut();
let mut data = managed_types.managed_buffer_map.get(data_handle).clone();
let accumulator = managed_types.managed_buffer_map.get_mut(accumulator_handle);
accumulator.append(&mut data);
}
fn mb_append_bytes(&self, accumulator_handle: Handle, bytes: &[u8]) {
let mut managed_types = self.m_types_borrow_mut();
let accumulator = managed_types.managed_buffer_map.get_mut(accumulator_handle);
accumulator.extend_from_slice(bytes);
}
fn mb_eq(&self, handle1: Handle, handle2: Handle) -> bool {
let managed_types = self.m_types_borrow();
let bytes1 = managed_types.managed_buffer_map.get(handle1);
let bytes2 = managed_types.managed_buffer_map.get(handle2);
bytes1 == bytes2
}
}