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
use stdweb::UnsafeTypedArray;
use crate::{
constants::{ReturnCode, Terrain},
local::RoomName,
objects::RoomTerrain,
traits::TryInto,
};
impl RoomTerrain {
pub fn constructor(room_name: RoomName) -> Self {
js_unwrap!(new Room.Terrain(@{room_name}))
}
pub fn get(&self, x: u32, y: u32) -> Terrain {
js_unwrap!(@{self.as_ref()}.get(@{x}, @{y}))
}
pub fn get_raw_buffer(&self) -> Vec<u8> {
let mut buffer: Vec<u8> = vec![0; 2500];
self.get_raw_buffer_to_vec(&mut buffer)
.expect("Panic in get_raw_buffer.");
buffer
}
pub fn get_raw_buffer_to_vec<'a>(
&self,
buffer: &'a mut Vec<u8>,
) -> Result<&'a mut Vec<u8>, ReturnCode> {
let is_success: bool;
{
let arr: UnsafeTypedArray<'_, u8> =
unsafe { UnsafeTypedArray::new(buffer.as_mut_slice()) };
is_success = js! {
var bytes = @{arr};
return @{self.as_ref()}.getRawBuffer(bytes) === bytes;
}
.try_into()
.unwrap();
}
if is_success {
Ok(buffer)
} else {
Err(ReturnCode::InvalidArgs)
}
}
pub fn get_raw_buffer_to_array<'a>(
&self,
buffer: &'a mut [u8; 2500],
) -> Result<(), ReturnCode> {
let is_success: bool;
{
let arr: UnsafeTypedArray<'_, u8> = unsafe { UnsafeTypedArray::new(&buffer[0..2500]) };
is_success = js! {
var bytes = @{arr};
return @{self.as_ref()}.getRawBuffer(bytes) === bytes;
}
.try_into()
.unwrap();
}
if is_success {
Ok(())
} else {
Err(ReturnCode::InvalidArgs)
}
}
}