From a181ceb0e3791c842db6e8e6f528cf9ce320642a Mon Sep 17 00:00:00 2001 From: Matt Mastracci Date: Sat, 24 Jun 2023 23:30:04 +0200 Subject: refactor(ops): op2 supports Result in slow call path (#19602) --- ops/op2/test_cases/sync/result_void.out | 45 +++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 ops/op2/test_cases/sync/result_void.out (limited to 'ops/op2/test_cases/sync/result_void.out') diff --git a/ops/op2/test_cases/sync/result_void.out b/ops/op2/test_cases/sync/result_void.out new file mode 100644 index 000000000..74c0c66a6 --- /dev/null +++ b/ops/op2/test_cases/sync/result_void.out @@ -0,0 +1,45 @@ +#[allow(non_camel_case_types)] +pub struct op_void_with_result {} +impl op_void_with_result { + pub const fn name() -> &'static str { + stringify!(op_void_with_result) + } + pub const fn decl() -> deno_core::_ops::OpDecl { + deno_core::_ops::OpDecl { + name: stringify!(op_void_with_result), + v8_fn_ptr: Self::slow_function as _, + enabled: true, + fast_fn: None, + is_async: false, + is_unstable: false, + is_v8: false, + arg_count: 0usize as u8, + } + } + pub extern "C" fn slow_function(info: *const deno_core::v8::FunctionCallbackInfo) { + let result = Self::call(); + match result { + Ok(result) => {} + Err(err) => { + let scope = &mut unsafe { deno_core::v8::CallbackScope::new(&*info) }; + let args = deno_core::v8::FunctionCallbackArguments::from_function_callback_info(unsafe { + &*info + }); + let opctx = unsafe { + &*(deno_core::v8::Local::::cast(args.data()) + .value() as *const deno_core::_ops::OpCtx) + }; + let opstate = ::std::cell::RefCell::borrow(&*opctx.state); + let exception = deno_core::error::to_v8_error( + scope, + opstate.get_error_class_fn, + &err, + ); + scope.throw_exception(exception); + return; + } + }; + } + #[inline(always)] + pub fn call() -> Result<(), AnyError> {} +} -- cgit v1.2.3