Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wa-lang
wa
提交
e5e4972d
wa
项目概览
wa-lang
/
wa
11 个月 前同步成功
通知
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,发现更多精彩内容 >>
提交
e5e4972d
编写于
7月 24, 2022
作者:
chai2010
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
修复 wa.mod.json 文件加载问题
上级
3bd7be6a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
14 addition
and
12 deletion
+14
-12
README.md
README.md
+2
-2
internal/app/utils.wa.go
internal/app/utils.wa.go
+3
-1
internal/config/manifest.go
internal/config/manifest.go
+9
-9
未找到文件。
README.md
浏览文件 @
e5e4972d
...
...
@@ -76,10 +76,10 @@ fn main() {
}
```
输出结果:
运行并
输出结果:
```
$
wa
run _examples/prime
$
go run main.go
run _examples/prime
2
3
5
...
...
internal/app/utils.wa.go
浏览文件 @
e5e4972d
...
...
@@ -6,6 +6,8 @@ import (
"fmt"
"os"
"path/filepath"
"github.com/wa-lang/wa/internal/config"
)
func
findPkgInfo
(
workDir
string
)
(
pkgroot
,
pkgpath
string
,
err
error
)
{
...
...
@@ -24,7 +26,7 @@ func findPkgInfo(workDir string) (pkgroot, pkgpath string, err error) {
pkgroot
=
wd
for
pkgroot
!=
""
{
waJsonPath
:=
filepath
.
Join
(
pkgroot
,
"wa.json"
)
waJsonPath
:=
filepath
.
Join
(
pkgroot
,
config
.
WaModFile
)
if
fi
,
_
:=
os
.
Stat
(
waJsonPath
);
fi
!=
nil
{
pkgpath
,
err
=
filepath
.
Rel
(
pkgroot
,
wd
)
pkgroot
=
filepath
.
ToSlash
(
pkgroot
)
...
...
internal/config/manifest.go
浏览文件 @
e5e4972d
...
...
@@ -14,9 +14,9 @@ import (
// 模块文件
const
WaModFile
=
"wa.mod.json"
//
wa.json
文件结构
//
WaModFile
文件结构
type
Manifest
struct
{
Root
string
`json:"root"`
//
wa.json
所在目录
Root
string
`json:"root"`
//
WaModFile
所在目录
MainPkg
string
`json:"main"`
// 主包路径
Pkg
Manifest_package
`json:"package"`
...
...
@@ -53,7 +53,7 @@ func (p *Manifest) Clone() *Manifest {
return
&
v
}
// 加载
wa.json
文件
// 加载
WaModFile
文件
func
LoadManifest
(
appPath
string
)
(
*
Manifest
,
error
)
{
workDir
:=
appPath
if
workDir
==
""
{
...
...
@@ -64,13 +64,13 @@ func LoadManifest(appPath string) (*Manifest, error) {
workDir
=
wd
}
// 查找
wa.json
路径
// 查找
WaModFile
路径
kManifestPath
,
err
:=
findManifestPath
(
workDir
)
if
err
!=
nil
{
return
nil
,
fmt
.
Errorf
(
"loader.LoadManifest: find
wa.json failed : %w"
,
err
)
return
nil
,
fmt
.
Errorf
(
"loader.LoadManifest: find
'%s' failed : %w"
,
WaModFile
,
err
)
}
// 读取
wa.json
文件
// 读取
WaModFile
文件
data
,
err
:=
os
.
ReadFile
(
kManifestPath
)
if
err
!=
nil
{
return
nil
,
fmt
.
Errorf
(
"loader.LoadManifest: read %s failed: %w"
,
kManifestPath
,
err
)
...
...
@@ -98,13 +98,13 @@ func (p *Manifest) JSONString() string {
return
string
(
d
)
}
// 查找
wa.json
文件路径
// 查找
WaModFile
文件路径
func
findManifestPath
(
pkgpath
string
)
(
string
,
error
)
{
if
pkgpath
==
""
{
return
""
,
fmt
.
Errorf
(
"empty pkgpath"
)
}
// 依次向上查找
wa.json
// 依次向上查找
WaModFile
pkgroot
:=
pkgpath
for
pkgroot
!=
""
{
kManifestPath
:=
filepath
.
Join
(
pkgroot
,
WaModFile
)
...
...
@@ -122,5 +122,5 @@ func findManifestPath(pkgpath string) (string, error) {
}
// 查找失败
return
""
,
fmt
.
Errorf
(
"%s:
<wa.json> not found"
,
pkgpath
)
return
""
,
fmt
.
Errorf
(
"%s:
'%s' not found"
,
WaModFile
,
pkgpath
)
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录