// Copyright 2015 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // Flags: --allow-natives-syntax "use strict"; function test(expected, f) { %PrepareFunctionForOptimization(f); assertEquals(expected, f()); assertEquals(expected, f()); %OptimizeFunctionOnNextCall(f); assertEquals(expected, f()); assertEquals(expected, f()); } function testThrows(f) { %PrepareFunctionForOptimization(f); assertThrows(f); assertThrows(f); %OptimizeFunctionOnNextCall(f); assertThrows(f); assertThrows(f); } function f1() { return NaN; } test((0/0), f1); function f2() { return (0/0); } test((0/0), f2); function f3() { return (0/0) == (0/0); } test(false, f3); function f4() { return (0/0) == NaN; } test(false, f4); function f5() { return NaN == (0/0); } test(false, f5); function f6() { return "" + NaN; } test("NaN", f6); function f7() { return (0/0) === (0/0); } test(false, f7); function f8() { return (0/0) === NaN; } test(false, f8); function f9() { return NaN === (0/0); } test(false, f9); // ---- function g1() { return NaN; } test((0/0), g1); function g2() { return (0/0); } test((0/0), g2); function g3() { return (0/0) == (0/0); } test(false, g3); function g4() { return (0/0) == NaN; } test(false, g4); function g5() { return NaN == (0/0); } test(false, g5); function g6() { return "" + NaN; } test("NaN", g6); function g7() { return (0/0) === (0/0); } test(false, g7); function g8() { return (0/0) === NaN; } test(false, g8); function g9() { return NaN === (0/0); } test(false, g9); testThrows(function() { NaN = 111; }); function h1() { return NaN; } test((0/0), h1); function h2() { return (0/0); } test((0/0), h2); function h3() { return (0/0) == (0/0); } test(false, h3); function h4() { return (0/0) == NaN; } test(false, h4); function h5() { return NaN == (0/0); } test(false, h5); function h6() { return "" + NaN; } test("NaN", h6); function h7() { return (0/0) === (0/0); } test(false, h7); function h8() { return (0/0) === NaN; } test(false, h8); function h9() { return NaN === (0/0); } test(false, h9); // ------------- function k1() { return this.NaN; } testThrows(k1); function k2() { return (0/0); } test((0/0), k2); function k3() { return (0/0) == (0/0); } test(false, k3); function k4() { return (0/0) == this.NaN; } testThrows(k4); function k5() { return this.NaN == (0/0); } testThrows(k5); function k6() { return "" + this.NaN; } testThrows(k6); function k7() { return (0/0) === (0/0); } test(false, k7); function k8() { return (0/0) === this.NaN; } testThrows(k8); function k9() { return this.NaN === (0/0); } testThrows(k9);