mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-21 12:05:15 +00:00
LibJS: Throw error in Object::to_string() if string conversion fails
This commit is contained in:
parent
95abcc3722
commit
2c6e7dbd07
Notes:
sideshowbarker
2024-07-19 07:11:05 +09:00
Author: https://github.com/linusg Commit: https://github.com/SerenityOS/serenity/commit/2c6e7dbd07f Pull-request: https://github.com/SerenityOS/serenity/pull/2020
2 changed files with 14 additions and 3 deletions
|
@ -360,7 +360,13 @@ Value Object::to_string() const
|
|||
&& to_string_property.is_object()
|
||||
&& to_string_property.as_object().is_function()) {
|
||||
auto& to_string_function = static_cast<Function&>(to_string_property.as_object());
|
||||
return const_cast<Object*>(this)->interpreter().call(to_string_function, const_cast<Object*>(this));
|
||||
auto& interpreter = const_cast<Object*>(this)->interpreter();
|
||||
auto string_value = interpreter.call(to_string_function, const_cast<Object*>(this));
|
||||
if (!string_value.is_string())
|
||||
interpreter.throw_exception<TypeError>("Cannot convert object to string");
|
||||
if (interpreter.exception())
|
||||
return {};
|
||||
return string_value;
|
||||
}
|
||||
return js_string(heap(), String::format("[object %s]", class_name()));
|
||||
}
|
||||
|
|
|
@ -69,8 +69,13 @@ String Value::to_string() const
|
|||
return String::format("%.4f", as_double());
|
||||
}
|
||||
|
||||
if (is_object())
|
||||
return as_object().to_primitive(Object::PreferredType::String).to_string();
|
||||
if (is_object()) {
|
||||
auto primitive_value = as_object().to_primitive(Object::PreferredType::String);
|
||||
// FIXME: Maybe we should pass in the Interpreter& and call interpreter.exception() instead?
|
||||
if (primitive_value.is_empty())
|
||||
return {};
|
||||
return primitive_value.to_string();
|
||||
}
|
||||
|
||||
if (is_string())
|
||||
return m_value.as_string->string();
|
||||
|
|
Loading…
Add table
Reference in a new issue