LibJS: Allow null or undefined as a bound |this| value in strict mode

This commit is contained in:
Jack Karamanian 2020-06-02 21:26:35 -05:00 committed by Andreas Kling
parent 870bcaeef6
commit b0932b0aec
Notes: sideshowbarker 2024-07-19 05:52:28 +09:00
2 changed files with 12 additions and 9 deletions

View file

@ -57,7 +57,8 @@ BoundFunction* Function::bind(Value bound_this_value, Vector<Value> arguments)
switch (bound_this_value.type()) {
case Value::Type::Undefined:
case Value::Type::Null:
// FIXME: Null or undefined should be passed through in strict mode.
if (interpreter().in_strict_mode())
return bound_this_value;
return &interpreter().global_object();
default:
return bound_this_value.to_object(interpreter());

View file

@ -103,15 +103,17 @@ try {
assert(Make5() === 5);
assert(new Make5().valueOf() === 5);
// FIXME: Uncomment me when strict mode is implemented
// function strictIdentity() {
// return this;
// }
// Null or undefined should be passed through as a |this| value in strict mode.
(() => {
"use strict";
function strictIdentity() {
return this;
}
// assert(strictIdentity.bind()() === undefined);
// assert(strictIdentity.bind(null)() === null);
// assert(strictIdentity.bind(undefined)() === undefined);
// })();
assert(strictIdentity.bind()() === undefined);
assert(strictIdentity.bind(null)() === null);
assert(strictIdentity.bind(undefined)() === undefined);
})();
// Arrow functions can not have their |this| value set.
assert((() => this).bind("foo")() === globalThis)