122 stable releases
4.30.0-beta1 | Dec 18, 2024 |
---|---|
3.7.1 | Oct 15, 2024 |
3.6.0 | Sep 30, 2024 |
3.5.0 | Jun 26, 2024 |
0.0.5 | Nov 28, 2014 |
#81 in Encoding
1,170,291 downloads per month
Used in 1,621 crates
(469 directly)
1.5MB
31K
SLoC
The runtime of the official Google Rust Protobuf implementation.
This is currently a beta release: the API is subject to change, and there may be some rough edges, including missing documentation and features.
Usage of this crate currently requires protoc to be built from source as it relies on changes that have not been included in the newest protoc release yet.
An example for how to use this crate can be found in the protobuf_example crate
V4 ownership and implementation change
V4 of this crate is officially supported by the Protobuf team at Google. Prior major versions were developed by as a community project by stepancheg who generously donated the crate name to Google.
V4 is a completely new implementation with a different API, as well as a fundamentally different approach than prior versions of this crate. It focuses on delivering a high-quality Rust API which is backed by either a pure C implementation (upb) or the Protobuf C++ implementation. This choice was made for performance, feature parity, development velocity, and security reasons. More discussion about the rationale and design philosophy can be found at https://protobuf.dev/reference/rust/.
It is not planned for the V3 pure Rust lineage to be actively developed going forward. While it is not expected to receive significant further development, as a stable and high quality pure Rust implementation, many open source projects may reasonably continue to stay on the V3 API.
How to get a compatible version of protoc
Usage of this crate currently requires protoc to be built from source as it relies on changes that have not been included in the newest protoc release yet.
A future stable release will be compatible with the officially released protoc binaries.
You can build a compatible protoc from source as follows:
git clone https://github.com/protocolbuffers/protobuf.git
cd protobuf
git checkout $TAG
cmake . -Dprotobuf_FORCE_FETCH_DEPENDENCIES=ON
cmake --build . --parallel 12"