be1a5f7551
I identified lots of asm.js tests that are actually not valid according to the spec, hence they execute in default-javascript-mode. This CL fixes most of them by adding additional type annotations. The atomic tests are totally non-spec-compliant by expecting a fourth argument, and infinite-loops-taken expects a function-type parameter, so I did not fix those. I also did not fix the regression tests. R=titzer@chromium.org, bradnelson@chromium.org BUG=v8:4203 Review-Url: https://codereview.chromium.org/2663243002 Cr-Commit-Position: refs/heads/master@{#43179}
39 lines
1.0 KiB
JavaScript
39 lines
1.0 KiB
JavaScript
// Copyright 2014 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.
|
|
|
|
function Module(stdlib) {
|
|
"use asm";
|
|
|
|
var floor = stdlib.Math.floor;
|
|
|
|
// f: double -> float
|
|
function f(a) {
|
|
a = +a
|
|
return +floor(a);
|
|
}
|
|
|
|
return { f: f };
|
|
}
|
|
|
|
var f = Module({ Math: Math }).f;
|
|
|
|
assertTrue(isNaN(f(NaN)));
|
|
assertTrue(isNaN(f(undefined)));
|
|
assertTrue(isNaN(f(function() {})));
|
|
|
|
assertEquals(0, f(0));
|
|
assertEquals(+0, f(+0));
|
|
assertEquals(-0, f(-0));
|
|
assertEquals(0, f(0.49999));
|
|
assertEquals(+0, f(0.6));
|
|
assertEquals(+0, f(0.5));
|
|
assertEquals(-1, f(-0.1));
|
|
assertEquals(-1, f(-0.5));
|
|
assertEquals(-1, f(-0.6));
|
|
assertEquals(-2, f(-1.6));
|
|
assertEquals(-1, f(-0.50001));
|
|
|
|
assertEquals("Infinity", String(f(Infinity)));
|
|
assertEquals("-Infinity", String(f(-Infinity)));
|