mirror of
https://github.com/denoland/deno.git
synced 2024-12-22 07:14:47 -05:00
fix(napi): date and unwrap handling (#17369)
This commit is contained in:
parent
a00e432297
commit
291dcc31f7
4 changed files with 101 additions and 1 deletions
|
@ -1484,6 +1484,11 @@ fn napi_get_date_value(
|
||||||
) -> Result {
|
) -> Result {
|
||||||
let env: &mut Env = env.as_mut().ok_or(Error::InvalidArg)?;
|
let env: &mut Env = env.as_mut().ok_or(Error::InvalidArg)?;
|
||||||
let value = transmute::<napi_value, v8::Local<v8::Value>>(value);
|
let value = transmute::<napi_value, v8::Local<v8::Value>>(value);
|
||||||
|
|
||||||
|
if !value.is_date() {
|
||||||
|
return Err(Error::DateExpected);
|
||||||
|
}
|
||||||
|
|
||||||
let date = v8::Local::<v8::Date>::try_from(value).unwrap();
|
let date = v8::Local::<v8::Date>::try_from(value).unwrap();
|
||||||
*result = date.number_value(&mut env.scope()).unwrap();
|
*result = date.number_value(&mut env.scope()).unwrap();
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -2287,7 +2292,9 @@ fn napi_unwrap(
|
||||||
let shared = &*(env.shared as *const EnvShared);
|
let shared = &*(env.shared as *const EnvShared);
|
||||||
let napi_wrap = v8::Local::new(&mut env.scope(), &shared.napi_wrap);
|
let napi_wrap = v8::Local::new(&mut env.scope(), &shared.napi_wrap);
|
||||||
let ext = obj.get_private(&mut env.scope(), napi_wrap).unwrap();
|
let ext = obj.get_private(&mut env.scope(), napi_wrap).unwrap();
|
||||||
let ext = v8::Local::<v8::External>::try_from(ext).unwrap();
|
let ext = v8::Local::<v8::External>::try_from(ext)
|
||||||
|
.ok()
|
||||||
|
.ok_or(Error::InvalidArg)?;
|
||||||
*result = ext.value();
|
*result = ext.value();
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
17
test_napi/date_test.js
Normal file
17
test_napi/date_test.js
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
||||||
|
|
||||||
|
import { assertEquals, loadTestLibrary } from "./common.js";
|
||||||
|
|
||||||
|
const date = loadTestLibrary();
|
||||||
|
|
||||||
|
Deno.test("napi date", function () {
|
||||||
|
const dateTypeTestDate = date.createDate(1549183351);
|
||||||
|
assertEquals(date.isDate(dateTypeTestDate), true);
|
||||||
|
assertEquals(date.isDate(new Date(1549183351)), true);
|
||||||
|
assertEquals(date.isDate(2.4), false);
|
||||||
|
assertEquals(date.isDate("not a date"), false);
|
||||||
|
assertEquals(date.isDate(undefined), false);
|
||||||
|
assertEquals(date.isDate(null), false);
|
||||||
|
assertEquals(date.isDate({}), false);
|
||||||
|
assertEquals(date.getDateValue(new Date(1549183351)), 1549183351);
|
||||||
|
});
|
74
test_napi/src/date.rs
Normal file
74
test_napi/src/date.rs
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
||||||
|
|
||||||
|
use crate::assert_napi_ok;
|
||||||
|
use crate::napi_get_callback_info;
|
||||||
|
use crate::napi_new_property;
|
||||||
|
use napi_sys::ValueType::napi_number;
|
||||||
|
use napi_sys::*;
|
||||||
|
use std::ptr;
|
||||||
|
|
||||||
|
extern "C" fn create_date(
|
||||||
|
env: napi_env,
|
||||||
|
info: napi_callback_info,
|
||||||
|
) -> napi_value {
|
||||||
|
let (args, argc, _) = napi_get_callback_info!(env, info, 1);
|
||||||
|
assert_eq!(argc, 1);
|
||||||
|
|
||||||
|
let mut ty = -1;
|
||||||
|
assert_napi_ok!(napi_typeof(env, args[0], &mut ty));
|
||||||
|
assert_eq!(ty, napi_number);
|
||||||
|
|
||||||
|
let mut time = -1.0;
|
||||||
|
assert_napi_ok!(napi_get_value_double(env, args[0], &mut time));
|
||||||
|
|
||||||
|
let mut date: napi_value = ptr::null_mut();
|
||||||
|
assert_napi_ok!(napi_create_date(env, time, &mut date));
|
||||||
|
|
||||||
|
date
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" fn is_date(env: napi_env, info: napi_callback_info) -> napi_value {
|
||||||
|
let (args, argc, _) = napi_get_callback_info!(env, info, 1);
|
||||||
|
assert_eq!(argc, 1);
|
||||||
|
|
||||||
|
let date: napi_value = args[0];
|
||||||
|
let mut result: napi_value = std::ptr::null_mut();
|
||||||
|
let mut is_date = false;
|
||||||
|
|
||||||
|
assert_napi_ok!(napi_is_date(env, date, &mut is_date));
|
||||||
|
assert_napi_ok!(napi_get_boolean(env, is_date, &mut result));
|
||||||
|
|
||||||
|
result
|
||||||
|
}
|
||||||
|
|
||||||
|
extern "C" fn get_date_value(
|
||||||
|
env: napi_env,
|
||||||
|
info: napi_callback_info,
|
||||||
|
) -> napi_value {
|
||||||
|
let (args, argc, _) = napi_get_callback_info!(env, info, 1);
|
||||||
|
assert_eq!(argc, 1);
|
||||||
|
|
||||||
|
let date: napi_value = args[0];
|
||||||
|
let mut result: napi_value = std::ptr::null_mut();
|
||||||
|
let mut value = 0.0;
|
||||||
|
|
||||||
|
assert_napi_ok!(napi_get_date_value(env, date, &mut value));
|
||||||
|
assert_napi_ok!(napi_create_double(env, value, &mut result));
|
||||||
|
|
||||||
|
result
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn init(env: napi_env, exports: napi_value) {
|
||||||
|
let properties = &[
|
||||||
|
napi_new_property!(env, "createDate", create_date),
|
||||||
|
napi_new_property!(env, "isDate", is_date),
|
||||||
|
napi_new_property!(env, "getDateValue", get_date_value),
|
||||||
|
];
|
||||||
|
|
||||||
|
assert_napi_ok!(napi_define_properties(
|
||||||
|
env,
|
||||||
|
exports,
|
||||||
|
properties.len(),
|
||||||
|
properties.as_ptr()
|
||||||
|
));
|
||||||
|
}
|
|
@ -11,6 +11,7 @@ pub mod arraybuffer;
|
||||||
pub mod r#async;
|
pub mod r#async;
|
||||||
pub mod callback;
|
pub mod callback;
|
||||||
pub mod coerce;
|
pub mod coerce;
|
||||||
|
pub mod date;
|
||||||
pub mod numbers;
|
pub mod numbers;
|
||||||
pub mod object_wrap;
|
pub mod object_wrap;
|
||||||
pub mod primitives;
|
pub mod primitives;
|
||||||
|
@ -127,6 +128,7 @@ unsafe extern "C" fn napi_register_module_v1(
|
||||||
object_wrap::init(env, exports);
|
object_wrap::init(env, exports);
|
||||||
callback::init(env, exports);
|
callback::init(env, exports);
|
||||||
r#async::init(env, exports);
|
r#async::init(env, exports);
|
||||||
|
date::init(env, exports);
|
||||||
tsfn::init(env, exports);
|
tsfn::init(env, exports);
|
||||||
init_cleanup_hook(env, exports);
|
init_cleanup_hook(env, exports);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue