From 805f352d7761d05cf33c551f549fe4ff8678811e Mon Sep 17 00:00:00 2001 From: Minseok Choe Date: Thu, 22 Feb 2024 14:06:54 +0900 Subject: [PATCH] Fix Object.setPrototypeOf --- packages/core-js/internals/object-set-prototype-of.js | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/packages/core-js/internals/object-set-prototype-of.js b/packages/core-js/internals/object-set-prototype-of.js index b9663133632a..94fcf6c41548 100644 --- a/packages/core-js/internals/object-set-prototype-of.js +++ b/packages/core-js/internals/object-set-prototype-of.js @@ -1,7 +1,8 @@ 'use strict'; /* eslint-disable no-proto -- safe */ var uncurryThisAccessor = require('../internals/function-uncurry-this-accessor'); -var anObject = require('../internals/an-object'); +var isObject = require('../internals/is-object'); +var requireObjectCoercible = require('../internals/require-object-coercible'); var aPossiblePrototype = require('../internals/a-possible-prototype'); // `Object.setPrototypeOf` method @@ -18,8 +19,9 @@ module.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () { CORRECT_SETTER = test instanceof Array; } catch (error) { /* empty */ } return function setPrototypeOf(O, proto) { - anObject(O); + requireObjectCoercible(O); aPossiblePrototype(proto); + if (!isObject(O)) return O; if (CORRECT_SETTER) setter(O, proto); else O.__proto__ = proto; return O;