assemblyscript/tests/compiler/std/set.untouched.wat

10896 lines
186 KiB
Plaintext

(module
(type $v (func))
(type $ii (func (param i32) (result i32)))
(type $i (func (result i32)))
(type $iv (func (param i32)))
(type $iiii (func (param i32 i32 i32) (result i32)))
(type $iiiiv (func (param i32 i32 i32 i32)))
(type $iiiv (func (param i32 i32 i32)))
(type $iii (func (param i32 i32) (result i32)))
(type $iiv (func (param i32 i32)))
(type $iIi (func (param i32 i64) (result i32)))
(type $Ii (func (param i64) (result i32)))
(type $iIii (func (param i32 i64 i32) (result i32)))
(type $iIv (func (param i32 i64)))
(type $ifi (func (param i32 f32) (result i32)))
(type $fi (func (param f32) (result i32)))
(type $ifii (func (param i32 f32 i32) (result i32)))
(type $ifv (func (param i32 f32)))
(type $iFi (func (param i32 f64) (result i32)))
(type $Fi (func (param f64) (result i32)))
(type $iFii (func (param i32 f64 i32) (result i32)))
(type $iFv (func (param i32 f64)))
(import "env" "abort" (func $~lib/env/abort (param i32 i32 i32 i32)))
(global $~lib/internal/allocator/AL_BITS i32 (i32.const 3))
(global $~lib/internal/allocator/AL_SIZE i32 (i32.const 8))
(global $~lib/internal/allocator/AL_MASK i32 (i32.const 7))
(global $~lib/internal/allocator/MAX_SIZE_32 i32 (i32.const 1073741824))
(global $~lib/allocator/arena/startOffset (mut i32) (i32.const 0))
(global $~lib/allocator/arena/offset (mut i32) (i32.const 0))
(global $~lib/set/INITIAL_CAPACITY i32 (i32.const 4))
(global $~lib/set/BUCKET_SIZE i32 (i32.const 4))
(global $~lib/internal/arraybuffer/HEADER_SIZE i32 (i32.const 8))
(global $~lib/internal/arraybuffer/MAX_BLENGTH i32 (i32.const 1073741816))
(global $~lib/internal/hash/FNV_OFFSET i32 (i32.const -2128831035))
(global $~lib/internal/hash/FNV_PRIME i32 (i32.const 16777619))
(global $~lib/set/EMPTY i32 (i32.const 1))
(global $~lib/set/FREE_FACTOR f64 (f64.const 0.75))
(global $~lib/set/FILL_FACTOR f64 (f64.const 2.6666666666666665))
(global $HEAP_BASE i32 (i32.const 136))
(memory $0 1)
(data (i32.const 8) "\13\00\00\00~\00l\00i\00b\00/\00a\00r\00r\00a\00y\00b\00u\00f\00f\00e\00r\00.\00t\00s\00")
(data (i32.const 52) "\1c\00\00\00~\00l\00i\00b\00/\00i\00n\00t\00e\00r\00n\00a\00l\00/\00a\00r\00r\00a\00y\00b\00u\00f\00f\00e\00r\00.\00t\00s\00")
(data (i32.const 112) "\n\00\00\00s\00t\00d\00/\00s\00e\00t\00.\00t\00s\00")
(export "memory" (memory $0))
(start $start)
(func $~lib/memory/memory.size (; 1 ;) (type $i) (result i32)
(current_memory)
)
(func $~lib/memory/memory.grow (; 2 ;) (type $ii) (param $0 i32) (result i32)
(grow_memory
(get_local $0)
)
)
(func $~lib/allocator/arena/__memory_allocate (; 3 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(if
(get_local $0)
(block
(if
(i32.gt_u
(get_local $0)
(get_global $~lib/internal/allocator/MAX_SIZE_32)
)
(unreachable)
)
(set_local $1
(get_global $~lib/allocator/arena/offset)
)
(set_local $2
(i32.and
(i32.add
(i32.add
(get_local $1)
(get_local $0)
)
(get_global $~lib/internal/allocator/AL_MASK)
)
(i32.xor
(get_global $~lib/internal/allocator/AL_MASK)
(i32.const -1)
)
)
)
(set_local $3
(call $~lib/memory/memory.size)
)
(if
(i32.gt_u
(get_local $2)
(i32.shl
(get_local $3)
(i32.const 16)
)
)
(block
(set_local $4
(i32.shr_u
(i32.and
(i32.add
(i32.sub
(get_local $2)
(get_local $1)
)
(i32.const 65535)
)
(i32.xor
(i32.const 65535)
(i32.const -1)
)
)
(i32.const 16)
)
)
(set_local $5
(select
(tee_local $5
(get_local $3)
)
(tee_local $6
(get_local $4)
)
(i32.gt_s
(get_local $5)
(get_local $6)
)
)
)
(if
(i32.lt_s
(call $~lib/memory/memory.grow
(get_local $5)
)
(i32.const 0)
)
(if
(i32.lt_s
(call $~lib/memory/memory.grow
(get_local $4)
)
(i32.const 0)
)
(unreachable)
)
)
)
)
(set_global $~lib/allocator/arena/offset
(get_local $2)
)
(return
(get_local $1)
)
)
)
(i32.const 0)
)
(func $~lib/memory/memory.allocate (; 4 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/allocator/arena/__memory_allocate
(get_local $0)
)
)
)
(func $~lib/internal/arraybuffer/computeSize (; 5 ;) (type $ii) (param $0 i32) (result i32)
(i32.shl
(i32.const 1)
(i32.sub
(i32.const 32)
(i32.clz
(i32.sub
(i32.add
(get_local $0)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.const 1)
)
)
)
)
)
(func $~lib/internal/arraybuffer/allocUnsafe (; 6 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(if
(i32.eqz
(i32.le_u
(get_local $0)
(get_global $~lib/internal/arraybuffer/MAX_BLENGTH)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 52)
(i32.const 22)
(i32.const 2)
)
(unreachable)
)
)
(set_local $1
(call $~lib/memory/memory.allocate
(call $~lib/internal/arraybuffer/computeSize
(get_local $0)
)
)
)
(i32.store
(get_local $1)
(get_local $0)
)
(get_local $1)
)
(func $~lib/memory/memset (; 7 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i64)
(if
(i32.eqz
(get_local $2)
)
(return)
)
(i32.store8
(get_local $0)
(get_local $1)
)
(i32.store8
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 1)
)
(get_local $1)
)
(if
(i32.le_u
(get_local $2)
(i32.const 2)
)
(return)
)
(i32.store8
(i32.add
(get_local $0)
(i32.const 1)
)
(get_local $1)
)
(i32.store8
(i32.add
(get_local $0)
(i32.const 2)
)
(get_local $1)
)
(i32.store8
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 2)
)
(get_local $1)
)
(i32.store8
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 3)
)
(get_local $1)
)
(if
(i32.le_u
(get_local $2)
(i32.const 6)
)
(return)
)
(i32.store8
(i32.add
(get_local $0)
(i32.const 3)
)
(get_local $1)
)
(i32.store8
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 4)
)
(get_local $1)
)
(if
(i32.le_u
(get_local $2)
(i32.const 8)
)
(return)
)
(set_local $3
(i32.and
(i32.sub
(i32.const 0)
(get_local $0)
)
(i32.const 3)
)
)
(set_local $0
(i32.add
(get_local $0)
(get_local $3)
)
)
(set_local $2
(i32.sub
(get_local $2)
(get_local $3)
)
)
(set_local $2
(i32.and
(get_local $2)
(i32.const -4)
)
)
(set_local $4
(i32.mul
(i32.div_u
(i32.const -1)
(i32.const 255)
)
(i32.and
(get_local $1)
(i32.const 255)
)
)
)
(i32.store
(get_local $0)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 4)
)
(get_local $4)
)
(if
(i32.le_u
(get_local $2)
(i32.const 8)
)
(return)
)
(i32.store
(i32.add
(get_local $0)
(i32.const 4)
)
(get_local $4)
)
(i32.store
(i32.add
(get_local $0)
(i32.const 8)
)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 12)
)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 8)
)
(get_local $4)
)
(if
(i32.le_u
(get_local $2)
(i32.const 24)
)
(return)
)
(i32.store
(i32.add
(get_local $0)
(i32.const 12)
)
(get_local $4)
)
(i32.store
(i32.add
(get_local $0)
(i32.const 16)
)
(get_local $4)
)
(i32.store
(i32.add
(get_local $0)
(i32.const 20)
)
(get_local $4)
)
(i32.store
(i32.add
(get_local $0)
(i32.const 24)
)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 28)
)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 24)
)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 20)
)
(get_local $4)
)
(i32.store
(i32.sub
(i32.add
(get_local $0)
(get_local $2)
)
(i32.const 16)
)
(get_local $4)
)
(set_local $3
(i32.add
(i32.const 24)
(i32.and
(get_local $0)
(i32.const 4)
)
)
)
(set_local $0
(i32.add
(get_local $0)
(get_local $3)
)
)
(set_local $2
(i32.sub
(get_local $2)
(get_local $3)
)
)
(set_local $5
(i64.or
(i64.extend_u/i32
(get_local $4)
)
(i64.shl
(i64.extend_u/i32
(get_local $4)
)
(i64.const 32)
)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ge_u
(get_local $2)
(i32.const 32)
)
(block
(block
(i64.store
(get_local $0)
(get_local $5)
)
(i64.store
(i32.add
(get_local $0)
(i32.const 8)
)
(get_local $5)
)
(i64.store
(i32.add
(get_local $0)
(i32.const 16)
)
(get_local $5)
)
(i64.store
(i32.add
(get_local $0)
(i32.const 24)
)
(get_local $5)
)
(set_local $2
(i32.sub
(get_local $2)
(i32.const 32)
)
)
(set_local $0
(i32.add
(get_local $0)
(i32.const 32)
)
)
)
(br $continue|0)
)
)
)
)
)
(func $~lib/memory/memory.fill (; 8 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(call $~lib/memory/memset
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(func $~lib/arraybuffer/ArrayBuffer#constructor (; 9 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(if
(i32.gt_u
(get_local $1)
(get_global $~lib/internal/arraybuffer/MAX_BLENGTH)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 13)
(i32.const 40)
)
(unreachable)
)
)
(set_local $3
(call $~lib/internal/arraybuffer/allocUnsafe
(get_local $1)
)
)
(if
(i32.eqz
(i32.and
(get_local $2)
(i32.const 1)
)
)
(call $~lib/memory/memory.fill
(i32.add
(get_local $3)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.const 0)
(get_local $1)
)
)
(get_local $3)
)
(func $~lib/set/Set<i8>#clear (; 10 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<i8>#constructor (; 11 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<i8>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash8 (; 12 ;) (type $ii) (param $0 i32) (result i32)
(i32.mul
(i32.xor
(get_global $~lib/internal/hash/FNV_OFFSET)
(get_local $0)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(func $~lib/internal/hash/hash<i8> (; 13 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/internal/hash/hash8
(i32.shr_s
(i32.shl
(get_local $0)
(i32.const 24)
)
(i32.const 24)
)
)
)
)
(func $~lib/set/Set<i8>#find (; 14 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i32.eq
(i32.load8_s
(get_local $3)
)
(i32.shr_s
(i32.shl
(get_local $1)
(i32.const 24)
)
(i32.const 24)
)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<i8>#has (; 15 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(i32.ne
(call $~lib/set/Set<i8>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<i8>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<i8>#rehash (; 16 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i32)
(local $12 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<i8>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<i8>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i32.store8
(get_local $10)
(i32.load8_s
(get_local $9)
)
)
(set_local $11
(i32.and
(block $~lib/internal/hash/hash<i8>|inlined.0 (result i32)
(set_local $11
(i32.load8_s
(get_local $9)
)
)
(br $~lib/internal/hash/hash<i8>|inlined.0
(call $~lib/internal/hash/hash8
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $12
(i32.add
(get_local $3)
(i32.mul
(get_local $11)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $12)
)
)
(i32.store offset=8
(get_local $12)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<i8>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<i8>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<i8>#add (; 17 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<i8>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<i8>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<i8>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<i8>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(i32.store8
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<i8>#get:size (; 18 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<i8>#delete (; 19 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<i8>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<i8>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<i8>|inlined.1
(call $~lib/internal/hash/hash8
(i32.shr_s
(i32.shl
(get_local $1)
(i32.const 24)
)
(i32.const 24)
)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<i8>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<i8> (; 20 ;) (type $v)
(local $0 i32)
(local $1 i32)
(set_local $0
(call $~lib/set/Set<i8>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i8>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i8>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i8>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i8>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i8>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i8>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i8>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i8>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i8>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<i8>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i8>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<u8>#clear (; 21 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<u8>#constructor (; 22 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<u8>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash<u8> (; 23 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/internal/hash/hash8
(i32.and
(get_local $0)
(i32.const 255)
)
)
)
)
(func $~lib/set/Set<u8>#find (; 24 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i32.eq
(i32.load8_u
(get_local $3)
)
(i32.and
(get_local $1)
(i32.const 255)
)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<u8>#has (; 25 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(i32.ne
(call $~lib/set/Set<u8>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<u8>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<u8>#rehash (; 26 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i32)
(local $12 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<u8>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<u8>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i32.store8
(get_local $10)
(i32.load8_u
(get_local $9)
)
)
(set_local $11
(i32.and
(block $~lib/internal/hash/hash<u8>|inlined.0 (result i32)
(set_local $11
(i32.load8_u
(get_local $9)
)
)
(br $~lib/internal/hash/hash<u8>|inlined.0
(call $~lib/internal/hash/hash8
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $12
(i32.add
(get_local $3)
(i32.mul
(get_local $11)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $12)
)
)
(i32.store offset=8
(get_local $12)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<u8>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<u8>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<u8>#add (; 27 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<u8>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<u8>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<u8>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<u8>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(i32.store8
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<u8>#get:size (; 28 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<u8>#delete (; 29 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<u8>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<u8>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<u8>|inlined.1
(call $~lib/internal/hash/hash8
(i32.and
(get_local $1)
(i32.const 255)
)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<u8>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<u8> (; 30 ;) (type $v)
(local $0 i32)
(local $1 i32)
(set_local $0
(call $~lib/set/Set<u8>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u8>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u8>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u8>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u8>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u8>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u8>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u8>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u8>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u8>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u8>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<u8>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u8>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<i16>#clear (; 31 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<i16>#constructor (; 32 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<i16>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash16 (; 33 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(set_local $1
(get_global $~lib/internal/hash/FNV_OFFSET)
)
(set_local $1
(i32.mul
(i32.xor
(get_local $1)
(i32.and
(get_local $0)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $1
(i32.mul
(i32.xor
(get_local $1)
(i32.shr_u
(get_local $0)
(i32.const 8)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(get_local $1)
)
(func $~lib/internal/hash/hash<i16> (; 34 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/internal/hash/hash16
(i32.shr_s
(i32.shl
(get_local $0)
(i32.const 16)
)
(i32.const 16)
)
)
)
)
(func $~lib/set/Set<i16>#find (; 35 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i32.eq
(i32.load16_s
(get_local $3)
)
(i32.shr_s
(i32.shl
(get_local $1)
(i32.const 16)
)
(i32.const 16)
)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<i16>#has (; 36 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(i32.ne
(call $~lib/set/Set<i16>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<i16>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<i16>#rehash (; 37 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i32)
(local $12 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<i16>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<i16>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i32.store16
(get_local $10)
(i32.load16_s
(get_local $9)
)
)
(set_local $11
(i32.and
(block $~lib/internal/hash/hash<i16>|inlined.0 (result i32)
(set_local $11
(i32.load16_s
(get_local $9)
)
)
(br $~lib/internal/hash/hash<i16>|inlined.0
(call $~lib/internal/hash/hash16
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $12
(i32.add
(get_local $3)
(i32.mul
(get_local $11)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $12)
)
)
(i32.store offset=8
(get_local $12)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<i16>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<i16>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<i16>#add (; 38 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<i16>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<i16>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<i16>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<i16>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(i32.store16
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<i16>#get:size (; 39 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<i16>#delete (; 40 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<i16>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<i16>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<i16>|inlined.1
(call $~lib/internal/hash/hash16
(i32.shr_s
(i32.shl
(get_local $1)
(i32.const 16)
)
(i32.const 16)
)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<i16>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<i16> (; 41 ;) (type $v)
(local $0 i32)
(local $1 i32)
(set_local $0
(call $~lib/set/Set<i16>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i16>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i16>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i16>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i16>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i16>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i16>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i16>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i16>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i16>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<i16>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i16>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<u16>#clear (; 42 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<u16>#constructor (; 43 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<u16>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash<u16> (; 44 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/internal/hash/hash16
(i32.and
(get_local $0)
(i32.const 65535)
)
)
)
)
(func $~lib/set/Set<u16>#find (; 45 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i32.eq
(i32.load16_u
(get_local $3)
)
(i32.and
(get_local $1)
(i32.const 65535)
)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<u16>#has (; 46 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(i32.ne
(call $~lib/set/Set<u16>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<u16>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<u16>#rehash (; 47 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i32)
(local $12 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<u16>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<u16>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i32.store16
(get_local $10)
(i32.load16_u
(get_local $9)
)
)
(set_local $11
(i32.and
(block $~lib/internal/hash/hash<u16>|inlined.0 (result i32)
(set_local $11
(i32.load16_u
(get_local $9)
)
)
(br $~lib/internal/hash/hash<u16>|inlined.0
(call $~lib/internal/hash/hash16
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $12
(i32.add
(get_local $3)
(i32.mul
(get_local $11)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $12)
)
)
(i32.store offset=8
(get_local $12)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<u16>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<u16>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<u16>#add (; 48 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<u16>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<u16>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<u16>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<u16>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(i32.store16
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<u16>#get:size (; 49 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<u16>#delete (; 50 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<u16>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<u16>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<u16>|inlined.1
(call $~lib/internal/hash/hash16
(i32.and
(get_local $1)
(i32.const 65535)
)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<u16>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<u16> (; 51 ;) (type $v)
(local $0 i32)
(local $1 i32)
(set_local $0
(call $~lib/set/Set<u16>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u16>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u16>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u16>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u16>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u16>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u16>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u16>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u16>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u16>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u16>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<u16>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u16>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<i32>#clear (; 52 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<i32>#constructor (; 53 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<i32>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash32 (; 54 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(set_local $1
(get_global $~lib/internal/hash/FNV_OFFSET)
)
(set_local $1
(i32.mul
(i32.xor
(get_local $1)
(i32.and
(get_local $0)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $1
(i32.mul
(i32.xor
(get_local $1)
(i32.and
(i32.shr_u
(get_local $0)
(i32.const 8)
)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $1
(i32.mul
(i32.xor
(get_local $1)
(i32.and
(i32.shr_u
(get_local $0)
(i32.const 16)
)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $1
(i32.mul
(i32.xor
(get_local $1)
(i32.shr_u
(get_local $0)
(i32.const 24)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(get_local $1)
)
(func $~lib/internal/hash/hash<i32> (; 55 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/internal/hash/hash32
(get_local $0)
)
)
)
(func $~lib/set/Set<i32>#find (; 56 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i32.eq
(i32.load
(get_local $3)
)
(get_local $1)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<i32>#has (; 57 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(i32.ne
(call $~lib/set/Set<i32>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<i32>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<i32>#rehash (; 58 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i32)
(local $12 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<i32>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<i32>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i32.store
(get_local $10)
(i32.load
(get_local $9)
)
)
(set_local $11
(i32.and
(block $~lib/internal/hash/hash<i32>|inlined.0 (result i32)
(set_local $11
(i32.load
(get_local $9)
)
)
(br $~lib/internal/hash/hash<i32>|inlined.0
(call $~lib/internal/hash/hash32
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $12
(i32.add
(get_local $3)
(i32.mul
(get_local $11)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $12)
)
)
(i32.store offset=8
(get_local $12)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<i32>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<i32>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<i32>#add (; 59 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<i32>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<i32>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<i32>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<i32>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(i32.store
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<i32>#get:size (; 60 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<i32>#delete (; 61 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<i32>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<i32>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<i32>|inlined.1
(call $~lib/internal/hash/hash32
(get_local $1)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<i32>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<i32> (; 62 ;) (type $v)
(local $0 i32)
(local $1 i32)
(set_local $0
(call $~lib/set/Set<i32>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i32>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i32>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i32>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i32>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i32.lt_s
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i32>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i32>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<i32>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i32>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<u32>#clear (; 63 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<u32>#constructor (; 64 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<u32>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash<u32> (; 65 ;) (type $ii) (param $0 i32) (result i32)
(return
(call $~lib/internal/hash/hash32
(get_local $0)
)
)
)
(func $~lib/set/Set<u32>#find (; 66 ;) (type $iiii) (param $0 i32) (param $1 i32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i32.eq
(i32.load
(get_local $3)
)
(get_local $1)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<u32>#has (; 67 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(i32.ne
(call $~lib/set/Set<u32>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<u32>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<u32>#rehash (; 68 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i32)
(local $12 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<u32>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<u32>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i32.store
(get_local $10)
(i32.load
(get_local $9)
)
)
(set_local $11
(i32.and
(block $~lib/internal/hash/hash<u32>|inlined.0 (result i32)
(set_local $11
(i32.load
(get_local $9)
)
)
(br $~lib/internal/hash/hash<u32>|inlined.0
(call $~lib/internal/hash/hash32
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $12
(i32.add
(get_local $3)
(i32.mul
(get_local $11)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $12)
)
)
(i32.store offset=8
(get_local $12)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<u32>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<u32>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<u32>#add (; 69 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<u32>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<u32>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<u32>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<u32>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(i32.store
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<u32>#get:size (; 70 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<u32>#delete (; 71 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<u32>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<u32>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<u32>|inlined.1
(call $~lib/internal/hash/hash32
(get_local $1)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<u32>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<u32> (; 72 ;) (type $v)
(local $0 i32)
(local $1 i32)
(set_local $0
(call $~lib/set/Set<u32>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u32>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u32>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u32>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u32>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i32.lt_u
(get_local $1)
(i32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u32>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i32.add
(get_local $1)
(i32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u32>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<u32>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u32>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<i64>#clear (; 73 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 64)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<i64>#constructor (; 74 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<i64>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash64 (; 75 ;) (type $Ii) (param $0 i64) (result i32)
(local $1 i32)
(local $2 i32)
(local $3 i32)
(set_local $1
(i32.wrap/i64
(get_local $0)
)
)
(set_local $2
(i32.wrap/i64
(i64.shr_u
(get_local $0)
(i64.const 32)
)
)
)
(set_local $3
(get_global $~lib/internal/hash/FNV_OFFSET)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.and
(get_local $1)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.and
(i32.shr_u
(get_local $1)
(i32.const 8)
)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.and
(i32.shr_u
(get_local $1)
(i32.const 16)
)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.shr_u
(get_local $1)
(i32.const 24)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.and
(get_local $2)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.and
(i32.shr_u
(get_local $2)
(i32.const 8)
)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.and
(i32.shr_u
(get_local $2)
(i32.const 16)
)
(i32.const 255)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(set_local $3
(i32.mul
(i32.xor
(get_local $3)
(i32.shr_u
(get_local $2)
(i32.const 24)
)
)
(get_global $~lib/internal/hash/FNV_PRIME)
)
)
(get_local $3)
)
(func $~lib/internal/hash/hash<i64> (; 76 ;) (type $Ii) (param $0 i64) (result i32)
(return
(call $~lib/internal/hash/hash64
(get_local $0)
)
)
)
(func $~lib/set/Set<i64>#find (; 77 ;) (type $iIii) (param $0 i32) (param $1 i64) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=8
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i64.eq
(i64.load
(get_local $3)
)
(get_local $1)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=8
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<i64>#has (; 78 ;) (type $iIi) (param $0 i32) (param $1 i64) (result i32)
(i32.ne
(call $~lib/set/Set<i64>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<i64>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<i64>#rehash (; 79 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i64)
(local $12 i32)
(local $13 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<i64>|inlined.1 (result i32)
(i32.const 16)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<i64>|inlined.2 (result i32)
(i32.const 16)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=8
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i64.store
(get_local $10)
(i64.load
(get_local $9)
)
)
(set_local $12
(i32.and
(block $~lib/internal/hash/hash<i64>|inlined.0 (result i32)
(set_local $11
(i64.load
(get_local $9)
)
)
(br $~lib/internal/hash/hash<i64>|inlined.0
(call $~lib/internal/hash/hash64
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $13
(i32.add
(get_local $3)
(i32.mul
(get_local $12)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=8
(get_local $10)
(i32.load offset=8
(get_local $13)
)
)
(i32.store offset=8
(get_local $13)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<i64>|inlined.3 (result i32)
(i32.const 16)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<i64>|inlined.4 (result i32)
(i32.const 16)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<i64>#add (; 80 ;) (type $iIv) (param $0 i32) (param $1 i64)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<i64>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<i64>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<i64>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<i64>|inlined.5 (result i32)
(i32.const 16)
)
)
)
)
(i64.store
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=8
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<i64>#get:size (; 81 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<i64>#delete (; 82 ;) (type $iIi) (param $0 i32) (param $1 i64) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<i64>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<i64>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<i64>|inlined.1
(call $~lib/internal/hash/hash64
(get_local $1)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=8
(get_local $2)
(i32.or
(i32.load offset=8
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<i64>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<i64> (; 83 ;) (type $v)
(local $0 i32)
(local $1 i64)
(set_local $0
(call $~lib/set/Set<i64>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i64.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i64.lt_s
(get_local $1)
(i64.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i64>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i64.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i64.lt_s
(get_local $1)
(i64.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i64>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i64.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i64.lt_s
(get_local $1)
(i64.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i64>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i64>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i64.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i64.lt_s
(get_local $1)
(i64.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<i64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<i64>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<i64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i64>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<i64>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<i64>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<u64>#clear (; 84 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 64)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<u64>#constructor (; 85 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<u64>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash<u64> (; 86 ;) (type $Ii) (param $0 i64) (result i32)
(return
(call $~lib/internal/hash/hash64
(get_local $0)
)
)
)
(func $~lib/set/Set<u64>#find (; 87 ;) (type $iIii) (param $0 i32) (param $1 i64) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=8
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(i64.eq
(i64.load
(get_local $3)
)
(get_local $1)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=8
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<u64>#has (; 88 ;) (type $iIi) (param $0 i32) (param $1 i64) (result i32)
(i32.ne
(call $~lib/set/Set<u64>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<u64>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<u64>#rehash (; 89 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 i64)
(local $12 i32)
(local $13 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<u64>|inlined.1 (result i32)
(i32.const 16)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<u64>|inlined.2 (result i32)
(i32.const 16)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=8
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(i64.store
(get_local $10)
(i64.load
(get_local $9)
)
)
(set_local $12
(i32.and
(block $~lib/internal/hash/hash<u64>|inlined.0 (result i32)
(set_local $11
(i64.load
(get_local $9)
)
)
(br $~lib/internal/hash/hash<u64>|inlined.0
(call $~lib/internal/hash/hash64
(get_local $11)
)
)
)
(get_local $1)
)
)
(set_local $13
(i32.add
(get_local $3)
(i32.mul
(get_local $12)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=8
(get_local $10)
(i32.load offset=8
(get_local $13)
)
)
(i32.store offset=8
(get_local $13)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<u64>|inlined.3 (result i32)
(i32.const 16)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<u64>|inlined.4 (result i32)
(i32.const 16)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<u64>#add (; 90 ;) (type $iIv) (param $0 i32) (param $1 i64)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<u64>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<u64>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<u64>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<u64>|inlined.5 (result i32)
(i32.const 16)
)
)
)
)
(i64.store
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=8
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<u64>#get:size (; 91 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<u64>#delete (; 92 ;) (type $iIi) (param $0 i32) (param $1 i64) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<u64>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<u64>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<u64>|inlined.1
(call $~lib/internal/hash/hash64
(get_local $1)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=8
(get_local $2)
(i32.or
(i32.load offset=8
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<u64>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<u64> (; 93 ;) (type $v)
(local $0 i32)
(local $1 i64)
(set_local $0
(call $~lib/set/Set<u64>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(i64.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(i64.lt_u
(get_local $1)
(i64.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u64>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(i64.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(i64.lt_u
(get_local $1)
(i64.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u64>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(i64.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(i64.lt_u
(get_local $1)
(i64.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u64>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u64>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(i64.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(i64.lt_u
(get_local $1)
(i64.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<u64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<u64>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<u64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(i64.add
(get_local $1)
(i64.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u64>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<u64>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<u64>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<f32>#clear (; 94 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 32)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<f32>#constructor (; 95 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<f32>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash<f32> (; 96 ;) (type $fi) (param $0 f32) (result i32)
(return
(call $~lib/internal/hash/hash32
(i32.reinterpret/f32
(get_local $0)
)
)
)
)
(func $~lib/set/Set<f32>#find (; 97 ;) (type $ifii) (param $0 i32) (param $1 f32) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(f32.eq
(f32.load
(get_local $3)
)
(get_local $1)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=4
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<f32>#has (; 98 ;) (type $ifi) (param $0 i32) (param $1 f32) (result i32)
(i32.ne
(call $~lib/set/Set<f32>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<f32>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<f32>#rehash (; 99 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 f32)
(local $12 i32)
(local $13 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<f32>|inlined.1 (result i32)
(i32.const 8)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<f32>|inlined.2 (result i32)
(i32.const 8)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=4
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(f32.store
(get_local $10)
(f32.load
(get_local $9)
)
)
(set_local $12
(i32.and
(block $~lib/internal/hash/hash<f32>|inlined.0 (result i32)
(set_local $11
(f32.load
(get_local $9)
)
)
(br $~lib/internal/hash/hash<f32>|inlined.0
(call $~lib/internal/hash/hash32
(i32.reinterpret/f32
(get_local $11)
)
)
)
)
(get_local $1)
)
)
(set_local $13
(i32.add
(get_local $3)
(i32.mul
(get_local $12)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $10)
(i32.load offset=8
(get_local $13)
)
)
(i32.store offset=8
(get_local $13)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<f32>|inlined.3 (result i32)
(i32.const 8)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<f32>|inlined.4 (result i32)
(i32.const 8)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<f32>#add (; 100 ;) (type $ifv) (param $0 i32) (param $1 f32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<f32>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<f32>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<f32>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<f32>|inlined.5 (result i32)
(i32.const 8)
)
)
)
)
(f32.store
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=4
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<f32>#get:size (; 101 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<f32>#delete (; 102 ;) (type $ifi) (param $0 i32) (param $1 f32) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<f32>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<f32>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<f32>|inlined.1
(call $~lib/internal/hash/hash32
(i32.reinterpret/f32
(get_local $1)
)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=4
(get_local $2)
(i32.or
(i32.load offset=4
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<f32>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<f32> (; 103 ;) (type $v)
(local $0 i32)
(local $1 f32)
(set_local $0
(call $~lib/set/Set<f32>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(f32.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(f32.lt
(get_local $1)
(f32.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<f32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f32.add
(get_local $1)
(f32.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f32>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(f32.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(f32.lt
(get_local $1)
(f32.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<f32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f32.add
(get_local $1)
(f32.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f32>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(f32.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(f32.lt
(get_local $1)
(f32.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<f32>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f32.add
(get_local $1)
(f32.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f32>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(f32.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(f32.lt
(get_local $1)
(f32.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<f32>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<f32>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f32>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f32.add
(get_local $1)
(f32.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f32>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<f32>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f32>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $~lib/set/Set<f64>#clear (; 104 ;) (type $iv) (param $0 i32)
(i32.store
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 16)
(i32.const 0)
)
)
(i32.store offset=4
(get_local $0)
(i32.sub
(get_global $~lib/set/INITIAL_CAPACITY)
(i32.const 1)
)
)
(i32.store offset=8
(get_local $0)
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.const 64)
(i32.const 1)
)
)
(i32.store offset=12
(get_local $0)
(get_global $~lib/set/INITIAL_CAPACITY)
)
(i32.store offset=16
(get_local $0)
(i32.const 0)
)
(i32.store offset=20
(get_local $0)
(i32.const 0)
)
)
(func $~lib/set/Set<f64>#constructor (; 105 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(call $~lib/set/Set<f64>#clear
(tee_local $0
(if (result i32)
(get_local $0)
(get_local $0)
(tee_local $0
(block (result i32)
(set_local $1
(call $~lib/memory/memory.allocate
(i32.const 24)
)
)
(i32.store
(get_local $1)
(i32.const 0)
)
(i32.store offset=4
(get_local $1)
(i32.const 0)
)
(i32.store offset=8
(get_local $1)
(i32.const 0)
)
(i32.store offset=12
(get_local $1)
(i32.const 0)
)
(i32.store offset=16
(get_local $1)
(i32.const 0)
)
(i32.store offset=20
(get_local $1)
(i32.const 0)
)
(get_local $1)
)
)
)
)
)
(get_local $0)
)
(func $~lib/internal/hash/hash<f64> (; 106 ;) (type $Fi) (param $0 f64) (result i32)
(return
(call $~lib/internal/hash/hash64
(i64.reinterpret/f64
(get_local $0)
)
)
)
)
(func $~lib/set/Set<f64>#find (; 107 ;) (type $iFii) (param $0 i32) (param $1 f64) (param $2 i32) (result i32)
(local $3 i32)
(local $4 i32)
(set_local $3
(i32.load offset=8
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
)
(block $break|0
(loop $continue|0
(if
(get_local $3)
(block
(block
(if
(if (result i32)
(tee_local $4
(i32.eqz
(i32.and
(i32.load offset=8
(get_local $3)
)
(get_global $~lib/set/EMPTY)
)
)
)
(f64.eq
(f64.load
(get_local $3)
)
(get_local $1)
)
(get_local $4)
)
(return
(get_local $3)
)
)
(set_local $3
(i32.and
(i32.load offset=8
(get_local $3)
)
(i32.xor
(get_global $~lib/set/EMPTY)
(i32.const -1)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.const 0)
)
(func $~lib/set/Set<f64>#has (; 108 ;) (type $iFi) (param $0 i32) (param $1 f64) (result i32)
(i32.ne
(call $~lib/set/Set<f64>#find
(get_local $0)
(get_local $1)
(call $~lib/internal/hash/hash<f64>
(get_local $1)
)
)
(i32.const 0)
)
)
(func $~lib/set/Set<f64>#rehash (; 109 ;) (type $iiv) (param $0 i32) (param $1 i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(local $6 i32)
(local $7 i32)
(local $8 i32)
(local $9 i32)
(local $10 i32)
(local $11 f64)
(local $12 i32)
(local $13 i32)
(set_local $2
(i32.add
(get_local $1)
(i32.const 1)
)
)
(set_local $3
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $2)
(get_global $~lib/set/BUCKET_SIZE)
)
(i32.const 0)
)
)
(set_local $4
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(get_local $2)
)
(get_global $~lib/set/FILL_FACTOR)
)
)
)
(set_local $5
(call $~lib/arraybuffer/ArrayBuffer#constructor
(i32.const 0)
(i32.mul
(get_local $4)
(block $~lib/set/ENTRY_SIZE<f64>|inlined.1 (result i32)
(i32.const 16)
)
)
(i32.const 1)
)
)
(set_local $6
(i32.add
(i32.load offset=8
(get_local $0)
)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(set_local $7
(i32.add
(get_local $6)
(i32.mul
(i32.load offset=16
(get_local $0)
)
(block $~lib/set/ENTRY_SIZE<f64>|inlined.2 (result i32)
(i32.const 16)
)
)
)
)
(set_local $8
(i32.add
(get_local $5)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
)
(block $break|0
(loop $continue|0
(if
(i32.ne
(get_local $6)
(get_local $7)
)
(block
(block
(set_local $9
(get_local $6)
)
(if
(i32.eqz
(i32.and
(i32.load offset=8
(get_local $9)
)
(get_global $~lib/set/EMPTY)
)
)
(block
(set_local $10
(get_local $8)
)
(f64.store
(get_local $10)
(f64.load
(get_local $9)
)
)
(set_local $12
(i32.and
(block $~lib/internal/hash/hash<f64>|inlined.0 (result i32)
(set_local $11
(f64.load
(get_local $9)
)
)
(br $~lib/internal/hash/hash<f64>|inlined.0
(call $~lib/internal/hash/hash64
(i64.reinterpret/f64
(get_local $11)
)
)
)
)
(get_local $1)
)
)
(set_local $13
(i32.add
(get_local $3)
(i32.mul
(get_local $12)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=8
(get_local $10)
(i32.load offset=8
(get_local $13)
)
)
(i32.store offset=8
(get_local $13)
(get_local $8)
)
(set_local $8
(i32.add
(get_local $8)
(block $~lib/set/ENTRY_SIZE<f64>|inlined.3 (result i32)
(i32.const 16)
)
)
)
)
)
(set_local $6
(i32.add
(get_local $6)
(block $~lib/set/ENTRY_SIZE<f64>|inlined.4 (result i32)
(i32.const 16)
)
)
)
)
(br $continue|0)
)
)
)
)
(i32.store
(get_local $0)
(get_local $3)
)
(i32.store offset=4
(get_local $0)
(get_local $1)
)
(i32.store offset=8
(get_local $0)
(get_local $5)
)
(i32.store offset=12
(get_local $0)
(get_local $4)
)
(i32.store offset=16
(get_local $0)
(i32.load offset=20
(get_local $0)
)
)
)
(func $~lib/set/Set<f64>#add (; 110 ;) (type $iFv) (param $0 i32) (param $1 f64)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/internal/hash/hash<f64>
(get_local $1)
)
)
(set_local $3
(call $~lib/set/Set<f64>#find
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(if
(i32.eqz
(get_local $3)
)
(block
(if
(i32.eq
(i32.load offset=16
(get_local $0)
)
(i32.load offset=12
(get_local $0)
)
)
(call $~lib/set/Set<f64>#rehash
(get_local $0)
(if (result i32)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(i32.load offset=4
(get_local $0)
)
(i32.or
(i32.shl
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(set_local $4
(i32.load offset=8
(get_local $0)
)
)
(set_local $3
(i32.add
(i32.add
(get_local $4)
(get_global $~lib/internal/arraybuffer/HEADER_SIZE)
)
(i32.mul
(block (result i32)
(set_local $5
(i32.load offset=16
(get_local $0)
)
)
(i32.store offset=16
(get_local $0)
(i32.add
(get_local $5)
(i32.const 1)
)
)
(get_local $5)
)
(block $~lib/set/ENTRY_SIZE<f64>|inlined.5 (result i32)
(i32.const 16)
)
)
)
)
(f64.store
(get_local $3)
(get_local $1)
)
(i32.store offset=20
(get_local $0)
(i32.add
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $5
(i32.add
(i32.load
(get_local $0)
)
(i32.mul
(i32.and
(get_local $2)
(i32.load offset=4
(get_local $0)
)
)
(get_global $~lib/set/BUCKET_SIZE)
)
)
)
(i32.store offset=8
(get_local $3)
(i32.load offset=8
(get_local $5)
)
)
(i32.store offset=8
(get_local $5)
(get_local $3)
)
)
)
)
(func $~lib/set/Set<f64>#get:size (; 111 ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=20
(get_local $0)
)
)
(func $~lib/set/Set<f64>#delete (; 112 ;) (type $iFi) (param $0 i32) (param $1 f64) (result i32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
(set_local $2
(call $~lib/set/Set<f64>#find
(get_local $0)
(get_local $1)
(block $~lib/internal/hash/hash<f64>|inlined.1 (result i32)
(br $~lib/internal/hash/hash<f64>|inlined.1
(call $~lib/internal/hash/hash64
(i64.reinterpret/f64
(get_local $1)
)
)
)
)
)
)
(if
(i32.eqz
(get_local $2)
)
(return
(i32.const 0)
)
)
(i32.store offset=8
(get_local $2)
(i32.or
(i32.load offset=8
(get_local $2)
)
(get_global $~lib/set/EMPTY)
)
)
(i32.store offset=20
(get_local $0)
(i32.sub
(i32.load offset=20
(get_local $0)
)
(i32.const 1)
)
)
(set_local $3
(i32.shr_u
(i32.load offset=4
(get_local $0)
)
(i32.const 1)
)
)
(if
(if (result i32)
(tee_local $4
(i32.ge_u
(i32.add
(get_local $3)
(i32.const 1)
)
(select
(tee_local $4
(get_global $~lib/set/INITIAL_CAPACITY)
)
(tee_local $5
(i32.load offset=20
(get_local $0)
)
)
(i32.gt_u
(get_local $4)
(get_local $5)
)
)
)
)
(i32.lt_s
(i32.load offset=20
(get_local $0)
)
(i32.trunc_s/f64
(f64.mul
(f64.convert_s/i32
(i32.load offset=12
(get_local $0)
)
)
(get_global $~lib/set/FREE_FACTOR)
)
)
)
(get_local $4)
)
(call $~lib/set/Set<f64>#rehash
(get_local $0)
(get_local $3)
)
)
(i32.const 1)
)
(func $std/set/test<f64> (; 113 ;) (type $v)
(local $0 i32)
(local $1 f64)
(set_local $0
(call $~lib/set/Set<f64>#constructor
(i32.const 0)
)
)
(block $break|0
(set_local $1
(f64.const 0)
)
(loop $repeat|0
(br_if $break|0
(i32.eqz
(f64.lt
(get_local $1)
(f64.const 100)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 8)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<f64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 10)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f64.add
(get_local $1)
(f64.const 1)
)
)
(br $repeat|0)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f64>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 12)
(i32.const 2)
)
(unreachable)
)
)
(block $break|1
(set_local $1
(f64.const 50)
)
(loop $repeat|1
(br_if $break|1
(i32.eqz
(f64.lt
(get_local $1)
(f64.const 100)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 16)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<f64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 18)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f64.add
(get_local $1)
(f64.const 1)
)
)
(br $repeat|1)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f64>#get:size
(get_local $0)
)
(i32.const 100)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 20)
(i32.const 2)
)
(unreachable)
)
)
(block $break|2
(set_local $1
(f64.const 0)
)
(loop $repeat|2
(br_if $break|2
(i32.eqz
(f64.lt
(get_local $1)
(f64.const 50)
)
)
)
(block
(if
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 24)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<f64>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 26)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f64.add
(get_local $1)
(f64.const 1)
)
)
(br $repeat|2)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f64>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 28)
(i32.const 2)
)
(unreachable)
)
)
(block $break|3
(set_local $1
(f64.const 0)
)
(loop $repeat|3
(br_if $break|3
(i32.eqz
(f64.lt
(get_local $1)
(f64.const 50)
)
)
)
(block
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 32)
(i32.const 4)
)
(unreachable)
)
)
(call $~lib/set/Set<f64>#add
(get_local $0)
(get_local $1)
)
(if
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 34)
(i32.const 4)
)
(unreachable)
)
)
(drop
(call $~lib/set/Set<f64>#delete
(get_local $0)
(get_local $1)
)
)
(if
(i32.eqz
(i32.eqz
(call $~lib/set/Set<f64>#has
(get_local $0)
(get_local $1)
)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 36)
(i32.const 4)
)
(unreachable)
)
)
)
(set_local $1
(f64.add
(get_local $1)
(f64.const 1)
)
)
(br $repeat|3)
)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f64>#get:size
(get_local $0)
)
(i32.const 50)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 38)
(i32.const 2)
)
(unreachable)
)
)
(call $~lib/set/Set<f64>#clear
(get_local $0)
)
(if
(i32.eqz
(i32.eq
(call $~lib/set/Set<f64>#get:size
(get_local $0)
)
(i32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 42)
(i32.const 2)
)
(unreachable)
)
)
)
(func $start (; 114 ;) (type $v)
(set_global $~lib/allocator/arena/startOffset
(i32.and
(i32.add
(get_global $HEAP_BASE)
(get_global $~lib/internal/allocator/AL_MASK)
)
(i32.xor
(get_global $~lib/internal/allocator/AL_MASK)
(i32.const -1)
)
)
)
(set_global $~lib/allocator/arena/offset
(get_global $~lib/allocator/arena/startOffset)
)
(call $std/set/test<i8>)
(call $std/set/test<u8>)
(call $std/set/test<i16>)
(call $std/set/test<u16>)
(call $std/set/test<i32>)
(call $std/set/test<u32>)
(call $std/set/test<i64>)
(call $std/set/test<u64>)
(call $std/set/test<f32>)
(call $std/set/test<f64>)
)
)