Skip to content

Commit 96fa84b

Browse files
[GR-25198] Correctly handle foreign null this in non-strict functions.
PullRequest: js/1621
2 parents 105d85f + af15c10 commit 96fa84b

File tree

2 files changed

+89
-4
lines changed
  • graal-js/src
    • com.oracle.truffle.js.scriptengine.test/src/com/oracle/truffle/js/scriptengine/test
    • com.oracle.truffle.js/src/com/oracle/truffle/js/nodes/cast

2 files changed

+89
-4
lines changed
Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
1+
/*
2+
* Copyright (c) 2020, 2020, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* The Universal Permissive License (UPL), Version 1.0
6+
*
7+
* Subject to the condition set forth below, permission is hereby granted to any
8+
* person obtaining a copy of this software, associated documentation and/or
9+
* data (collectively the "Software"), free of charge and under any and all
10+
* copyright rights in the Software, and any and all patent rights owned or
11+
* freely licensable by each licensor hereunder covering either (i) the
12+
* unmodified Software as contributed to or provided by such licensor, or (ii)
13+
* the Larger Works (as defined below), to deal in both
14+
*
15+
* (a) the Software, and
16+
*
17+
* (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
18+
* one is included with the Software each a "Larger Work" to which the Software
19+
* is contributed by such licensors),
20+
*
21+
* without restriction, including without limitation the rights to copy, create
22+
* derivative works of, display, perform, and distribute the Software and make,
23+
* use, sell, offer for sale, import, export, have made, and have sold the
24+
* Software and the Larger Work(s), and to sublicense the foregoing rights on
25+
* either these or other terms.
26+
*
27+
* This license is subject to the following condition:
28+
*
29+
* The above copyright notice and either this complete permission notice or at a
30+
* minimum a reference to the UPL must be included in all copies or substantial
31+
* portions of the Software.
32+
*
33+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
39+
* SOFTWARE.
40+
*/
41+
package com.oracle.truffle.js.scriptengine.test;
42+
43+
import static org.junit.Assert.assertEquals;
44+
45+
import javax.script.Invocable;
46+
import javax.script.ScriptEngine;
47+
import javax.script.ScriptException;
48+
49+
import org.junit.Test;
50+
51+
import com.oracle.truffle.js.scriptengine.GraalJSScriptEngine;
52+
53+
public class GR25198 {
54+
55+
static void defineAlert(ScriptEngine engine) throws ScriptException {
56+
try {
57+
// @formatter:off
58+
Object defineAlert = engine.eval(""
59+
+ "(function(out) {\n"
60+
+ " this.alert = function(msg) {\n"
61+
+ " return msg;\n"
62+
+ " };"
63+
+ "});"
64+
);
65+
// @formatter:on
66+
((Invocable) engine).invokeMethod(defineAlert, "call", null, "out");
67+
assertEquals("red", ((Invocable) engine).invokeFunction("alert", "red"));
68+
} catch (NoSuchMethodException ex) {
69+
throw new ScriptException(ex);
70+
}
71+
}
72+
73+
@Test
74+
public void testNullThis() throws ScriptException {
75+
try (GraalJSScriptEngine engine = GraalJSScriptEngine.create(null, TestUtil.newContextBuilder())) {
76+
defineAlert(engine);
77+
}
78+
}
79+
}

graal-js/src/com.oracle.truffle.js/src/com/oracle/truffle/js/nodes/cast/JSPrepareThisNode.java

Lines changed: 10 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -40,9 +40,13 @@
4040
*/
4141
package com.oracle.truffle.js.nodes.cast;
4242

43+
import java.util.Set;
44+
4345
import com.oracle.truffle.api.dsl.Cached;
4446
import com.oracle.truffle.api.dsl.Specialization;
4547
import com.oracle.truffle.api.instrumentation.Tag;
48+
import com.oracle.truffle.api.interop.InteropLibrary;
49+
import com.oracle.truffle.api.library.CachedLibrary;
4650
import com.oracle.truffle.api.object.DynamicObject;
4751
import com.oracle.truffle.js.nodes.JavaScriptNode;
4852
import com.oracle.truffle.js.nodes.access.GlobalObjectNode;
@@ -58,8 +62,6 @@
5862
import com.oracle.truffle.js.runtime.builtins.JSSymbol;
5963
import com.oracle.truffle.js.runtime.objects.JSLazyString;
6064

61-
import java.util.Set;
62-
6365
/**
6466
* Implementation of ECMAScript 5.1, 10.4.3 Entering Function Code, for non-strict callees.
6567
*
@@ -136,8 +138,12 @@ protected DynamicObject doSymbol(Symbol value) {
136138
return JSSymbol.create(context, value);
137139
}
138140

139-
@Specialization(guards = "isForeignObject(object)")
140-
protected Object doForeignObject(Object object) {
141+
@Specialization(guards = "isForeignObject(object)", limit = "5")
142+
protected Object doForeignObject(Object object,
143+
@CachedLibrary("object") InteropLibrary interop) {
144+
if (interop.isNull(object)) {
145+
return GlobalObjectNode.getGlobalObject(context);
146+
}
141147
return object;
142148
}
143149

0 commit comments

Comments
 (0)