This is an alternative implementation of the official Apache Thrift code generator, with a focus on the compact protocol.
The initial goal of this project is to develop a more efficient rust parser for the metadata embedded in Apache Parquet files.
Higher performance is achieved by the following design decisions:
- Fewer abstractions by focusing on the compact protocol.
- The generated code for example inlines the reading of field headers and so avoids method calls and passing of slightly larger structure like
TFieldIdentifier
. - The field id and field delta can be tracked inside the generated code, similar for boolean fields, making the actual protocol code much simpler.
- The generated code for example inlines the reading of field headers and so avoids method calls and passing of slightly larger structure like
- The rust target avoids moving structures from optional local variables into fields of the returned struct by directly filling the struct. This unfortunately requires all generated structs to implement the default trait.
Even though the initial target language for the code generator is rust, the code generator is written in Kotlin. The reasons for this choice are:
- Using a jvm-based language gives access to one of the most developer friendly parser generators, ANTLR. (There is a rust implementation of Antlr, but it is mostly unmaintained at the moment.)
- Kotlins
sealed
anddata
classes are very powerful for modeling domain objects (similar to rust enums). - Kotlin has built-in support for string templates, which are checked at compile time.
The runtime support for the generated rust code can be found in the runtime
folder.
To run this code generator you will need a Java Distribution like
Amazon Corretto
and Apache Maven as a build tool. Once these are installed and
their bin
folders added to the PATH
, the definitions for the included parquet.thrift
can be generated
by running:
$ cd generator && ./generate-parquet.sh
As an alternative to the code generator, the structures correponding to thrift definitions can also be generated with a declarative macro:
thrift! {
/** doc */
struct SomeStructure {
/** doc */
1: required i64 offset;
2: optional i64 length;
3: optional list<i64> numbers;
4: optional string data;
}
}