dts-from-thrift
thrift RPC 定义文件转 d.ts 工具
安装(install): npm install dts-from-thrift -g
运行(exec):dts-from-thrift -p ~/git/my-thrift-repo/thrift -o ~/git/my-ts-repo/typings
由于实现全靠正则,特殊 case 无法避免,可以提 issue 或者 PR。
(The tool use RegExp to generate d.ts file. If some special statement cases causes bugs, an issue or a PR is welcome.)
变更历史(ChangeLog)
1.1.4 - 2020.04.28
Changed
1.1.3 - 2020.03.29
Breaking Change
- protobuf 所有字段均为 optional,与 pb3 一致
1.1.0 - 2020.03.19
Breaking Change
Changed
- 将行尾注释放到该行上面,使用
/** */
标注,以使得 vscode 可提示注释内容
1.0.3 - 2019.11.18
Bugfix
1.0.2 - 2019.10.29
Bugfix
- 老的 protobuf 转换类型逻辑受 1.0.0 功能影响,回滚老的代码逻辑
1.0.0 - 2019.10.20
Added
-
新增 --i64
参数
i64 转换成 string 或 Int64 对象**(需要加 --new 参数)**
node ./bin/dts-from-[thrift|protobuf] -p ./test/idl/ \
-o ./test/idl/out/ \
--new --i64 string
-
新增 --enum-json
参数
把 thrift idl 中的 const 输出到 d.ts 和 enum.json 中,用于类型提示或者自定义 babel 插件(for byted-react-scripts)
默认输出在 enums.json 文件中
注意:d.ts 中的 const 在编译过程中并不会被转换。效果可以运行根目录下的 run.sh 来查看。
-
新增 --map
参数
支持 thrift idl 中的 map<type_a, type_b>
输出到 Record<string, type_b>
注意:Record 对于 key 的支持只有 number,string,symbol,所以 type_a
强制为 string
。
栗子:
node ./bin/dts-from-[thrift|protobuf] -p ./test/idl/ \
-o ./test/idl/out/ \
--new --i64 string --map
1.0.0-rc.10 - 2019.9.8
针对 struct 中的 field 是否是 optional 进行了梳理,详见test/thriftNew/readCode.test.ts
line649 和下表,主要是针对/\w+Response/i
和/\w+Request/i
做了特殊处理,以符合实际的 idl 语义
是否可选 | requeird | 无(默认) | optional |
---|
*response | false | false | true |
*response & defualt value | False | false | true |
*request | false | false|true* | true |
*request & default value | false | true | true |
Use-strict | false | true | true |
No-use-strict | false | false | true |
[^request|response] & Default value | false | true | true |
"*"表示需要标记strict-request
开启,表示是业务定制
1.0.0-rc.6 - 2019.8.19
Added
1.0.0-rc.5 - 2019.8.9
Added
1.0.0-rc.3 - 2019.7.12
Fixed
- dts-from-protobuf 旧逻辑没有适配
--i64_as_number
参数
1.0.0-rc.2 - 2019.6.25
Added
- protobuf 如果没有 package,将尝试从 options 中取一个名称作为 namespace。如果没有 options,取文件路径为 namespace
- dts-from-protobuf 新增
--i64_as_number
参数,将 i64 降级为 number
1.0.0-rc.1 - 2019.6.24
Changed
- protobuf 如果没有 package,将跳过该文件,而非中断报错
1.0.0-rc.0 - 2019.6.5
Added
0.9.0-beta.1 - 2019.1.7
Bugfix
0.9.0-beta.0 - 2019.1.2
Breaking Change
- thrift
i64
类型会被生成为 Int64
的接口类型。该接口定义在 tsHelper.d.ts
中
0.8.8 - 2018.12.28
Bugfix
0.8.6 - 2018.12.27
Bugfix
0.8 - 2018.11.26
Added
-
为 ${namespace}._Summary_
接口增加了 WrapperService
推导函数。用来解决 i64
转 number 在 js 下需要特殊处理的问题。可以通过扩展 Int64Type
接口来实现自己的 i64
类型适配
Add a type inference wrapper function to process the i64 type. Extends the Int64Type
interface for customization.
0.7 - 2018.11.20
Added
-
dts-from-thrift
支持合并 service 到一个定义文件中
使用 --rpc-namespace=xxx
来指定需要合并到的 namespace 中,并且可以通过 ${namespace}._Summary_
来获得一个总的 interface 用以继承
> dts-from-thrift -p ./ -o ../typings --rpc-namespace=demo.rpc
> RPC d.ts files is /Users/xxx/projectpath/typings/demo.rpc-rpc.d.ts
使用 _Summary* 继承 rpc 接口 (use _Summary* to extends)
interface MyRPCContainer extends demo.rpc._Summary_ {}
Bugfix
0.6 - 2018.11.13
Added
-
thrift 现在支持生成 service RpcService {}
定义
(support service definition)
service RpcService {
ResponseType interface1 (1: RequestType req);
}
export interface RpcService {
interface1(req: RequestType): Promise<ResponseType>;
}
0.5
Added
-
dts-from-protobuf 支持
(add dts-from-protobuf CLI, support protobuf)
dts-from-protobuf -p <protobuf_idl_dir> -o <output_dir>
0.4
Added
-
--use-tag CLI option,来支持下面的语法
(add a new option [--use-tag] to replace original fieldname with tagname)
struct Foo {
1: list<string> comments (go.tag="json:\\"list,omitempty\\""),
}
interface Foo {
comments: string[];
}
interface Foo {
list: string[];
}
Changed