LibJS: Adding two values should convert them to primitives first

This commit is contained in:
Andreas Kling 2020-04-15 09:32:44 +02:00
parent 63499c2c9f
commit fa30355194
Notes: sideshowbarker 2024-07-19 07:35:21 +09:00
3 changed files with 26 additions and 3 deletions

View file

@ -100,6 +100,13 @@ bool Value::to_boolean() const
}
}
Value Value::to_primitive(Interpreter&) const
{
if (is_object())
return as_object().to_primitive();
return *this;
}
Object* Value::to_object(Heap& heap) const
{
if (is_object())
@ -256,10 +263,13 @@ Value right_shift(Interpreter&, Value lhs, Value rhs)
Value add(Interpreter& interpreter, Value lhs, Value rhs)
{
if (lhs.is_string() || rhs.is_string())
return js_string(interpreter.heap(), String::format("%s%s", lhs.to_string().characters(), rhs.to_string().characters()));
auto lhs_primitive = lhs.to_primitive(interpreter);
auto rhs_primitive = rhs.to_primitive(interpreter);
return Value(lhs.to_number().as_double() + rhs.to_number().as_double());
if (lhs_primitive.is_string() || rhs_primitive.is_string())
return js_string(interpreter.heap(), String::format("%s%s", lhs_primitive.to_string().characters(), rhs_primitive.to_string().characters()));
return Value(lhs_primitive.to_number().as_double() + rhs_primitive.to_number().as_double());
}
Value sub(Interpreter&, Value lhs, Value rhs)

View file

@ -147,6 +147,7 @@ public:
Value to_number() const;
i32 to_i32() const;
double to_double() const;
Value to_primitive(Interpreter&) const;
Object* to_object(Heap&) const;

View file

@ -0,0 +1,12 @@
load("test-common.js");
try {
// Note that these will give different results in the REPL due to parsing behavior.
assert([] + [] === "");
assert([] + {} === "[object Object]");
assert({} + {} === "[object Object][object Object]");
assert({} + [] === "[object Object]");
console.log("PASS");
} catch (e) {
console.log("FAIL: " + e);
}