ReadArrayView.js 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. //-------------------------------------------------------------------------------------------------------
  2. // Copyright (C) Microsoft. All rights reserved.
  3. // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information.
  4. //-------------------------------------------------------------------------------------------------------
  5. function foo() {}
  6. var all = [ undefined, null,
  7. true, false, new Boolean(true), new Boolean(false),
  8. NaN, +0, -0, 0, 1, 10.0, 10.1, -1, -5, 5,
  9. 124, 248, 654, 987, -1026, +98768.2546, -88754.15478,
  10. 1<<32, -(1<<32), (1<<32)-1, 1<<31, -(1<<31), 1<<25, -1<<25,
  11. Number.MAX_VALUE, Number.MIN_VALUE, Number.NaN, Number.POSITIVE_INFINITY, Number.NEGATIVE_INFINITY,
  12. new Number(NaN), new Number(+0), new Number( -0), new Number(0), new Number(1),
  13. new Number(10.0), new Number(10.1),
  14. new Number(Number.MAX_VALUE), new Number(Number.MIN_VALUE), new Number(Number.NaN),
  15. new Number(Number.POSITIVE_INFINITY), new Number(Number.NEGATIVE_INFINITY),
  16. "", "hello", "hel" + "lo", "+0", "-0", "0", "1", "10.0", "10.1",
  17. new String(""), new String("hello"), new String("he" + "llo"),
  18. new Object(), [1,2,3], new Object(), [1,2,3] , foo
  19. ];
  20. function AsmModule(stdlib,foreign,buffer) {
  21. "use asm";
  22. // numerical mutable variable
  23. var i1 = 0, d1 = 0.0, i2 = -5;
  24. // foreign imports
  25. var fi1 = foreign.i1|0;
  26. var fi2 = foreign.i2|0;
  27. var fd1 = +foreign.d1;
  28. var fd2 = +foreign.d2;
  29. var fun1 = foreign.fun1;
  30. var fun2 = foreign.fun2;
  31. var fround= stdlib.Math.fround;
  32. // stdlib immutable variable type double
  33. var sInf = stdlib.Infinity, sNaN = stdlib.NaN;
  34. // stdlib math (double) -> double
  35. var m1 = stdlib.Math.acos ;
  36. var m2 = stdlib.Math.asin ;
  37. var m3 = stdlib.Math.atan ;
  38. var m4 = stdlib.Math.cos ;
  39. var m5 = stdlib.Math.sin ;
  40. var m6 = stdlib.Math.tan ;
  41. var m7 = stdlib.Math.ceil ;
  42. var m8 = stdlib.Math.floor;
  43. var m9 = stdlib.Math.exp ;
  44. var m10 = stdlib.Math.log ;
  45. var m11 = stdlib.Math.sqrt ;
  46. // stdlib math (signed) -> signed ^ (doublish) -> double
  47. var m12 = stdlib.Math.abs;
  48. // stdlib math (doublish, doublish) -> double
  49. var m13 = stdlib.Math.atan2;
  50. var m34 = stdlib.Math.pow;
  51. // stdlib math (int,int) -> signed
  52. var m14 = stdlib.Math.imul;
  53. // stdlib math imm variable double
  54. var m15 = stdlib.Math.E;
  55. var m16 = stdlib.Math.LN10;
  56. var m17 = stdlib.Math.LN2;
  57. var m18 = stdlib.Math.LOG2E;
  58. var m19 = stdlib.Math.LOG10E;
  59. var m20 = stdlib.Math.PI;
  60. var m21 = stdlib.Math.SQRT1_2;
  61. var m22 = stdlib.Math.SQRT2;
  62. //views
  63. var HEAP8 =new stdlib.Int8Array(buffer);
  64. var HEAP16 =new stdlib.Int16Array(buffer);
  65. var HEAP32 =new stdlib.Int32Array(buffer);
  66. var HEAPU8 =new stdlib.Uint8Array(buffer);
  67. var HEAPU16=new stdlib.Uint16Array(buffer);
  68. var HEAPU32=new stdlib.Uint32Array(buffer);
  69. var HEAPF32=new stdlib.Float32Array(buffer);
  70. var HEAP64 =new stdlib.Float64Array(buffer);
  71. function read8 (x){x = x|0; return HEAP8 [x] |0; }
  72. function read16 (x){x = x|0; return HEAP16 [x>>1]|0; }
  73. function read32 (x){x = x|0; return HEAP32 [x>>2]|0; }
  74. function readU8 (x){x = x|0; return +((HEAPU8[x]) >>>0); }
  75. function readU16(x){x = x|0; return +((HEAPU16[x>>1])>>>0); }
  76. function readU32(x){x = x|0; return +((HEAPU32[x>>2])>>>0); }
  77. function readF32(x){x = x|0; return +HEAPF32[x>>2]; }
  78. function readF32f(x){x = x|0; return fround(HEAPF32[x>>2]); }
  79. function read64 (x){x = x|0; return +HEAP64 [x>>3]; }
  80. return {
  81. read8 : read8
  82. ,read16 : read16
  83. ,read32 : read32
  84. ,readU8 : readU8
  85. ,readU16 : readU16
  86. ,readU32 : readU32
  87. ,readF32 : readF32
  88. ,readF32f : readF32f
  89. ,read64 : read64
  90. };
  91. }
  92. var stdlib = {Math:Math,Int8Array:Int8Array,Int16Array:Int16Array,Int32Array:Int32Array,Uint8Array:Uint8Array,Uint16Array:Uint16Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array,Infinity:Infinity, NaN:NaN}
  93. var env = {fun1:function(x){print(x);}, fun2:function(x,y){print(x,y);},i1:155,i2:658,d1:68.25,d2:3.14156,f1:48.1523,f2:14896.2514}
  94. var buffer = new ArrayBuffer(1<<20);
  95. var HEAP8 =new stdlib.Int8Array(buffer);
  96. var HEAP16 =new stdlib.Int16Array(buffer);
  97. var HEAP32 =new stdlib.Int32Array(buffer);
  98. var HEAPU8 =new stdlib.Uint8Array(buffer);
  99. var HEAPU16=new stdlib.Uint16Array(buffer);
  100. var HEAPU32=new stdlib.Uint32Array(buffer);
  101. var HEAPF32=new stdlib.Float32Array(buffer);
  102. var HEAP64 =new stdlib.Float64Array(buffer);
  103. var asmModule = AsmModule(stdlib,env,buffer);
  104. for (var i=0; i<all.length; ++i) {
  105. var x = all[i]|0;
  106. for (var j=0; j<all.length; ++j) {
  107. var y = all[j];
  108. HEAP8 [x] = y|0;
  109. print("read8 HEAP8 ["+x+"] = all["+j+"]("+y+"); = " + (asmModule.read8 (x)));
  110. HEAP16 [x>>1]= y|0;
  111. print("read16 HEAP16 ["+x+"] = all["+j+"]("+y+"); = " + (asmModule.read16 (x)));
  112. HEAP32 [x>>2]= y|0;
  113. print("read32 HEAP32 ["+x+"] = all["+j+"]("+y+"); = " + (asmModule.read32 (x)));
  114. HEAPU8 [x] = y|0;
  115. print("readU8 HEAPU8 ["+x+"] = all["+j+"]("+y+"); = " + (asmModule.readU8 (x)));
  116. HEAPU16[x>>1]= y|0;
  117. print("readU16 HEAPU16["+x+"] = all["+j+"]("+y+"); = " + (asmModule.readU16 (x)));
  118. HEAPU32[x>>2]= y|0;
  119. print("readU32 HEAPU32["+x+"] = all["+j+"]("+y+"); = " + (asmModule.readU32 (x)));
  120. HEAPF32[x>>2]= +y;
  121. print("readF32 HEAPF32["+x+"] = all["+j+"]("+y+"); = " + (asmModule.readF32 (x)));
  122. print("readF32f HEAPF32["+x+"] = all["+j+"]("+y+"); = " + (asmModule.readF32f(x)));
  123. HEAP64 [x>>3]= +y;
  124. print("read64 HEAP64 ["+x+"] = all["+j+"]("+y+"); = " + (asmModule.read64 (x)));
  125. }
  126. }