From a94d64b30857fab479e11672f7e24807adf2801f Mon Sep 17 00:00:00 2001 From: y21 <30553356+y21@users.noreply.github.com> Date: Tue, 29 Oct 2024 11:22:19 +0100 Subject: [PATCH] fix Object.defineProperty with symbols and fix some clippy warnings --- crates/dash_node_impl/src/events.rs | 22 ++++++++++------------ crates/dash_node_impl/src/lib.rs | 6 +++--- crates/dash_vm/src/js_std/object.rs | 8 +++++++- crates/dash_vm/src/lib.rs | 4 +--- 4 files changed, 21 insertions(+), 19 deletions(-) diff --git a/crates/dash_node_impl/src/events.rs b/crates/dash_node_impl/src/events.rs index 55772a9f..135d41a5 100644 --- a/crates/dash_node_impl/src/events.rs +++ b/crates/dash_node_impl/src/events.rs @@ -46,26 +46,26 @@ pub fn init_module(sc: &mut LocalScope<'_>) -> Result { let EventsState { event_emitter_prototype, event_emitter_constructor, - } = &State::from_vm(cx.scope).store[EventsKey]; + } = State::from_vm(cx.scope).store[EventsKey]; let emitter = EventEmitter { object: NamedObject::with_prototype_and_constructor( - event_emitter_prototype.clone(), - event_emitter_constructor.clone(), + event_emitter_prototype, + event_emitter_constructor, ), handlers: RefCell::new(FxHashMap::default()), }; Ok(cx.scope.register(emitter).into()) }), ); - event_emitter_ctor.set_fn_prototype(event_emitter_prototype.clone()); + event_emitter_ctor.set_fn_prototype(event_emitter_prototype); sc.register(event_emitter_ctor) }; State::from_vm_mut(sc).store.insert( EventsKey, EventsState { - event_emitter_constructor: event_emitter_ctor.clone(), + event_emitter_constructor: event_emitter_ctor, event_emitter_prototype, }, ); @@ -73,7 +73,7 @@ pub fn init_module(sc: &mut LocalScope<'_>) -> Result { event_emitter_ctor.set_property( sc, event_emitter_sym.into(), - PropertyValue::static_default(event_emitter_ctor.clone().into()), + PropertyValue::static_default(event_emitter_ctor.into()), )?; Ok(Value::object(event_emitter_ctor)) @@ -111,7 +111,7 @@ impl Object for EventEmitter { } fn on(cx: CallContext) -> Result { - let [name, cb] = &*cx.args else { + let [name, cb] = *cx.args else { throw!(cx.scope, Error, "expected an event name and callback function"); }; let name = name.to_js_string(cx.scope)?; @@ -123,8 +123,8 @@ fn on(cx: CallContext) -> Result { throw!(cx.scope, TypeError, "on can only be called on EventEmitter instances") }; match this.handlers.borrow_mut().entry(name.sym()) { - Entry::Occupied(mut entry) => entry.get_mut().push(cb.clone()), - Entry::Vacant(entry) => drop(entry.insert(vec![cb.clone()])), + Entry::Occupied(mut entry) => entry.get_mut().push(cb), + Entry::Vacant(entry) => drop(entry.insert(vec![cb])), }; Ok(cx.this) } @@ -141,9 +141,7 @@ fn emit(cx: CallContext) -> Result { let mut did_emit = false; if let Some(handlers) = this.handlers.borrow().get(&name.sym()) { for handler in handlers { - handler - .apply(cx.scope, cx.this.clone(), args.to_owned()) - .root_err(cx.scope)?; + handler.apply(cx.scope, cx.this, args.to_owned()).root_err(cx.scope)?; did_emit = true; } } diff --git a/crates/dash_node_impl/src/lib.rs b/crates/dash_node_impl/src/lib.rs index 9a0c15d6..d6577528 100644 --- a/crates/dash_node_impl/src/lib.rs +++ b/crates/dash_node_impl/src/lib.rs @@ -178,13 +178,13 @@ fn execute_node_module( })); let key = scope.intern("exports"); module - .set_property(scope, key.into(), PropertyValue::static_default(exports.clone())) + .set_property(scope, key.into(), PropertyValue::static_default(exports)) .unwrap(); global_state .ongoing_requires .borrow_mut() - .insert(file_path.to_owned(), module.clone()); + .insert(file_path.to_owned(), module); let mut code = String::from("(function(exports, module, require) {\n"); code += source; @@ -195,7 +195,7 @@ fn execute_node_module( Err(err) => return Err((err, code)), }; - fun.apply(scope, Value::undefined(), vec![exports, module.clone(), require]) + fun.apply(scope, Value::undefined(), vec![exports, module, require]) .map_err(|err| (EvalError::Exception(err), code))?; Ok(module) diff --git a/crates/dash_vm/src/js_std/object.rs b/crates/dash_vm/src/js_std/object.rs index 836f90f1..179cb847 100644 --- a/crates/dash_vm/src/js_std/object.rs +++ b/crates/dash_vm/src/js_std/object.rs @@ -138,7 +138,13 @@ pub fn define_property(cx: CallContext) -> Result { }; let property = match cx.args.get(1) { - Some(other) => PropertyKey::from(other.to_js_string(cx.scope)?), + Some(other) => { + if let ValueKind::Symbol(sym) = other.unpack() { + PropertyKey::Symbol(sym) + } else { + PropertyKey::from(other.to_js_string(cx.scope)?) + } + } _ => throw!(cx.scope, TypeError, "Property must be a string or symbol"), }; let descriptor = match cx.args.get(2).unpack() { diff --git a/crates/dash_vm/src/lib.rs b/crates/dash_vm/src/lib.rs index 5a8576fc..9992c708 100644 --- a/crates/dash_vm/src/lib.rs +++ b/crates/dash_vm/src/lib.rs @@ -1,6 +1,6 @@ #![cfg_attr(dash_lints, feature(register_tool))] #![cfg_attr(dash_lints, register_tool(dash_lints))] -#![allow(clippy::clone_on_copy)] // TODO: Requires large amounts of changes +#![allow(clippy::clone_on_copy, clippy::needless_borrow)] // TODO: Requires large amounts of changes #![warn(clippy::redundant_clone)] #![deny(clippy::disallowed_methods)] @@ -1476,11 +1476,9 @@ impl Vm { // All reachable roots are marked. debug!("rss before sweep: {}", self.alloc.rss()); - let before = self.alloc.rss(); let sweep = span!(Level::TRACE, "gc sweep"); sweep.in_scope(|| unsafe { self.alloc.sweep() }); debug!("rss after sweep: {}", self.alloc.rss()); - println!("[GC] {} -> {}", before, self.alloc.rss()); debug!("sweep interner"); self.interner.sweep();