1
0
Fork 0
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:
Bartek Iwańczuk 2020-09-15 03:23:48 +02:00 committed by GitHub
parent 9b8f1d9be8
commit 7023263b30
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 17 deletions

View file

@ -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();

View file

@ -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();