[automerger skipped] Mark sc-dev-plus-aosp-without-vendor@7634622 as merged am: 9d6abb182c -s ours am: ac0109fc6a -s ours

am skip reason: Merged-In I5de8dc7d0ee573c02ac3ed90bac485df5f8dcdd8 with SHA-1 48aae05446 is already in history

Original change: https://googleplex-android-review.googlesource.com/c/platform/external/rust/crates/protobuf-codegen/+/15571561

Change-Id: Id32f8aaeafb27c13da66f7da280d4940c1266e39
tree: fafdecfbe1360449dedb04dc6cd3b4a6c1c1083f
  1. src/
  2. .cargo_vcs_info.json
  3. Android.bp
  4. Cargo.lock
  5. Cargo.toml
  6. Cargo.toml.orig
  7. LICENSE.txt
  8. METADATA
  9. MODULE_LICENSE_MIT
  10. OWNERS
  11. README.android
  12. README.md
README.md

protobuf-codegen

This crate contains protobuf code generator and a protoc-gen-rust protoc plugin.

protoc-gen-rust

protoc-gen-rust implements standard protobuf protoc plugin conventions.

Probably you do not want to use it directly in Rust environment, there are easier to use alternatives:

  • protoc-rust crate which can be invoked programmatically from build.rs of your project which requires only protoc in $PATH but not protoc-gen-rust.
  • protobuf-codegen-pure crate which behaves like protoc-rust, but does not depend on protoc binary

But if you really want to use that plugin, here's the instruction

(Note protoc can be invoked programmatically with protoc crate)

  1. Install protobuf for protoc binary.

On OS X Homebrew can be used:

brew install protobuf

On Ubuntu, protobuf-compiler package can be installed:

apt-get install protobuf-compiler

Protobuf is needed only for code generation, rust-protobuf runtime does not use protobuf library.

  1. Install protoc-gen-rust program (which is protoc plugin)

It can be installed either from source or with cargo install protobuf command.

  1. Add protoc-gen-rust to $PATH

If you installed it with cargo, it should be

PATH="$HOME/.cargo/bin:$PATH"
  1. Generate .rs files:
protoc --rust_out . foo.proto

This will generate .rs files in current directory.