0
0
Fork 0
mirror of https://github.com/denoland/rusty_v8.git synced 2025-01-14 10:02:09 -05:00

refactor: Move set_promise_hooks API to HandleScope (#1186)

This commit is contained in:
Bartek Iwańczuk 2023-02-09 20:38:25 +01:00 committed by GitHub
parent 3b6d79c0e6
commit 36cf16b594
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 30 additions and 37 deletions

View file

@ -5,7 +5,6 @@ use crate::isolate::Isolate;
use crate::isolate::RawSlot; use crate::isolate::RawSlot;
use crate::support::int; use crate::support::int;
use crate::Context; use crate::Context;
use crate::Function;
use crate::HandleScope; use crate::HandleScope;
use crate::Local; use crate::Local;
use crate::Object; use crate::Object;
@ -27,13 +26,6 @@ extern "C" {
fn v8__Context__Global(this: *const Context) -> *const Object; fn v8__Context__Global(this: *const Context) -> *const Object;
fn v8__Context__GetExtrasBindingObject(this: *const Context) fn v8__Context__GetExtrasBindingObject(this: *const Context)
-> *const Object; -> *const Object;
fn v8__Context__SetPromiseHooks(
this: *const Context,
init_hook: *const Function,
before_hook: *const Function,
after_hook: *const Function,
resolve_hook: *const Function,
);
fn v8__Context__GetNumberOfEmbedderDataFields(this: *const Context) -> u32; fn v8__Context__GetNumberOfEmbedderDataFields(this: *const Context) -> u32;
fn v8__Context__GetAlignedPointerFromEmbedderData( fn v8__Context__GetAlignedPointerFromEmbedderData(
this: *const Context, this: *const Context,
@ -107,26 +99,6 @@ impl Context {
unsafe { scope.cast_local(|_| v8__Context__Global(self)) }.unwrap() unsafe { scope.cast_local(|_| v8__Context__Global(self)) }.unwrap()
} }
#[inline(always)]
pub fn set_promise_hooks<'s>(
&self,
_scope: &mut HandleScope<'s, ()>,
init_hook: Option<Local<Function>>,
before_hook: Option<Local<Function>>,
after_hook: Option<Local<Function>>,
resolve_hook: Option<Local<Function>>,
) {
unsafe {
v8__Context__SetPromiseHooks(
self,
init_hook.map_or_else(null, |v| &*v),
before_hook.map_or_else(null, |v| &*v),
after_hook.map_or_else(null, |v| &*v),
resolve_hook.map_or_else(null, |v| &*v),
)
}
}
#[inline] #[inline]
fn get_annex_mut<'a>( fn get_annex_mut<'a>(
&'a self, &'a self,

View file

@ -96,6 +96,7 @@ use crate::function::PropertyCallbackInfo;
use crate::Context; use crate::Context;
use crate::Data; use crate::Data;
use crate::DataError; use crate::DataError;
use crate::Function;
use crate::Handle; use crate::Handle;
use crate::Isolate; use crate::Isolate;
use crate::Local; use crate::Local;
@ -287,6 +288,26 @@ impl<'s> HandleScope<'s> {
} }
} }
#[inline(always)]
pub fn set_promise_hooks(
&mut self,
init_hook: Option<Local<Function>>,
before_hook: Option<Local<Function>>,
after_hook: Option<Local<Function>>,
resolve_hook: Option<Local<Function>>,
) {
unsafe {
let sd = data::ScopeData::get_mut(self);
raw::v8__Context__SetPromiseHooks(
sd.get_current_context(),
init_hook.map_or_else(std::ptr::null, |v| &*v),
before_hook.map_or_else(std::ptr::null, |v| &*v),
after_hook.map_or_else(std::ptr::null, |v| &*v),
resolve_hook.map_or_else(std::ptr::null, |v| &*v),
);
}
}
#[inline(always)] #[inline(always)]
pub fn set_continuation_preserved_embedder_data( pub fn set_continuation_preserved_embedder_data(
&mut self, &mut self,
@ -1719,6 +1740,13 @@ mod raw {
this: *const Context, this: *const Context,
index: usize, index: usize,
) -> *const Data; ) -> *const Data;
pub(super) fn v8__Context__SetPromiseHooks(
this: *const Context,
init_hook: *const Function,
before_hook: *const Function,
after_hook: *const Function,
resolve_hook: *const Function,
);
pub(super) fn v8__Context__SetContinuationPreservedEmbedderData( pub(super) fn v8__Context__SetContinuationPreservedEmbedderData(
this: *const Context, this: *const Context,
value: *const Value, value: *const Value,

View file

@ -3269,8 +3269,7 @@ fn context_promise_hooks() {
.unwrap(), .unwrap(),
) )
.unwrap(); .unwrap();
context.set_promise_hooks( scope.set_promise_hooks(
scope,
Some(init_hook), Some(init_hook),
Some(before_hook), Some(before_hook),
Some(after_hook), Some(after_hook),
@ -3349,13 +3348,7 @@ fn context_promise_hooks_partial() {
.unwrap(), .unwrap(),
) )
.unwrap(); .unwrap();
context.set_promise_hooks( scope.set_promise_hooks(Some(init_hook), Some(before_hook), None, None);
scope,
Some(init_hook),
Some(before_hook),
None,
None,
);
let source = r#" let source = r#"
function expect(expected, actual = promises.size) { function expect(expected, actual = promises.size) {