Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wa-lang
wa
提交
bff4fd18
wa
项目概览
wa-lang
/
wa
10 个月 前同步成功
通知
68
Star
655
Fork
45
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
wa
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
bff4fd18
编写于
8月 10, 2023
作者:
3
3dgen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
wat目标输出顺序固定
上级
7ee8e627
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
46 addition
and
22 deletion
+46
-22
internal/backends/compiler_wat/compile.go
internal/backends/compiler_wat/compile.go
+46
-22
未找到文件。
internal/backends/compiler_wat/compile.go
浏览文件 @
bff4fd18
...
...
@@ -36,24 +36,27 @@ func (p *Compiler) Compile(prog *loader.Program, mainFunc string) (output string
p
.
tLib
=
newTypeLib
(
p
.
module
,
prog
)
for
_
,
pkg
:=
range
prog
.
Pkgs
{
p
.
ssaPkg
=
pkg
.
SSAPkg
p
.
CompilePkgConst
(
pkg
.
SSAPkg
)
var
pkgnames
[]
string
for
n
:=
range
prog
.
Pkgs
{
p
kgnames
=
append
(
pkgnames
,
n
)
}
sort
.
Strings
(
pkgnames
)
for
_
,
pkg
:=
range
prog
.
Pkg
s
{
p
.
ssaPkg
=
p
kg
.
SSAPkg
p
.
CompilePkg
Type
(
pkg
.
SSA
Pkg
)
for
_
,
n
:=
range
pkgname
s
{
p
.
ssaPkg
=
p
rog
.
Pkgs
[
n
]
.
SSAPkg
p
.
CompilePkg
Const
(
p
.
ssa
Pkg
)
}
for
_
,
pkg
:=
range
prog
.
Pkgs
{
p
.
ssaPkg
=
pkg
.
SSAPkg
p
.
CompilePkgGlobal
(
pkg
.
SSAPkg
)
for
_
,
n
:=
range
pkgnames
{
p
.
ssaPkg
=
prog
.
Pkgs
[
n
]
.
SSAPkg
p
.
CompilePkgType
(
p
.
ssaPkg
)
}
for
_
,
pkg
:=
range
prog
.
Pkgs
{
p
.
ssaPkg
=
pkg
.
SSAPkg
p
.
CompilePkgFunc
(
pkg
.
SSAPkg
)
for
_
,
n
:=
range
pkgnames
{
p
.
ssaPkg
=
prog
.
Pkgs
[
n
]
.
SSAPkg
p
.
CompilePkgGlobal
(
p
.
ssaPkg
)
}
for
_
,
n
:=
range
pkgnames
{
p
.
ssaPkg
=
prog
.
Pkgs
[
n
]
.
SSAPkg
p
.
CompilePkgFunc
(
p
.
ssaPkg
)
}
p
.
tLib
.
finish
()
...
...
@@ -119,15 +122,22 @@ func (p *Compiler) CompileWsFiles(prog *loader.Program) {
}
func
(
p
*
Compiler
)
CompilePkgConst
(
ssaPkg
*
ssa
.
Package
)
{
for
_
,
m
:=
range
p
.
ssaPkg
.
Members
{
if
con
,
ok
:=
m
.
(
*
ssa
.
NamedConst
);
ok
{
p
.
compileConst
(
con
)
}
}
//
for _, m := range p.ssaPkg.Members {
//
if con, ok := m.(*ssa.NamedConst); ok {
//
p.compileConst(con)
//
}
//
}
}
func
(
p
*
Compiler
)
CompilePkgType
(
ssaPkg
*
ssa
.
Package
)
{
for
_
,
m
:=
range
p
.
ssaPkg
.
Members
{
var
memnames
[]
string
for
name
:=
range
p
.
ssaPkg
.
Members
{
memnames
=
append
(
memnames
,
name
)
}
sort
.
Strings
(
memnames
)
for
_
,
name
:=
range
memnames
{
m
:=
p
.
ssaPkg
.
Members
[
name
]
if
t
,
ok
:=
m
.
(
*
ssa
.
Type
);
ok
{
p
.
compileType
(
t
)
}
...
...
@@ -135,7 +145,14 @@ func (p *Compiler) CompilePkgType(ssaPkg *ssa.Package) {
}
func
(
p
*
Compiler
)
CompilePkgGlobal
(
ssaPkg
*
ssa
.
Package
)
{
for
_
,
m
:=
range
p
.
ssaPkg
.
Members
{
var
memnames
[]
string
for
name
:=
range
p
.
ssaPkg
.
Members
{
memnames
=
append
(
memnames
,
name
)
}
sort
.
Strings
(
memnames
)
for
_
,
name
:=
range
memnames
{
m
:=
p
.
ssaPkg
.
Members
[
name
]
if
global
,
ok
:=
m
.
(
*
ssa
.
Global
);
ok
{
p
.
compileGlobal
(
global
)
}
...
...
@@ -143,7 +160,14 @@ func (p *Compiler) CompilePkgGlobal(ssaPkg *ssa.Package) {
}
func
(
p
*
Compiler
)
CompilePkgFunc
(
ssaPkg
*
ssa
.
Package
)
{
for
_
,
m
:=
range
p
.
ssaPkg
.
Members
{
var
memnames
[]
string
for
name
:=
range
p
.
ssaPkg
.
Members
{
memnames
=
append
(
memnames
,
name
)
}
sort
.
Strings
(
memnames
)
for
_
,
name
:=
range
memnames
{
m
:=
p
.
ssaPkg
.
Members
[
name
]
if
fn
,
ok
:=
m
.
(
*
ssa
.
Function
);
ok
{
CompileFunc
(
fn
,
p
.
prog
,
p
.
tLib
,
p
.
module
)
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录