wasmer/entities/memory/buffer/
inner.rs1use std::{marker::PhantomData, mem::MaybeUninit};
2
3use crate::{
4 MemoryAccessError,
5 macros::backend::{gen_rt_ty, match_rt},
6};
7
8gen_rt_ty!(MemoryBuffer<'a>
10 @derives Debug, Copy, Clone, derive_more::From;
11 @path memory
12);
13
14impl BackendMemoryBuffer<'_> {
15 #[allow(unused)]
16 #[inline]
17 pub(crate) fn read(&self, offset: u64, buf: &mut [u8]) -> Result<(), MemoryAccessError> {
18 match_rt!(on self => s {
19 s.read(offset, buf)
20 })
21 }
22
23 #[allow(unused)]
24 #[inline]
25 pub(crate) fn read_uninit<'b>(
26 &self,
27 offset: u64,
28 buf: &'b mut [MaybeUninit<u8>],
29 ) -> Result<&'b mut [u8], MemoryAccessError> {
30 match_rt!(on self => s {
31 s.read_uninit(offset, buf)
32 })
33 }
34
35 #[allow(unused)]
36 #[inline]
37 pub(crate) fn write(&self, offset: u64, data: &[u8]) -> Result<(), MemoryAccessError> {
38 match_rt!(on self => s {
39 s.write(offset, data)
40 })
41 }
42
43 #[inline]
44 pub(crate) fn len(&self) -> usize {
45 match self {
46 #[cfg(feature = "sys")]
47 Self::Sys(s) => s.len,
48
49 #[cfg(feature = "wamr")]
50 Self::Wamr(s) => s.len,
51
52 #[cfg(feature = "wasmi")]
53 Self::Wasmi(s) => s.len,
54
55 #[cfg(feature = "v8")]
56 Self::V8(s) => s.len,
57
58 #[cfg(feature = "js")]
59 Self::Js(s) => s.len(),
60
61 #[cfg(feature = "jsc")]
62 Self::Jsc(s) => s.len,
63 }
64 }
65
66 #[inline]
67 pub(crate) fn is_owned(&self) -> bool {
68 match self {
69 #[cfg(feature = "js")]
70 Self::Js(_) => true,
71 _ => false,
72 }
73 }
74
75 #[inline]
76 pub(crate) fn base(&self) -> *mut u8 {
77 match self {
78 #[cfg(feature = "sys")]
79 Self::Sys(s) => s.base,
80 #[cfg(feature = "wamr")]
81 Self::Wamr(s) => s.base,
82 #[cfg(feature = "wasmi")]
83 Self::Wasmi(s) => s.base,
84 #[cfg(feature = "v8")]
85 Self::V8(s) => s.base,
86 #[cfg(feature = "js")]
87 Self::Js(s) => panic!("js memory buffers do not support the `base` function!"),
88 #[cfg(feature = "jsc")]
89 Self::Jsc(s) => s.base,
90 }
91 }
92}