mirror of
https://github.com/denoland/deno.git
synced 2025-01-08 15:19:40 -05:00
refactor(core): remove JsRuntime::set_js_error_create_fn (#7478)
Instead use RuntimeOptions.js_error_create_fn
This commit is contained in:
parent
9b8f1d9be8
commit
7023263b30
2 changed files with 18 additions and 17 deletions
|
@ -106,19 +106,16 @@ impl Worker {
|
||||||
startup_snapshot: Option<Snapshot>,
|
startup_snapshot: Option<Snapshot>,
|
||||||
state: &Rc<CliState>,
|
state: &Rc<CliState>,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
|
let global_state = state.global_state.clone();
|
||||||
|
|
||||||
let mut isolate = JsRuntime::new(RuntimeOptions {
|
let mut isolate = JsRuntime::new(RuntimeOptions {
|
||||||
module_loader: Some(state.clone()),
|
module_loader: Some(state.clone()),
|
||||||
startup_snapshot,
|
startup_snapshot,
|
||||||
|
js_error_create_fn: Some(Box::new(move |core_js_error| {
|
||||||
|
JsError::create(core_js_error, &global_state.ts_compiler)
|
||||||
|
})),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
});
|
});
|
||||||
{
|
|
||||||
let global_state = state.global_state.clone();
|
|
||||||
let js_runtime_state = JsRuntime::state(&isolate);
|
|
||||||
let mut js_runtime_state = js_runtime_state.borrow_mut();
|
|
||||||
js_runtime_state.set_js_error_create_fn(move |core_js_error| {
|
|
||||||
JsError::create(core_js_error, &global_state.ts_compiler)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
{
|
{
|
||||||
let op_state = isolate.op_state();
|
let op_state = isolate.op_state();
|
||||||
let mut op_state = op_state.borrow_mut();
|
let mut op_state = op_state.borrow_mut();
|
||||||
|
|
|
@ -180,6 +180,11 @@ pub struct HeapLimits {
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
pub struct RuntimeOptions {
|
pub struct RuntimeOptions {
|
||||||
|
/// Allows a callback to be set whenever a V8 exception is made. This allows
|
||||||
|
/// the caller to wrap the JsError into an error. By default this callback
|
||||||
|
/// is set to `JsError::create()`.
|
||||||
|
pub js_error_create_fn: Option<Box<JsErrorCreateFn>>,
|
||||||
|
|
||||||
/// Implementation of `ModuleLoader` which will be
|
/// Implementation of `ModuleLoader` which will be
|
||||||
/// called when V8 requests to load ES modules.
|
/// called when V8 requests to load ES modules.
|
||||||
///
|
///
|
||||||
|
@ -266,6 +271,9 @@ impl JsRuntime {
|
||||||
.module_loader
|
.module_loader
|
||||||
.unwrap_or_else(|| Rc::new(NoopModuleLoader));
|
.unwrap_or_else(|| Rc::new(NoopModuleLoader));
|
||||||
|
|
||||||
|
let js_error_create_fn = options
|
||||||
|
.js_error_create_fn
|
||||||
|
.unwrap_or_else(|| Box::new(JsError::create));
|
||||||
let op_state = OpState::default();
|
let op_state = OpState::default();
|
||||||
|
|
||||||
isolate.set_slot(Rc::new(RefCell::new(JsRuntimeState {
|
isolate.set_slot(Rc::new(RefCell::new(JsRuntimeState {
|
||||||
|
@ -274,7 +282,7 @@ impl JsRuntime {
|
||||||
shared_ab: None,
|
shared_ab: None,
|
||||||
js_recv_cb: None,
|
js_recv_cb: None,
|
||||||
js_macrotask_cb: None,
|
js_macrotask_cb: None,
|
||||||
js_error_create_fn: Box::new(JsError::create),
|
js_error_create_fn,
|
||||||
shared: SharedQueue::new(RECOMMENDED_SIZE),
|
shared: SharedQueue::new(RECOMMENDED_SIZE),
|
||||||
pending_ops: FuturesUnordered::new(),
|
pending_ops: FuturesUnordered::new(),
|
||||||
pending_unref_ops: FuturesUnordered::new(),
|
pending_unref_ops: FuturesUnordered::new(),
|
||||||
|
@ -332,8 +340,7 @@ impl JsRuntime {
|
||||||
///
|
///
|
||||||
/// `AnyError` can be downcast to a type that exposes additional information
|
/// `AnyError` can be downcast to a type that exposes additional information
|
||||||
/// about the V8 exception. By default this type is `JsError`, however it may
|
/// about the V8 exception. By default this type is `JsError`, however it may
|
||||||
/// be a different type if `JsRuntime::set_js_error_create_fn()` has been
|
/// be a different type if `RuntimeOptions::js_error_create_fn` has been set.
|
||||||
/// used.
|
|
||||||
pub fn execute(
|
pub fn execute(
|
||||||
&mut self,
|
&mut self,
|
||||||
js_filename: &str,
|
js_filename: &str,
|
||||||
|
@ -380,8 +387,7 @@ impl JsRuntime {
|
||||||
///
|
///
|
||||||
/// `AnyError` can be downcast to a type that exposes additional information
|
/// `AnyError` can be downcast to a type that exposes additional information
|
||||||
/// about the V8 exception. By default this type is `JsError`, however it may
|
/// about the V8 exception. By default this type is `JsError`, however it may
|
||||||
/// be a different type if `JsRuntime::set_js_error_create_fn()` has been
|
/// be a different type if `RuntimeOptions::js_error_create_fn` has been set.
|
||||||
/// used.
|
|
||||||
pub fn snapshot(&mut self) -> v8::StartupData {
|
pub fn snapshot(&mut self) -> v8::StartupData {
|
||||||
assert!(self.snapshot_creator.is_some());
|
assert!(self.snapshot_creator.is_some());
|
||||||
let state = Self::state(self);
|
let state = Self::state(self);
|
||||||
|
@ -838,8 +844,7 @@ impl JsRuntime {
|
||||||
///
|
///
|
||||||
/// `AnyError` can be downcast to a type that exposes additional information
|
/// `AnyError` can be downcast to a type that exposes additional information
|
||||||
/// about the V8 exception. By default this type is `JsError`, however it may
|
/// about the V8 exception. By default this type is `JsError`, however it may
|
||||||
/// be a different type if `JsRuntime::set_js_error_create_fn()` has been
|
/// be a different type if `RuntimeOptions::js_error_create_fn` has been set.
|
||||||
/// used.
|
|
||||||
fn mod_instantiate(&mut self, id: ModuleId) -> Result<(), AnyError> {
|
fn mod_instantiate(&mut self, id: ModuleId) -> Result<(), AnyError> {
|
||||||
let state_rc = Self::state(self);
|
let state_rc = Self::state(self);
|
||||||
let state = state_rc.borrow();
|
let state = state_rc.borrow();
|
||||||
|
@ -875,8 +880,7 @@ impl JsRuntime {
|
||||||
///
|
///
|
||||||
/// `AnyError` can be downcast to a type that exposes additional information
|
/// `AnyError` can be downcast to a type that exposes additional information
|
||||||
/// about the V8 exception. By default this type is `JsError`, however it may
|
/// about the V8 exception. By default this type is `JsError`, however it may
|
||||||
/// be a different type if `JsRuntime::set_js_error_create_fn()` has been
|
/// be a different type if `RuntimeOptions::js_error_create_fn` has been set.
|
||||||
/// used.
|
|
||||||
pub fn mod_evaluate(&mut self, id: ModuleId) -> Result<(), AnyError> {
|
pub fn mod_evaluate(&mut self, id: ModuleId) -> Result<(), AnyError> {
|
||||||
self.shared_init();
|
self.shared_init();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue