@sisyphus.js/cli
v2.3.0
Published
Protoc cli for sisyphus project on js platform
Downloads
50
Readme
@sisyphus.js/cli
sisyphus.js 命令行界面,提供一个 sisygen 命令用于为 sisyphus.js 工程生成代码。
Sisygen
sisygen 是为了工程化与自动化代码生产而定制的命令,sisygen 只有一个参数需要指定,使用 -O 或者 --output 指定 ts 文件的生成目录,其他大部分的配置都集中在 package.json 中,所以
sisygen 命令需要在某个包的根目录下执行。
配置 sisyphus.js 工程
配置 protobuf 编译源
sisygen 会自动将包目录下 proto 文件夹的 .proto 文件加入编译源,并生成代码。
这个文件夹的位置可以通过 package.json 的 directories 字段自定义。
{
"directories": {
"proto": "otherDir",
"lib": "lib"
}
}此外,sisygen 也可以指定外部包作为编译源,需要将外部包加入依赖,并将包名加入 package.json 的 protobuf.packages 字段中。
{
"directories": {
"lib": "lib"
},
"protobuf": {
"packages": [
"@sisyphus.js/runtime"
]
}
}配置使用的编译插件
sisygen 会自动在所有的 devDependencies 中发现定义的编译器插件,并输出在日志中。
sisyphus info cli Protoc plugins found in @sisyphus.js/compiler: core, proto, aip将要使用的插件名加入到 package.json 的 protobuf.plugins 字段中,sisygen 就会在编译过程中调用这些插件。
{
"directories": {
"lib": "lib"
},
"protobuf": {
"plugins": [
"core",
"proto",
"aip"
]
}
}发现 Proto 编译依赖
proto 之间的依赖是非常常见的,多数的 TypeScript/JavaScript 实现都编译将所有 proto 文件整合在一起,并生成所有文件。
sisygen 采用 sisyphus-dist.json 文件来编排依赖与依赖中已经生成好的代码,这意味着可以将生成的代码推送到 npm 仓库中,并在后续复用这些代码。
sisygen 会发现所有 dependencies 中符合 sisyphus.js 工程结构的包,并将 proto 文件加入编译时依赖,另外如果包还包含默认导入(package.json 中拥有 main 字段),sisygen
会自动导入此包,这一般用于有拓展字段定义的包,可以将拓展定义导出到 index.js 中,并被 sisyphus.js 编译器使用。
{
"dependencies": {
"@sisyphus.js/runtime": "^2.0.0"
}
}上面的配置导致 sisygen 会自动将 @sisyphus.js/runtime 中 proto 文件加入编译时依赖中。
sisyphus-dist.json 模块映射
sisygen 会读取 proto 依赖包下面的 sisyphus-dist.json 文件,获取已经编译好的文件,并在生成代码时从该依赖包中导入。
当没有 sisyphus-dist.json 时,sisygen 认为所有生成的 ts 文件都在同一个根目录下,并通过 proto 文件的结构导入相应的依赖。
// 当前文件 /google/showcase/v1beta1/echo.ts
// 目标导入依赖 /google/protobuf/duration.ts
import {Duration} from '../../protobuf/duration'当有 @sisyphus.js/runtime 中拥有 sisyphus-dist.json 并包含 google/protobuf/duration.ts。
sisygen 会自动将 /google/protobuf/duration 映射为 @sisyphus.js/runtime/lib/google/protobuf/duration。
// 当前文件 /google/showcase/v1beta1/echo.ts
// 目标导入依赖 /google/protobuf/duration.ts
import {Duration} from '@sisyphus.js/runtime/lib/google/protobuf/duration'映射规则为包名 + lib 文件夹 + 依赖模块,例如上述例子中,就由 @sisyphus.js/runtime,lib,google/protobuf/duration 三部分构成。
其中 lib 文件夹的值由 package.json 的 directories.lib 值决定,默认值为 lib。
package.json 属性
由 sisyphus.js 拓展的 package.json 增加了以下属性来配置 sisyphus.js 工程。
{
"sisyphus": {
// 注册 sisygen 的编译器插件
"plugins": {
"core": "lib/core/index.js",
"proto": "lib/proto/index.js",
"aip": "lib/aip/index.js"
}
},
"protobuf": {
// 将指定名字的插件加入编译过程
"plugins": [
"core",
"aip"
],
// 将指定的包加入编译源
"packages": [
"@sisyphus.js/google"
]
}
}