refactor(napi): change data to &'static [u8] in JsBuffer
This commit is contained in:
parent
088d5fb1f3
commit
64df7205e9
14 changed files with 45 additions and 45 deletions
|
@ -179,17 +179,19 @@ impl Env {
|
||||||
check_status(status)?;
|
check_status(status)?;
|
||||||
mem::forget(data);
|
mem::forget(data);
|
||||||
|
|
||||||
let mut buffer = JsBuffer::from_raw_unchecked(self.0, raw_value);
|
Ok(JsBuffer::from_raw_unchecked(
|
||||||
buffer.data = data_ptr as *const u8;
|
self.0,
|
||||||
buffer.len = length;
|
raw_value,
|
||||||
Ok(buffer)
|
data_ptr as *mut u8,
|
||||||
|
length as usize,
|
||||||
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn create_buffer_with_data(&self, data: Vec<u8>) -> Result<JsBuffer> {
|
pub fn create_buffer_with_data(&self, mut data: Vec<u8>) -> Result<JsBuffer> {
|
||||||
let length = data.len() as u64;
|
let length = data.len() as u64;
|
||||||
let mut raw_value = ptr::null_mut();
|
let mut raw_value = ptr::null_mut();
|
||||||
let data_ptr = data.as_ptr();
|
let data_ptr = data.as_mut_ptr();
|
||||||
let status = unsafe {
|
let status = unsafe {
|
||||||
sys::napi_create_external_buffer(
|
sys::napi_create_external_buffer(
|
||||||
self.0,
|
self.0,
|
||||||
|
@ -206,10 +208,12 @@ impl Env {
|
||||||
unsafe { sys::napi_adjust_external_memory(self.0, length as i64, &mut changed) };
|
unsafe { sys::napi_adjust_external_memory(self.0, length as i64, &mut changed) };
|
||||||
check_status(adjust_external_memory_status)?;
|
check_status(adjust_external_memory_status)?;
|
||||||
mem::forget(data);
|
mem::forget(data);
|
||||||
let mut buffer = JsBuffer::from_raw_unchecked(self.0, raw_value);
|
Ok(JsBuffer::from_raw_unchecked(
|
||||||
buffer.data = data_ptr as *const u8;
|
self.0,
|
||||||
buffer.len = length;
|
raw_value,
|
||||||
Ok(buffer)
|
data_ptr,
|
||||||
|
length as usize,
|
||||||
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -4,7 +4,7 @@ use super::{JsObject, NapiValue, Value, ValueType};
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Result};
|
use crate::{sys, Result};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsArrayBuffer {
|
pub struct JsArrayBuffer {
|
||||||
pub value: JsObject,
|
pub value: JsObject,
|
||||||
pub data: *const u8,
|
pub data: *const u8,
|
||||||
|
|
|
@ -4,7 +4,7 @@ use super::Value;
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Error, Result};
|
use crate::{sys, Error, Result};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsBoolean(pub(crate) Value);
|
pub struct JsBoolean(pub(crate) Value);
|
||||||
|
|
||||||
impl JsBoolean {
|
impl JsBoolean {
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use std::ops::{Deref, DerefMut};
|
use std::ops::Deref;
|
||||||
use std::ptr;
|
use std::ptr;
|
||||||
use std::slice;
|
use std::slice;
|
||||||
|
|
||||||
|
@ -6,23 +6,26 @@ use super::{JsObject, JsUnknown, NapiValue, Value, ValueType};
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Result};
|
use crate::{sys, Result};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsBuffer {
|
pub struct JsBuffer {
|
||||||
pub value: JsObject,
|
pub value: JsObject,
|
||||||
pub data: *const u8,
|
pub data: &'static [u8],
|
||||||
pub len: u64,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl JsBuffer {
|
impl JsBuffer {
|
||||||
pub(crate) fn from_raw_unchecked(env: sys::napi_env, value: sys::napi_value) -> Self {
|
pub(crate) fn from_raw_unchecked(
|
||||||
|
env: sys::napi_env,
|
||||||
|
value: sys::napi_value,
|
||||||
|
data: *mut u8,
|
||||||
|
len: usize,
|
||||||
|
) -> Self {
|
||||||
Self {
|
Self {
|
||||||
value: JsObject(Value {
|
value: JsObject(Value {
|
||||||
env,
|
env,
|
||||||
value,
|
value,
|
||||||
value_type: ValueType::Object,
|
value_type: ValueType::Object,
|
||||||
}),
|
}),
|
||||||
data: ptr::null(),
|
data: unsafe { slice::from_raw_parts_mut(data, len) },
|
||||||
len: 0,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,15 +50,14 @@ impl NapiValue for JsBuffer {
|
||||||
value,
|
value,
|
||||||
value_type: ValueType::Object,
|
value_type: ValueType::Object,
|
||||||
}),
|
}),
|
||||||
data: data as *const u8,
|
data: unsafe { slice::from_raw_parts_mut(data as *mut _, len as usize) },
|
||||||
len,
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl AsRef<[u8]> for JsBuffer {
|
impl AsRef<[u8]> for JsBuffer {
|
||||||
fn as_ref(&self) -> &[u8] {
|
fn as_ref(&self) -> &[u8] {
|
||||||
self.deref()
|
self.data
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,12 +65,6 @@ impl Deref for JsBuffer {
|
||||||
type Target = [u8];
|
type Target = [u8];
|
||||||
|
|
||||||
fn deref(&self) -> &[u8] {
|
fn deref(&self) -> &[u8] {
|
||||||
unsafe { slice::from_raw_parts(self.data, self.len as usize) }
|
self.data
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl DerefMut for JsBuffer {
|
|
||||||
fn deref_mut(&mut self) -> &mut [u8] {
|
|
||||||
unsafe { slice::from_raw_parts_mut(self.data as *mut _, self.len as usize) }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ use std::ptr;
|
||||||
|
|
||||||
use crate::{sys, Callback, Env, NapiValue, Result};
|
use crate::{sys, Callback, Env, NapiValue, Result};
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Property {
|
pub struct Property {
|
||||||
name: String,
|
name: String,
|
||||||
raw_descriptor: sys::napi_property_descriptor,
|
raw_descriptor: sys::napi_property_descriptor,
|
||||||
|
|
|
@ -5,7 +5,7 @@ use super::Value;
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Env, Error, JsObject, JsUnknown, NapiValue, Result, Status};
|
use crate::{sys, Env, Error, JsObject, JsUnknown, NapiValue, Result, Status};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsFunction(pub(crate) Value);
|
pub struct JsFunction(pub(crate) Value);
|
||||||
|
|
||||||
/// See [Working with JavaScript Functions](https://nodejs.org/api/n-api.html#n_api_working_with_javascript_functions).
|
/// See [Working with JavaScript Functions](https://nodejs.org/api/n-api.html#n_api_working_with_javascript_functions).
|
||||||
|
|
|
@ -35,20 +35,20 @@ pub(crate) use value_ref::Ref;
|
||||||
pub use value_type::ValueType;
|
pub use value_type::ValueType;
|
||||||
|
|
||||||
// Value types
|
// Value types
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsUnknown(pub(crate) Value);
|
pub struct JsUnknown(pub(crate) Value);
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsNull(pub(crate) Value);
|
pub struct JsNull(pub(crate) Value);
|
||||||
|
|
||||||
#[cfg(napi6)]
|
#[cfg(napi6)]
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsBigint(pub(crate) Value);
|
pub struct JsBigint(pub(crate) Value);
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsSymbol(pub(crate) Value);
|
pub struct JsSymbol(pub(crate) Value);
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsExternal(pub(crate) Value);
|
pub struct JsExternal(pub(crate) Value);
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
|
|
@ -4,7 +4,7 @@ use super::Value;
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Error, Result};
|
use crate::{sys, Error, Result};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsNumber(pub(crate) Value);
|
pub struct JsNumber(pub(crate) Value);
|
||||||
|
|
||||||
impl TryFrom<JsNumber> for usize {
|
impl TryFrom<JsNumber> for usize {
|
||||||
|
|
|
@ -5,7 +5,7 @@ use super::Value;
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Env, Error, JsBuffer, JsNumber, JsString, NapiValue, Result, Status};
|
use crate::{sys, Env, Error, JsBuffer, JsNumber, JsString, NapiValue, Result, Status};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsObject(pub(crate) Value);
|
pub struct JsObject(pub(crate) Value);
|
||||||
|
|
||||||
impl JsObject {
|
impl JsObject {
|
||||||
|
|
|
@ -8,7 +8,7 @@ use super::Value;
|
||||||
use crate::error::check_status;
|
use crate::error::check_status;
|
||||||
use crate::{sys, Error, Result, Status};
|
use crate::{sys, Error, Result, Status};
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsString(pub(crate) Value);
|
pub struct JsString(pub(crate) Value);
|
||||||
|
|
||||||
impl JsString {
|
impl JsString {
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use super::Value;
|
use super::Value;
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct JsUndefined(pub(crate) Value);
|
pub struct JsUndefined(pub(crate) Value);
|
||||||
|
|
|
@ -2,7 +2,7 @@ use crate::sys;
|
||||||
|
|
||||||
use super::ValueType;
|
use super::ValueType;
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Value {
|
pub struct Value {
|
||||||
pub env: sys::napi_env,
|
pub env: sys::napi_env,
|
||||||
pub value: sys::napi_value,
|
pub value: sys::napi_value,
|
||||||
|
|
|
@ -159,7 +159,7 @@ macro_rules! register_module {
|
||||||
let hook_result = Ok(());
|
let hook_result = Ok(());
|
||||||
|
|
||||||
match hook_result.and_then(move |_| result) {
|
match hook_result.and_then(move |_| result) {
|
||||||
Ok(_) => exports.raw_value(),
|
Ok(_) => cjs_module.exports.raw_value(),
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
unsafe {
|
unsafe {
|
||||||
sys::napi_throw_error(
|
sys::napi_throw_error(
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use napi::{JsFunction, CallContext, JsNull, Result, JsObject};
|
use napi::{CallContext, JsFunction, JsNull, JsObject, Result};
|
||||||
|
|
||||||
#[js_function(1)]
|
#[js_function(1)]
|
||||||
pub fn call_function(ctx: CallContext) -> Result<JsNull> {
|
pub fn call_function(ctx: CallContext) -> Result<JsNull> {
|
||||||
|
@ -13,10 +13,10 @@ pub fn call_function(ctx: CallContext) -> Result<JsNull> {
|
||||||
|
|
||||||
#[js_function(1)]
|
#[js_function(1)]
|
||||||
pub fn call_function_with_this(ctx: CallContext<JsObject>) -> Result<JsNull> {
|
pub fn call_function_with_this(ctx: CallContext<JsObject>) -> Result<JsNull> {
|
||||||
let js_this = ctx.this;
|
let js_this = &ctx.this;
|
||||||
let js_func = ctx.get::<JsFunction>(0)?;
|
let js_func = ctx.get::<JsFunction>(0)?;
|
||||||
|
|
||||||
js_func.call(Some(&js_this), &[])?;
|
js_func.call(Some(js_this), &[])?;
|
||||||
|
|
||||||
ctx.env.get_null()
|
ctx.env.get_null()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue