my rage from v8 is spilling over
Go to file
Jie Luo 09292d5759 Merge pull request #1392 from anandolee/master
Sync the manually integrate changes in google3/third_party
2016-04-07 11:05:05 -07:00
benchmarks More cleanup, based around searches for "Google.ProtocolBuffers" 2015-06-26 20:13:07 +01:00
cmake Added access_level for types 2016-04-05 09:47:11 -07:00
conformance Changed Ruby to properly camelCase its JSON by default. 2016-02-18 10:50:14 -08:00
csharp Remove duplicate test cases. 2016-04-01 17:18:45 +01:00
editors down-integrate internal changes 2015-05-21 19:32:02 -07:00
examples Merge pull request #1144 from dongjoon-hyun/remove_redundant_the 2016-02-11 17:17:48 -08:00
java Allow custom URLs for Any in JsonFormat 2016-03-18 23:06:14 -07:00
javanano Update version number and fix javadoc errors. 2016-01-06 15:47:41 -08:00
jenkins Rearranged and commented files for running under Jenkins. 2016-03-04 14:34:30 -08:00
js Moved CommonJS-specific files into commonjs directory 2016-02-24 14:23:08 -08:00
m4 Merge pull request #789 from motahan/solaris64_fix 2016-01-20 16:57:01 -08:00
more_tests Add makefile for extended tests to be run before release. 2010-01-12 22:45:15 +00:00
objectivec Merge pull request #1391 from thomasvl/string_tweaks 2016-04-06 15:52:17 -04:00
protoc-artifacts Fix typos in README.md/CHANGES.txt 2016-01-11 14:52:01 -08:00
python Linking the cpp implementation extension statically with libprotobuf 2016-04-01 15:58:48 -07:00
ruby Merge pull request #1139 from haberman/rubyjsoncamel 2016-03-04 17:31:11 -08:00
src Merge pull request #1392 from anandolee/master 2016-04-07 11:05:05 -07:00
util/python Remove hack for building Python support with Bazel. 2016-02-25 12:52:21 -08:00
.gitignore Manually down-integrate python JSON struct support from internal code base. 2016-01-29 18:10:50 -08:00
.travis.yml Merge branch 'master' into docker 2016-03-29 16:24:35 -07:00
appveyor.bat Improved SHARED build from CMake project 2015-10-15 02:56:48 +03:00
appveyor.yml Down-integrate from internal code base. 2015-12-11 17:10:28 -08:00
autogen.sh Add support for arguments. 2015-10-13 09:42:20 -07:00
BUILD Update BUILD 2016-04-04 16:13:31 -04:00
CHANGES.txt Some fixes for the most recent release notes. 2016-02-18 13:59:33 -08:00
configure.ac Add missing files to EXTRA_DIST. 2015-12-28 14:18:49 -08:00
CONTRIBUTORS.txt Add nano proto authors and update LICENSE file to include Android.mk. 2014-11-20 14:27:46 -08:00
generate_descriptor_proto.sh Shrink ObjC overhead (generated size and some runtime sizes) 2016-03-17 10:04:21 -04:00
gmock.BUILD Fix headers for gmock.BUILD 2015-12-01 22:52:42 +01:00
LICENSE Add support for POWER Linux 2015-11-03 14:49:42 -08:00
Makefile.am Shrink ObjC overhead (generated size and some runtime sizes) 2016-03-17 10:04:21 -04:00
post_process_dist.sh Add js to post_process_dist.sh. 2015-12-28 16:31:10 -08:00
protobuf-lite.pc.in Uncomment conflict fields from pkg-config files. 2015-05-12 17:50:05 +02:00
protobuf.bzl pass correct args to protoc for java wellknown protos when used as an external repository 2016-03-10 15:04:46 -08:00
protobuf.pc.in Uncomment conflict fields from pkg-config files. 2015-05-12 17:50:05 +02:00
Protobuf.podspec Shrink ObjC overhead (generated size and some runtime sizes) 2016-03-17 10:04:21 -04:00
README.md Fix typos in README.md 2016-01-25 21:41:31 +01:00
six.BUILD Add srcs_version = "PY2AND3" in BUILD files 2015-12-03 13:16:06 -08:00
tests.sh Merge branch 'master' into docker 2016-03-29 16:24:35 -07:00
update_file_lists.sh Fix bugs on windows 2015-08-25 17:58:48 -07:00
WORKSPACE add java/util support based on java/util/pom.xml 2016-03-11 18:08:09 -08:00

Protocol Buffers - Google's data interchange format

Build Status Build status

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.

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:

https://github.com/google/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:

http://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.

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 TBD

Usage

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

https://developers.google.com/protocol-buffers/