| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- //-------------------------------------------------------------------------------------------------------
- // Copyright (C) Microsoft. All rights reserved.
- // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
- //-------------------------------------------------------------------------------------------------------
- function foo() {}
- var all = [ undefined, null,
- true, false, new Boolean(true), new Boolean(false),
- NaN, +0, -0, 0, 1, 10.0, 10.1, -1, -5, 5,
- 124, 248, 654, 987, -1026, +98768.2546, -88754.15478,
- 1<<32, -(1<<32), (1<<32)-1, 1<<31, -(1<<31), 1<<25, -1<<25,
- Number.MAX_VALUE, Number.MIN_VALUE, Number.NaN, Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY,
- new Number(NaN), new Number(+0), new Number( -0), new Number(0), new Number(1),
- new Number(10.0), new Number(10.1),
- new Number(Number.MAX_VALUE), new Number(Number.MIN_VALUE), new Number(Number.NaN),
- new Number(Number.POSITIVE_INFINITY), new Number(Number.NEGATIVE_INFINITY),
- "", "hello", "hel" + "lo", "+0", "-0", "0", "1", "10.0", "10.1",
- new String(""), new String("hello"), new String("he" + "llo"),
- new Object(), [1,2,3], new Object(), [1,2,3] , foo
- ];
- function AsmModule(stdlib) {
- "use asm";
- var fround = stdlib.Math.fround;
- function dbConvNot(y) {
- y = +y;
- var i = 0;
- i = ~((~~y)|0);
- return (!!i)|0;
- }
- function fltConvNot(y) {
- y = fround(y);
- var i = 0;
- i = ~((~~y)|0);
- return (!!i)|0;
- }
- return {
- dbConvNot : dbConvNot ,
- fltConvNot : fltConvNot ,
- };
- }
- var asmModule = AsmModule({Math:Math});
- for (var i=0; i<all.length; ++i) {
- print("i +a["+i+"](" + all[i] +") = " + (asmModule.dbConvNot(all[i])));
- print("i +a["+i+"](" + all[i] +") = " + (asmModule.fltConvNot(all[i])));
- }
|