The standard way to use protobuf is something like:
- write/edit protobuf file
- generate bindings for Rust/GoLang/JVM/...
- if need to change, go to 1
In practice this works great if all the used languages are equal class citizens in the project. This is not my situation, where Rust is the 'main' language, and the other languages are 'glue' languages.
The above is inconvenient for two reasons:
- the generated protobuf -> Rust struct/enums are not always idiomatic / concise
- when editing in Rust, IntelliJ jumps me to the generated Rust code, but then I have to go modify the *.proto file, etc ...
I am wondering if there is a set of crates that works as follows:
- instead of a *.proto file, we define the structs / enums in a strict subset of Rust
- so the ".proto file" is a ".rs file" but in a strict subset of Rust
- the ".proto file" is then generated from this "heavily restricted .rs file"
The benefits here are:
- the Rust bindings always feel clean/idiomatic
- IntelliJ can jump me to the right files to edit
The downside is that other language bindings are a bit messier, but in this case where Rust = main langauges, other = glue languages, it is an acceptable tradeoff.
Is there any crate that does this? Express protobuf structs in an restricted subset of Rust.
EDIT: Preemptive 'why not use Serde/Json' -- I like static types in the glue languages too.
EDIT 2: I am willing to give up all the versioning / add-remove field benefits of protobuf. My workflow will be something like:
-
Write Rust code.
-
Run the "restricted *.rs -> proto -> GoLang / JVM" generator
-
Fix the GoLang / JVM code.
-
There is no need to access previously stored protobuf data; nor is there a need to be compatible with anything but the current version of the structs/enums.