my rage from v8 is spilling over
Go to file
2016-03-05 09:32:59 +01:00
benchmarks More cleanup, based around searches for "Google.ProtocolBuffers" 2015-06-26 20:13:07 +01:00
cmake Clarified that 'nmake' must be run before 'nmake check'. 2016-02-10 14:44:29 -08:00
conformance Changed Ruby to properly camelCase its JSON by default. 2016-02-18 10:50:14 -08:00
csharp Fix copy/paste typo in CodedInputStreamTest 2016-03-01 07:30:40 +00: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 Remove redundant the in comments. 2016-02-03 15:27:27 -08:00
javanano Update version number and fix javadoc errors. 2016-01-06 15:47:41 -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 Support ObjC Generic Collections 2016-02-18 13:55:59 -05:00
protoc-artifacts Fix typos in README.md/CHANGES.txt 2016-01-11 14:52:01 -08:00
python Add a modified patch from craigcitro@ to handle namespace sharing. 2016-02-18 16:12:11 -08:00
ruby Merge pull request #1139 from haberman/rubyjsoncamel 2016-03-04 17:31:11 -08:00
src Fix compiling clang/libc++ builds. (Issue: #1266) 2016-03-05 09:32:59 +01: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 List python_cpp as failing on OS X 2016-02-18 13:22:05 -05: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 Remove hack for building Python support with Bazel. 2016-02-25 12:52:21 -08: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 Generate C# code whenever descriptor.proto changes 2016-02-15 10:33:13 +00: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 Removed the generated Ruby file from Makefile.am. 2016-03-03 23:52:31 -08: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 Remove hack for building Python support with Bazel. 2016-02-25 12:52:21 -08:00
protobuf.pc.in Uncomment conflict fields from pkg-config files. 2015-05-12 17:50:05 +02:00
Protobuf.podspec Include 'source' attribute in the podspec 2016-02-10 19:19:17 -08: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
travis.sh Disable the xctool updates 2016-02-18 12:13:20 -05:00
update_file_lists.sh Fix bugs on windows 2015-08-25 17:58:48 -07:00
WORKSPACE Remove hack for building Python support with Bazel. 2016-02-25 12:52:21 -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/