Merge "Use MIT license type, specified in Cargo.toml" am: 54ea0582f3 am: a75e2dec5a am: 0dad75e4d8

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

Change-Id: Id8ea2efea8839168a926f137e05d5c2cef800f4d
tree: 0cb8ac5cbf23fdb23352659f614de903efd58b49
  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. post_update.sh
  12. README.android
  13. README.md
  14. TEST_MAPPING
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.