From 5b84a1226b6f5493273351b8c44c39355bffd254 Mon Sep 17 00:00:00 2001 From: y21 <30553356+y21@users.noreply.github.com> Date: Mon, 18 Mar 2024 18:56:58 +0100 Subject: [PATCH] don't use `undefined` if `String` ctor is invoked with no arguments --- crates/dash_vm/src/js_std/string.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/crates/dash_vm/src/js_std/string.rs b/crates/dash_vm/src/js_std/string.rs index 6ac03a07..360888d8 100644 --- a/crates/dash_vm/src/js_std/string.rs +++ b/crates/dash_vm/src/js_std/string.rs @@ -1,3 +1,5 @@ +use dash_middle::interner::sym; + use crate::localscope::LocalScope; use crate::throw; use crate::value::array::{Array, ArrayIterator}; @@ -9,7 +11,10 @@ use crate::value::{Value, ValueContext}; use std::fmt::Write; pub fn constructor(cx: CallContext) -> Result { - let value = cx.args.first().unwrap_or_undefined().to_js_string(cx.scope)?; + let value = match cx.args.first() { + Some(arg) => arg.to_js_string(cx.scope)?, + None => sym::empty.into(), + }; if cx.is_constructor_call { let boxed = BoxedString::new(cx.scope, value); Ok(Value::Object(cx.scope.register(boxed)))