var b: bool; class C {} // type checks assert(isInteger()); assert(!isInteger()); assert(isFloat()); assert(!isFloat()); assert(isReference()); assert(!isReference()); assert(isArray()); assert(!isArray()); assert(isArrayLike()); assert(isArrayLike()); assert(isArrayLike()); assert(!isArrayLike()); assert(isFunction<() => void>()); assert(!isFunction()); assert(isNullable()); assert(!isNullable()); assert(isInteger(1)); assert(!isInteger(1)); assert(isFloat(1)); assert(!isFloat(1)); assert(isReference(changetype(null))); assert(!isReference(changetype(null))); assert(isString("1")); assert(!isString(1)); assert(isArray(changetype(null))); assert(isArrayLike(changetype(null))); assert(isArrayLike(changetype(null))); assert(isArrayLike(changetype(null))); assert(!isArray(changetype(null))); assert(isFunction(changetype<() => void>(null))); assert(!isFunction(changetype(null))); assert(isNullable(changetype(null))); assert(!isNullable(changetype(null))); // evaluation assert(isDefined(b)); assert(!isDefined(c)); assert(isConstant(1)); assert(!isConstant(b)); // integers var i: i32; clz(1); ctz(1); popcnt(1); rotl(1, 1); rotr(1, 1); abs(-42); max(1, 2); min(1, 2); i = clz(1); i = ctz(1); i = popcnt(1); i = rotl(1, 1); i = rotr(1, 1); i = abs(-42); assert(i == 42); i = max(1, 2); assert(i == 2); i = min(1, 2); assert(i == 1); var I: i64; clz(1); ctz(1); popcnt(1); rotl(1, 1); rotr(1, 1); abs(-42); I = clz(1); I = ctz(1); I = popcnt(1); I = rotl(1, 1); I = rotr(1, 1); I = abs(-42); assert(I == 42); I = max(1, 2); assert(I == 2); I = min(1, 2); assert(i == 1); // floats var f: f32; NaN; Infinity; abs(1.25); ceil(1.25); copysign(1.25, 2.5); floor(1.25); max(1.25, 2.5); min(1.25, 2.5); nearest(1.25); sqrt(1.25); trunc(1.25); assert(isNaN(1.25) == false); assert(isNaN(NaN) == true); assert(isFinite(1.25) == true); assert(isFinite(Infinity) == false); assert(isFinite(-Infinity) == false); assert(isFinite(NaN) == false); f = NaN; f = Infinity; f = abs(1.25); f = ceil(1.25); f = copysign(1.25, 2.5); f = floor(1.25); f = max(1.25, 2.5); f = min(1.25, 2.5); f = nearest(1.25); f = sqrt(1.25); f = trunc(1.25); b = isNaN(1.25); b = isFinite(1.25); var F: f64; NaN; Infinity; NaN; Infinity; abs(1.25); ceil(1.25); copysign(1.25, 2.5); floor(1.25); max(1.25, 2.5); min(1.25, 2.5); nearest(1.25); sqrt(1.25); trunc(1.25); assert(isNaN(1.25) == false); assert(isNaN(NaN) == true); assert(isFinite(1.25) == true); assert(isFinite(Infinity) == false); assert(isFinite(-Infinity) == false); assert(isFinite(NaN) == false); F = NaN; F = Infinity; F = abs(1.25); F = ceil(1.25); F = copysign(1.25, 2.5); F = floor(1.25); F = max(1.25, 2.5); F = min(1.25, 2.5); F = nearest(1.25); F = sqrt(1.25); F = trunc(1.25); b = isNaN(1.25); b = isFinite(1.25); // load and store i = load(8); store(8, i); store(8, load(8)); I = load(8); store(8, I); store(8, load(8)); f = load(8); store(8, f); store(8, load(8)); F = load(8); store(8, F); store(8, load(8)); const constantOffset: usize = 8; i = load(0, constantOffset); store(0, i, constantOffset); store(0, load(0, constantOffset), constantOffset); I = load(0, constantOffset); store(0, I, constantOffset); store(0, load(0, constantOffset), constantOffset); f = load(0, constantOffset); store(0, f, constantOffset); store(0, load(0, constantOffset), constantOffset); F = load(0, constantOffset); store(0, F, constantOffset); store(0, load(0, constantOffset), constantOffset); // load and store smaller types i = load(8); i = load(8); i = load(8); i = load(8); i = load(8); i = load(8); var u: u32; u = load(8); u = load(8); u = load(8); u = load(8); u = load(8); u = load(8); I = load(8); I = load(8); I = load(8); I = load(8); var U: u64; U = load(8); U = load(8); U = load(8); U = load(8); store(8, 1); store(8, 1); store(8, 1); store(8, 1); store(8, 1); store(8, 1); store(8, 1); store(8, 1); // must extend // reinterpretation reinterpret(1.25); reinterpret(25); reinterpret(1.25); reinterpret(25); i = reinterpret(1.25); f = reinterpret(25); I = reinterpret(1.25); F = reinterpret(25); // host var s: usize; memory.size(); memory.grow(1); // also necessary for load/store tests below s = memory.size(); s = memory.grow(1); // other select(10, 20, true); select(100, 200, false); select(1.25, 2.5, true); select(12.5, 25.0, false); i = select(10, 20, true); I = select(100, 200, false); f = select(1.25, 2.5, true); F = select(12.5, 25.0, false); if (!i) unreachable(); var fn = function(a: i32, b: i32): void {}; call_indirect(fn, 1, 2); // AS specific assert(sizeof() == 1); assert(sizeof() == 2); assert(sizeof() == 4); assert(sizeof() == 8); sizeof(); assert(sizeof() == 1); assert(sizeof() == 1); assert(sizeof() == 2); assert(sizeof() == 4); assert(sizeof() == 8); sizeof(); assert(sizeof() == 4); assert(sizeof() == 8); assert(alignof() == 0); assert(alignof() == 1); assert(alignof() == 2); assert(alignof() == 3); assert(alignof() == 0); class Foo { a: T; b: T; } assert(offsetof>("a") == 0); assert(offsetof>("b") == 4); assert(offsetof>("a") == 0); assert(offsetof>("b") == 2); class Bar extends Foo {} assert(offsetof("a") == 0); assert(offsetof("b") == 8); assert(NaN != NaN); assert(isNaN(NaN)); assert(isNaN(NaN)); assert(!isFinite(NaN)); assert(!isFinite(Infinity)); assert(!isFinite(NaN)); assert(!isFinite(Infinity)); assert(isFinite(0)); assert(isFinite(0)); // imported export function test(): void { // cannot be interpreted // parseInt("01"); // parseInt("1", 10); // parseFloat("1.0"); } // limits assert(i8.MIN_VALUE == 0x80); assert(i8.MAX_VALUE == 0x7f); assert(i16.MIN_VALUE == 0x8000); assert(i16.MAX_VALUE == 0x7fff); assert(i32.MIN_VALUE == 0x80000000); assert(i32.MAX_VALUE == 0x7fffffff); assert(i64.MIN_VALUE == 0x8000000000000000); assert(i64.MAX_VALUE == 0x7fffffffffffffff); assert(u8.MIN_VALUE == 0); assert(u8.MAX_VALUE == 0xff); assert(u16.MIN_VALUE == 0); assert(u16.MAX_VALUE == 0xffff); assert(u32.MIN_VALUE == 0); assert(u32.MAX_VALUE == 0xffffffff); assert(u64.MIN_VALUE == 0); assert(u64.MAX_VALUE == 0xffffffffffffffff); assert(bool.MIN_VALUE == 0); assert(bool.MIN_VALUE == false); assert(bool.MAX_VALUE == 1); assert(bool.MAX_VALUE == true); assert(f32.MIN_NORMAL_VALUE == 1.1754943508222875e-38); assert(f32.MIN_VALUE == 1.401298464324817e-45); assert(f32.MAX_VALUE == 3.40282347e+38); assert(f32.MIN_SAFE_INTEGER == -16777215); assert(f32.MAX_SAFE_INTEGER == 16777215); assert(f32.EPSILON == 1.19209290e-07); assert(f64.MIN_NORMAL_VALUE == 2.2250738585072014e-308); assert(f64.MIN_VALUE == 5e-324); assert(f64.MAX_VALUE == 1.7976931348623157e+308); assert(f64.MIN_SAFE_INTEGER == -9007199254740991); assert(f64.MAX_SAFE_INTEGER == 9007199254740991); assert(f64.EPSILON == 2.2204460492503131e-16); // inline-assembler f32.abs(1.0); f64.abs(1.0); f32.ceil(1.0); f64.ceil(1.0); i32.clz(1); i64.clz(1); f32.copysign(1.0, 2.0); f64.copysign(1.0, 2.0); i32.ctz(1); i64.ctz(1); f32.floor(1.0); f64.floor(1.0); f32.nearest(1.0); f64.nearest(1.0); i32.popcnt(1); i64.popcnt(1); i32.load8_s(8); i32.load8_u(8); i32.load16_s(8); i32.load16_u(8); i32.load(8); i64.load8_s(8); i64.load8_u(8); i64.load16_s(8); i64.load16_u(8); i64.load32_s(8); i64.load32_u(8); i64.load(8); f32.load(8); f64.load(8); f32.max(1.0, 2.0); f64.max(1.0, 2.0); f32.min(1.0, 2.0); f64.min(1.0, 2.0); i32.reinterpret_f32(1.0); i64.reinterpret_f64(1.0); f32.reinterpret_i32(1); f64.reinterpret_i64(1); i32.rotl(1, 2); i64.rotl(1, 2); i32.rotr(1, 2); i64.rotr(1, 2); f32.sqrt(1.0); f64.sqrt(1.0); i32.store8(8, 1); i32.store16(8, 1); i32.store(8, 1); i64.store8(8, 1); i64.store16(8, 1); i64.store32(8, 1); i64.store(8, 1); f32.store(8, 1.0); f64.store(8, 1.0); f32.trunc(1.0); f64.trunc(1.0); // should be importable import { isNaN as isItNaN } from "builtins"; isItNaN(1);