|
|
|
Protocol Buffers - Google's data interchange format
|
|
|
|
===================================================
|
|
|
|
|
|
|
|
Copyright 2008 Google Inc.
|
|
|
|
|
|
|
|
https://developers.google.com/protocol-buffers/
|
|
|
|
|
|
|
|
Overview
|
|
|
|
--------
|
|
|
|
|
|
|
|
Protocol Buffers (a.k.a., protobuf) are Google's language-neutral,
|
|
|
|
platform-neutral, extensible mechanism for serializing structured data. You
|
|
|
|
can find [protobuf's documentation on the Google Developers site](https://developers.google.com/protocol-buffers/).
|
|
|
|
|
|
|
|
This README file contains protobuf installation instructions. To install
|
|
|
|
protobuf, you need to install the protocol compiler (used to compile .proto
|
|
|
|
files) and the protobuf runtime for your chosen programming language.
|
|
|
|
|
|
|
|
Protocol Compiler Installation
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
The protocol compiler is written in C++. If you are using C++, please follow
|
|
|
|
the [C++ Installation Instructions](src/README.md) to install protoc along
|
|
|
|
with the C++ runtime.
|
|
|
|
|
|
|
|
For non-C++ users, the simplest way to install the protocol compiler is to
|
|
|
|
download a pre-built binary from our release page:
|
|
|
|
|
|
|
|
[https://github.com/protocolbuffers/protobuf/releases](https://github.com/protocolbuffers/protobuf/releases)
|
|
|
|
|
|
|
|
In the downloads section of each release, you can find pre-built binaries in
|
|
|
|
zip packages: protoc-$VERSION-$PLATFORM.zip. It contains the protoc binary
|
|
|
|
as well as a set of standard .proto files distributed along with protobuf.
|
|
|
|
|
|
|
|
If you are looking for an old version that is not available in the release
|
|
|
|
page, check out the maven repo here:
|
|
|
|
|
|
|
|
[https://repo1.maven.org/maven2/com/google/protobuf/protoc/](https://repo1.maven.org/maven2/com/google/protobuf/protoc/)
|
|
|
|
|
|
|
|
These pre-built binaries are only provided for released versions. If you want
|
|
|
|
to use the github master version at HEAD, or you need to modify protobuf code,
|
|
|
|
or you are using C++, it's recommended to build your own protoc binary from
|
|
|
|
source.
|
|
|
|
|
|
|
|
If you would like to build protoc binary from source, see the [C++ Installation
|
|
|
|
Instructions](src/README.md).
|
|
|
|
|
|
|
|
Protobuf Runtime Installation
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
Protobuf supports several different programming languages. For each programming
|
|
|
|
language, you can find instructions in the corresponding source directory about
|
|
|
|
how to install protobuf runtime for that specific language:
|
|
|
|
|
|
|
|
| Language | Source | Ubuntu | MacOS | Windows |
|
|
|
|
|--------------------------------------|-------------------------------------------------------------|--------|-------|---------|
|
|
|
|
| C++ (include C++ runtime and protoc) | [src](src) | [data:image/s3,"s3://crabby-images/8aa3e/8aa3ee4db047799dbedd6c1212807479d1ea3bec" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fcpp_distcheck%2Fcontinuous) [data:image/s3,"s3://crabby-images/f6c84/f6c84ec4a6aba3448a7f253df593244e03014a42" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fbazel%2Fcontinuous) | [data:image/s3,"s3://crabby-images/5e2d0/5e2d0998838957488a3adedd77648c393149ae6d" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fcpp%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/d410d/d410d41ec7079e257000829c7544a14d58510fcf" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fcpp_distcheck%2Fcontinuous) | [data:image/s3,"s3://crabby-images/eb523/eb52327a523268b45d87ecb5099bdba3b40ee744" alt="Build status"](https://ci.appveyor.com/project/protobuf/protobuf) |
|
|
|
|
| Java | [java](java) | [data:image/s3,"s3://crabby-images/16cdc/16cdc2707bc3ebd0c17ddbee52fc1636da6a72a7" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fjava_compatibility%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/7ba88/7ba88528d347229bce46e9ed0feef2921e2d4877" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fjava_jdk7%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/4ea2e/4ea2eb53ba457dce6b038736c57978c2b5120da9" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fjava_oracle7%2Fcontinuous) | | |
|
|
|
|
| Python | [python](python) | [data:image/s3,"s3://crabby-images/746a9/746a933e6c5dbdc6126c36ba3a2741680410150e" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fpython%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/9f744/9f7443687e4534c0f492d877bb2df82b5f989f28" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fpython_compatibility%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/b1ee4/b1ee46ca61d4c12c219da0c3813ab0171375b0df" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fpython_cpp%2Fcontinuous) | [data:image/s3,"s3://crabby-images/0ead2/0ead25a62e8d24bb5d492b17eada6f38e4bc843f" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fpython%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/70bb9/70bb9397a3b01c5c0dbfcff4c8a76246d4b82dba" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fpython_cpp%2Fcontinuous) | |
|
|
|
|
| Objective-C | [objectivec](objectivec) | | [data:image/s3,"s3://crabby-images/3abc4/3abc4a9c5761c9a2fceea12c9ffc1f7bf2e2eb8a" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fobjectivec_cocoapods_integration%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/92983/929834ca4b4bac83651613ba7abc20bd2d0dc5af" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fobjectivec_ios_debug%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/657d9/657d96f3fd674df768db4ffb3964fc46b993bdb9" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fobjectivec_ios_release%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/cf097/cf0974a1c1e0719756a1c7dbf072060c17f5f924" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fobjectivec_osx%2Fcontinuous) | |
|
|
|
|
| C# | [csharp](csharp) | [data:image/s3,"s3://crabby-images/31026/310267fd15733ca0a1cacb8d7bd840d6a8ccac8d" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fcsharp%2Fcontinuous) | | [data:image/s3,"s3://crabby-images/eb523/eb52327a523268b45d87ecb5099bdba3b40ee744" alt="Build status"](https://ci.appveyor.com/project/protobuf/protobuf) |
|
|
|
|
| JavaScript | [js](js) | [data:image/s3,"s3://crabby-images/8b2f0/8b2f0f3630ff1602a19e18c1a9e07e2b3d6ec698" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fjavascript%2Fcontinuous) | [data:image/s3,"s3://crabby-images/961ec/961ec13134d5e6557594682ec4b7b67355235bd2" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fjavascript%2Fcontinuous) | |
|
|
|
|
| Ruby | [ruby](ruby) | [data:image/s3,"s3://crabby-images/a4241/a42416e7dbe9adc132b51106cbbbe2f6d4fdfdea" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fruby_all%2Fcontinuous) | [data:image/s3,"s3://crabby-images/f35a5/f35a5ab119e6a32cdc682a08dd0dce7e923b5111" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fruby21%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/ff214/ff214bb44176f6e70cfc2d55c43c778281bb0c5b" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fruby22%2Fcontinuous) | |
|
|
|
|
| Go | [golang/protobuf](https://github.com/golang/protobuf) | | | |
|
|
|
|
| PHP | [php](php) | [data:image/s3,"s3://crabby-images/31308/3130837b1f79421bce3e9b1f7e5647a4f4ed9bf5" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2Fphp_all%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/a5329/a5329f0772f50c232b373374305dc8cda3b5bcb7" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fubuntu%2F32-bit%2Fcontinuous) | [data:image/s3,"s3://crabby-images/625d5/625d59e56737d9590950ba4b56dc3c0b233cb0df" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fphp5.6_mac%2Fcontinuous)<br/>[data:image/s3,"s3://crabby-images/b6d08/b6d08b1d4a9d5636925bbf1aa5cc443950afc5e1" alt="Build status"](https://fusion.corp.google.com/projectanalysis/current/KOKORO/prod:protobuf%2Fgithub%2Fmaster%2Fmacos%2Fphp7.0_mac%2Fcontinuous) | |
|
|
|
|
| Dart | [dart-lang/protobuf](https://github.com/dart-lang/protobuf) | | | |
|
|
|
|
|
|
|
|
Quick Start
|
|
|
|
-----------
|
|
|
|
|
|
|
|
The best way to learn how to use protobuf is to follow the tutorials in our
|
|
|
|
developer guide:
|
|
|
|
|
|
|
|
https://developers.google.com/protocol-buffers/docs/tutorials
|
|
|
|
|
|
|
|
If you want to learn from code examples, take a look at the examples in the
|
|
|
|
[examples](examples) directory.
|
|
|
|
|
|
|
|
Documentation
|
|
|
|
-------------
|
|
|
|
|
|
|
|
The complete documentation for Protocol Buffers is available via the
|
|
|
|
web at:
|
|
|
|
|
|
|
|
https://developers.google.com/protocol-buffers/
|