mirror of
https://github.com/denoland/deno.git
synced 2024-12-22 07:14:47 -05:00
fix(napi): fix is_detached_arraybuffer (#16478)
This commit is contained in:
parent
59ac110edd
commit
207dd8d111
5 changed files with 52 additions and 4 deletions
|
@ -1798,9 +1798,7 @@ fn napi_is_detached_arraybuffer(
|
||||||
) -> Result {
|
) -> Result {
|
||||||
let value = transmute::<napi_value, v8::Local<v8::Value>>(value);
|
let value = transmute::<napi_value, v8::Local<v8::Value>>(value);
|
||||||
let _ab = v8::Local::<v8::ArrayBuffer>::try_from(value).unwrap();
|
let _ab = v8::Local::<v8::ArrayBuffer>::try_from(value).unwrap();
|
||||||
// TODO: what is API for checking if ArrayBuffer is detached?
|
*result = _ab.was_detached();
|
||||||
// there's only is_detachable I could find.
|
|
||||||
*result = false;
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ publish = false
|
||||||
crate-type = ["cdylib"]
|
crate-type = ["cdylib"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
napi-sys = { version = "2.2.2", default-features = false, features = ["napi4"] }
|
napi-sys = { version = "2.2.2", default-features = false, features = ["napi7"] }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
test_util = { path = "../test_util" }
|
test_util = { path = "../test_util" }
|
||||||
|
|
12
test_napi/arraybuffer_test.js
Normal file
12
test_napi/arraybuffer_test.js
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
||||||
|
|
||||||
|
import { assertEquals, loadTestLibrary } from "./common.js";
|
||||||
|
|
||||||
|
const typedarray = loadTestLibrary();
|
||||||
|
|
||||||
|
Deno.test("napi arraybuffer detach", function () {
|
||||||
|
const buf = new ArrayBuffer(5);
|
||||||
|
assertEquals(buf.byteLength, 5);
|
||||||
|
typedarray.test_detached(buf);
|
||||||
|
assertEquals(buf.byteLength, 0);
|
||||||
|
});
|
36
test_napi/src/arraybuffer.rs
Normal file
36
test_napi/src/arraybuffer.rs
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
||||||
|
|
||||||
|
use napi_sys::Status::napi_ok;
|
||||||
|
use napi_sys::*;
|
||||||
|
use std::ptr;
|
||||||
|
|
||||||
|
extern "C" fn test_detached(
|
||||||
|
env: napi_env,
|
||||||
|
info: napi_callback_info,
|
||||||
|
) -> napi_value {
|
||||||
|
let (args, argc, _) = crate::get_callback_info!(env, info, 1);
|
||||||
|
assert_eq!(argc, 1);
|
||||||
|
|
||||||
|
let mut value = false;
|
||||||
|
assert!(
|
||||||
|
unsafe { napi_is_detached_arraybuffer(env, args[0], &mut value) }
|
||||||
|
== napi_ok
|
||||||
|
);
|
||||||
|
assert!(!value);
|
||||||
|
assert!(unsafe { napi_detach_arraybuffer(env, args[0]) } == napi_ok);
|
||||||
|
assert!(
|
||||||
|
unsafe { napi_is_detached_arraybuffer(env, args[0], &mut value) }
|
||||||
|
== napi_ok
|
||||||
|
);
|
||||||
|
assert!(value);
|
||||||
|
args[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn init(env: napi_env, exports: napi_value) {
|
||||||
|
let properties =
|
||||||
|
&[crate::new_property!(env, "test_detached\0", test_detached)];
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
napi_define_properties(env, exports, properties.len(), properties.as_ptr())
|
||||||
|
};
|
||||||
|
}
|
|
@ -5,6 +5,7 @@
|
||||||
use napi_sys::*;
|
use napi_sys::*;
|
||||||
|
|
||||||
pub mod array;
|
pub mod array;
|
||||||
|
pub mod arraybuffer;
|
||||||
pub mod r#async;
|
pub mod r#async;
|
||||||
pub mod callback;
|
pub mod callback;
|
||||||
pub mod coerce;
|
pub mod coerce;
|
||||||
|
@ -67,6 +68,7 @@ unsafe extern "C" fn napi_register_module_v1(
|
||||||
strings::init(env, exports);
|
strings::init(env, exports);
|
||||||
numbers::init(env, exports);
|
numbers::init(env, exports);
|
||||||
typedarray::init(env, exports);
|
typedarray::init(env, exports);
|
||||||
|
arraybuffer::init(env, exports);
|
||||||
array::init(env, exports);
|
array::init(env, exports);
|
||||||
primitives::init(env, exports);
|
primitives::init(env, exports);
|
||||||
properties::init(env, exports);
|
properties::init(env, exports);
|
||||||
|
|
Loading…
Reference in a new issue