LibJS: Remove non-spec compliant code from internal_construct

It seems that we are now spec compliant enough to be able to remove this
code block :^)

Diff Tests:
    +2     -2 
This commit is contained in:
Shannon Booth 2024-05-26 20:10:23 +12:00 committed by Andreas Kling
parent 18d39deefe
commit f28bb90d9b
Notes: sideshowbarker 2024-07-16 19:17:47 +09:00
2 changed files with 26 additions and 9 deletions

View file

@ -506,15 +506,6 @@ ThrowCompletionOr<NonnullGCPtr<Object>> ECMAScriptFunctionObject::internal_const
// 10. If result.[[Type]] is return, then
if (result.type() == Completion::Type::Return) {
// FIXME: This is leftover from untangling the call/construct mess - doesn't belong here in any way, but removing it breaks derived classes.
// Likely fixed by making ClassDefinitionEvaluation fully spec compliant.
if (kind == ConstructorKind::Derived && result.value()->is_object()) {
auto prototype = TRY(new_target.get(vm.names.prototype));
if (prototype.is_object())
TRY(result.value()->as_object().internal_set_prototype_of(&prototype.as_object()));
}
// EOF (End of FIXME)
// a. If Type(result.[[Value]]) is Object, return result.[[Value]].
if (result.value()->is_object())
return result.value()->as_object();