C++ Java Objective-C C# Protocol Buffer C Other
Latest commit eef2edc Jul 24, 2017 @acozzette acozzette committed on GitHub Merge pull request #3403 from ax3l/topic-cmake-pkgconfig
CMake: Install .pc Files
Failed to load latest commit information.
benchmarks Added C++ benchmark. (#1525) Sep 23, 2016
cmake CMake: Install .pc Files Jul 23, 2017
conformance Add std:: namespace prefix to set and map (#3332) Jul 10, 2017
csharp Merge pull request #3375 from TeBoring/3.3.x Jul 19, 2017
docs Updated outdated hyperlink Jul 21, 2017
editors Improve fix for #295 May 23, 2017
examples add protobuf_generate function, allows use of target_sources where av… Jun 3, 2017
java Merge 3.3.x into master Jul 18, 2017
javanano Add a notice for nano. Mar 16, 2017
jenkins Merge 3.3.x into master Jul 18, 2017
js Merge pull request #3375 from TeBoring/3.3.x Jul 19, 2017
kokoro Add continuous testing config files for Kokoro Jun 7, 2017
m4 Fixed cross compilations with the Autotools build Jan 3, 2017
more_tests Add makefile for extended tests to be run before release. Jan 12, 2010
objectivec Expose the initializer for unknown fields. Jul 5, 2017
php compiles removal of newline (#3333) (#3370) Jul 19, 2017
protoc-artifacts Merge pull request #3375 from TeBoring/3.3.x Jul 19, 2017
python Merge pull request #3179 from bjwatson/fix-duration-typo Jul 20, 2017
ruby Merge 3.3.x into master Jul 18, 2017
src Fixed dynamic initialization for C++ lite Jul 19, 2017
third_party Added C++ benchmark. (#1525) Sep 23, 2016
util/python Remove hack for building Python support with Bazel. Feb 25, 2016
.gitignore bazel: add bazel symlinks to .gitignore Jun 16, 2017
.gitmodules Added C++ benchmark. (#1525) Sep 23, 2016
.travis.yml Convert C# projects to MSBuild (csproj) format May 24, 2017
BUILD Merge 3.3.x into master Jul 18, 2017
CHANGES.txt Update version number and changelog for 3.3.0 Apr 6, 2017
CONTRIBUTORS.txt Add nano proto authors and update LICENSE file to include Android.mk. Nov 20, 2014
LICENSE Add support for POWER Linux Nov 3, 2015
Makefile.am Support PHP generic services (#3269) Jul 18, 2017
Protobuf.podspec Merge 3.3.x into master Jul 18, 2017
README.md Updated links to use https Jun 23, 2017
WORKSPACE Fix gson dependency. Sep 21, 2016
appveyor.bat Convert C# projects to MSBuild (csproj) format May 24, 2017
appveyor.yml Convert C# projects to MSBuild (csproj) format May 24, 2017
autogen.sh Update gmock links. Aug 26, 2016
composer.json Follows proper autoloading standards (#3123) Jun 14, 2017
configure.ac Update version number to 3.3.2 Jun 21, 2017
generate_changelog.py generate_changelog.py: flush output so piping works correctly. Dec 10, 2016
generate_descriptor_proto.sh Down-integrate from google3. Mar 29, 2017
gmock.BUILD Update repo to use google test Sep 9, 2016
post_process_dist.sh Add php files for make dist. Oct 10, 2016
protobuf-lite.pc.in Uncomment conflict fields from pkg-config files. May 12, 2015
protobuf.bzl Adding default shell env Apr 3, 2017
protobuf.pc.in Uncomment conflict fields from pkg-config files. May 12, 2015
six.BUILD Add srcs_version = "PY2AND3" in BUILD files Dec 3, 2015
tests.sh Travis: Exclude CMake .pc files Jul 23, 2017
update_file_lists.sh Fix C++ build for down-integration. Mar 29, 2017


Protocol Buffers - Google's data interchange format

Build Status Build status Build Status Build Status Build Status

Copyright 2008 Google Inc.



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.

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 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:


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:


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.

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
C++ (include C++ runtime and protoc) src
Java java
Python python
Objective-C objectivec
C# csharp
JavaNano javanano
JavaScript js
Ruby ruby
Go golang/protobuf
PHP php
Dart dart-lang/protobuf


The complete documentation for Protocol Buffers is available via the web at: