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)
        }
    }
}