From 1eb6e5cb4259c76be5a6e894434632e6dab8925f Mon Sep 17 00:00:00 2001 From: Attila Szegedi Date: Wed, 6 Aug 2014 10:42:46 +0200 Subject: [PATCH] 8044786: Some tests fail with non-optimistic compilation Reviewed-by: hannesw, jlaskey --- .../internal/objects/NativeUint8ClampedArray.java | 14 +++++++++++--- .../nashorn/internal/runtime/ScriptRuntime.java | 5 ++--- nashorn/test/script/basic/JDK-8030182_2.js | 2 +- .../test/script/basic/JDK-8030182_2.js.EXPECTED | 2 +- .../basic/optimistic_arithmetic_check_type.js | 1 + .../basic/optimistic_assignment_check_type.js | 1 + nashorn/test/script/basic/optimistic_check_type.js | 1 + nashorn/test/script/trusted/event_queue.js | 1 + .../script/trusted/optimistic_recompilation.js | 1 + 9 files changed, 20 insertions(+), 8 deletions(-) diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java b/nashorn/src/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java index 8e81924d3cf..db19ab37a59 100644 --- a/nashorn/src/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeUint8ClampedArray.java @@ -80,7 +80,8 @@ public final class NativeUint8ClampedArray extends ArrayBufferView { private static final MethodHandle GET_ELEM = specialCall(MethodHandles.lookup(), Uint8ClampedArrayData.class, "getElem", int.class, int.class).methodHandle(); private static final MethodHandle SET_ELEM = specialCall(MethodHandles.lookup(), Uint8ClampedArrayData.class, "setElem", void.class, int.class, int.class).methodHandle(); - private static final MethodHandle RINT = staticCall(MethodHandles.lookup(), Uint8ClampedArrayData.class, "rint", double.class, double.class).methodHandle(); + private static final MethodHandle RINT_D = staticCall(MethodHandles.lookup(), Uint8ClampedArrayData.class, "rint", double.class, double.class).methodHandle(); + private static final MethodHandle RINT_O = staticCall(MethodHandles.lookup(), Uint8ClampedArrayData.class, "rint", Object.class, Object.class).methodHandle(); private static final MethodHandle CLAMP_LONG = staticCall(MethodHandles.lookup(), Uint8ClampedArrayData.class, "clampLong", long.class, long.class).methodHandle(); private Uint8ClampedArrayData(final ByteBuffer nb, final int start, final int end) { @@ -109,8 +110,10 @@ public final class NativeUint8ClampedArray extends ArrayBufferView { public MethodHandle getElementSetter(final Class elementType) { final MethodHandle setter = super.getElementSetter(elementType); //getContinuousElementSetter(getClass(), setElem(), elementType); if (setter != null) { - if (elementType == double.class) { - return MH.filterArguments(setter, 2, RINT); + if (elementType == Object.class) { + return MH.filterArguments(setter, 2, RINT_O); + } else if (elementType == double.class) { + return MH.filterArguments(setter, 2, RINT_D); } else if (elementType == long.class) { return MH.filterArguments(setter, 2, CLAMP_LONG); } @@ -190,6 +193,11 @@ public final class NativeUint8ClampedArray extends ArrayBufferView { return (int)Math.rint(rint); } + @SuppressWarnings("unused") + private static Object rint(final Object rint) { + return rint(JSType.toNumber(rint)); + } + @SuppressWarnings("unused") private static long clampLong(final long l) { if(l < 0L) { diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java index a2516ba181f..d4350c5998a 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java @@ -818,9 +818,8 @@ public final class ScriptRuntime { /** ECMA 11.9.6 The Strict Equality Comparison Algorithm */ private static boolean strictEquals(final Object x, final Object y) { - if(x == y) { - return true; - } + // NOTE: you might be tempted to do a quick x == y comparison. Remember, though, that any Double object having + // NaN value is not equal to itself by value even though it is referentially. final JSType xType = JSType.ofNoFunction(x); final JSType yType = JSType.ofNoFunction(y); diff --git a/nashorn/test/script/basic/JDK-8030182_2.js b/nashorn/test/script/basic/JDK-8030182_2.js index 4c2f5c429f6..9ad8f31bae5 100644 --- a/nashorn/test/script/basic/JDK-8030182_2.js +++ b/nashorn/test/script/basic/JDK-8030182_2.js @@ -41,6 +41,6 @@ str +="g()"; try { eval(str); } catch (e) { - print(e.stack.replace(/\\/g, '/')); + print(e.stack.replace(/\\/g, '/').replace(/@[0-9]+/, '@')); } diff --git a/nashorn/test/script/basic/JDK-8030182_2.js.EXPECTED b/nashorn/test/script/basic/JDK-8030182_2.js.EXPECTED index 090bd1f1ab2..9fdd913f12d 100644 --- a/nashorn/test/script/basic/JDK-8030182_2.js.EXPECTED +++ b/nashorn/test/script/basic/JDK-8030182_2.js.EXPECTED @@ -1,3 +1,3 @@ ReferenceError: "g" is not defined - at (test/script/basic/JDK-8030182_2.js#42:4@1:-1) + at (test/script/basic/JDK-8030182_2.js#42:4@:-1) at (test/script/basic/JDK-8030182_2.js:42) diff --git a/nashorn/test/script/basic/optimistic_arithmetic_check_type.js b/nashorn/test/script/basic/optimistic_arithmetic_check_type.js index 66b1e361508..62ff301d0f0 100644 --- a/nashorn/test/script/basic/optimistic_arithmetic_check_type.js +++ b/nashorn/test/script/basic/optimistic_arithmetic_check_type.js @@ -25,6 +25,7 @@ * @test * @bug 8036987, 8037572 * @summary Implement tests that checks static types in the compiled code + * @option --optimistic-types=true * @run */ diff --git a/nashorn/test/script/basic/optimistic_assignment_check_type.js b/nashorn/test/script/basic/optimistic_assignment_check_type.js index 2665c18d9ba..7ead00d8448 100644 --- a/nashorn/test/script/basic/optimistic_assignment_check_type.js +++ b/nashorn/test/script/basic/optimistic_assignment_check_type.js @@ -25,6 +25,7 @@ * @test * @bug 8036987, 8037572 * @summary Implement tests that checks static types in the compiled code + * @option --optimistic-types=true * @run */ diff --git a/nashorn/test/script/basic/optimistic_check_type.js b/nashorn/test/script/basic/optimistic_check_type.js index 163244e817b..d2b50a4c3fb 100644 --- a/nashorn/test/script/basic/optimistic_check_type.js +++ b/nashorn/test/script/basic/optimistic_check_type.js @@ -25,6 +25,7 @@ * @test * @bug 8036987, 8037572 * @summary Implement tests that checks static types in the compiled code + * @option --optimistic-types=true * @run */ diff --git a/nashorn/test/script/trusted/event_queue.js b/nashorn/test/script/trusted/event_queue.js index 305240eff45..feecc201da5 100644 --- a/nashorn/test/script/trusted/event_queue.js +++ b/nashorn/test/script/trusted/event_queue.js @@ -29,6 +29,7 @@ * @fork * @option -Dnashorn.debug=true * @option --log=recompile:quiet + * @option --optimistic-types=true */ print(Debug); diff --git a/nashorn/test/script/trusted/optimistic_recompilation.js b/nashorn/test/script/trusted/optimistic_recompilation.js index 2435ed510f9..9c9a9c751b0 100644 --- a/nashorn/test/script/trusted/optimistic_recompilation.js +++ b/nashorn/test/script/trusted/optimistic_recompilation.js @@ -28,6 +28,7 @@ * @fork * @option -Dnashorn.debug=true * @option --log=recompile:quiet + * @option --optimistic-types=true */ var forName = java.lang.Class["forName(String)"];