1.1.7 • Published 2 years ago

@antfu/dts-from-thrift v1.1.7

Weekly downloads
1
License
ISC
Repository
github
Last release
2 years ago

dts-from-thrift

npm versionbuildcoverageinstall size

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

  • 优化 thrift 文件生成的代码格式 (@mehwww in #22)

1.1.3 - 2020.03.29

Breaking Change

  • protobuf 所有字段均为 optional,与 pb3 一致

1.1.0 - 2020.03.19

Breaking Change

  • 删除 --new 传参,只保留 ast 解析

Changed

  • 将行尾注释放到该行上面,使用 /** */ 标注,以使得 vscode 可提示注释内容

1.0.3 - 2019.11.18

Bugfix

  • 修复 const enum 为空的报错 commit

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
*responsefalsefalsetrue
*response & defualt valueFalsefalsetrue
*requestfalsefalse|true*true
*request & default valuefalsetruetrue
Use-strictfalsetruetrue
No-use-strictfalsefalsetrue
^request|response & Default valuefalsetruetrue

"*"表示需要标记strict-request开启,表示是业务定制

1.0.0-rc.6 - 2019.8.19

Added

  • 新增 --strict-response 传参

    指定后如果 struct 名称包含 Response(例如:ListResponse),那么它的字段如果有 defaultValue 词缀,则此字段不会有 optional 标识

    /*
    struct CreateResponse {
        255: optional i32 err_no (defaultValue=0);
    }
    */
    
    interface CreateResponse {
      err_no: number; // 不指定的时候是 err_no?: number;
    }

1.0.0-rc.5 - 2019.8.9

Added

  • dts-from-thrift 保留注释和注解

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

  • thrift Struct 字段如果定义了 defaultValue,生成的 dts 字段将带 ?

    fields in thrift Struct with defaultValue will attach a ? when in d.ts file

0.9.0-beta.0 - 2019.1.2

Breaking Change

  • thrift i64 类型会被生成为 Int64 的接口类型。该接口定义在 tsHelper.d.ts

0.8.8 - 2018.12.28

Bugfix

  • 正确解析有多个形参的 service

    parse service with multiple params currectly

0.8.6 - 2018.12.27

Bugfix

  • 正确解析单行 service 声明

    parse single line service declaration currectly.

  • typeof 泛型映射修复

    typedef generic type fix

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
    	// 你输入的命令 (the Command you input)
    > RPC d.ts files is /Users/xxx/projectpath/typings/demo.rpc-rpc.d.ts
    	// 生成的 rpc 定义文件 (the rpc definition file name)

    使用 _Summary 继承 rpc 接口 (use _Summary to extends)

    interface MyRPCContainer extends demo.rpc._Summary_ {}

Bugfix

  • 修复 service 无形参接口的报错问题

    fix service interfaces which are without input params

0.6 - 2018.11.13

Added

  • thrift 现在支持生成 service RpcService {} 定义

    (support service definition)

    // thrift sample
    service RpcService {
        ResponseType interface1 (1: RequestType req);
    }
    
    // generate code
    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\\""),
    }
    
    // before 0.4.0
    interface Foo {
      comments: string[];
    }
    
    // after 0.4.0 with [--use-tag go]
    interface Foo {
      list: string[];
    }
    // detail in parseStruct.test.ts

Changed

  • codestyle: 生成文件增加 // prettier-ignore 避免 format 导致的 git 提交

    (add // prettier-ignore at head of d.ts file to prevent useless git commit)