Rework resolver (#489)

* Rework IR and resolver to use nested lookup tables
* Integrate types into IR
* Make components prefer IR, slimmed down AST
* Implement `export *`
* Add `@lazy` annotation and remove `--noTreeShaking`
* Add `@start` annotation and remove magic `main`
* Related refactoring, cleanup and docs
This commit is contained in:
Daniel Wirtz
2019-02-21 00:11:22 +01:00
committed by GitHub
parent e623786b42
commit 0c64f21250
234 changed files with 16949 additions and 37871 deletions

View File

@ -1,4 +1,5 @@
(module
(type $_ (func))
(type $ii (func (param i32) (result i32)))
(type $iiii_ (func (param i32 i32 i32 i32)))
(type $i_ (func (param i32)))
@ -6,7 +7,6 @@
(type $iii_ (func (param i32 i32 i32)))
(type $iii (func (param i32 i32) (result i32)))
(type $ii_ (func (param i32 i32)))
(type $_ (func))
(type $FUNCSIG$vii (func (param i32 i32)))
(type $FUNCSIG$iii (func (param i32 i32) (result i32)))
(type $FUNCSIG$i (func (result i32)))
@ -2440,7 +2440,7 @@
i32.const 592
call $~lib/string/String.__concat
)
(func $start (; 28 ;) (type $_)
(func $start:std/symbol (; 28 ;) (type $_)
(local $0 i32)
i32.const 760
global.set $~lib/allocator/arena/startOffset
@ -2617,7 +2617,10 @@
unreachable
end
)
(func $null (; 29 ;) (type $_)
(func $start (; 29 ;) (type $_)
call $start:std/symbol
)
(func $null (; 30 ;) (type $_)
nop
)
)