소스 검색

LibJS: Add missing exception checks to Number() constructor

Linus Groh 4 년 전
부모
커밋
fba3c77a04
1개의 변경된 파일14개의 추가작업 그리고 3개의 파일을 삭제
  1. 14 3
      Userland/Libraries/LibJS/Runtime/NumberConstructor.cpp

+ 14 - 3
Userland/Libraries/LibJS/Runtime/NumberConstructor.cpp

@@ -84,15 +84,26 @@ static Value get_value_from_constructor_argument(GlobalObject& global_object)
 // 21.1.1.1 Number ( value ), https://tc39.es/ecma262/#sec-number-constructor-number-value
 Value NumberConstructor::call()
 {
-    return get_value_from_constructor_argument(global_object());
+    auto& vm = this->vm();
+    auto& global_object = this->global_object();
+
+    auto number = get_value_from_constructor_argument(global_object);
+    if (vm.exception())
+        return {};
+    return number;
 }
 
 // 21.1.1.1 Number ( value ), https://tc39.es/ecma262/#sec-number-constructor-number-value
 Value NumberConstructor::construct(Function&)
 {
-    auto number = get_value_from_constructor_argument(global_object());
+    auto& vm = this->vm();
+    auto& global_object = this->global_object();
+
+    auto number = get_value_from_constructor_argument(global_object);
+    if (vm.exception())
+        return {};
     // FIXME: Use OrdinaryCreateFromConstructor(NewTarget, "%Number.prototype%")
-    return NumberObject::create(global_object(), number.as_double());
+    return NumberObject::create(global_object, number.as_double());
 }
 
 // 21.1.2.2 Number.isFinite ( number ), https://tc39.es/ecma262/#sec-number.isfinite