my rage from v8 is spilling over
Go to file
Feng Xiao 61e87f3d41 Use per-type table to lookup JSON name.
Different fields from different messages can map to the same JSON name
and the original global lookup table is only capable of mapping one of
such fields. This change converts the global table to per-type tables
so fields from different messages won't conflict.
2017-03-09 16:30:15 -08:00
benchmarks Added C++ benchmark. (#1525) 2016-09-23 11:07:45 -07:00
cmake Detect if Descriptor.cs changes for csharp 2017-03-02 17:15:58 -08:00
conformance Merge pull request #2819 from haberman/pythonexcept 2017-03-09 14:58:01 -08:00
csharp There might be duplicated enum values when allow_alias is true. Add PreferredAlias into OriginalNameAttribute to remove the duplication (#2727) 2017-02-28 10:51:19 -08:00
docs Fix Bad Link for Common Lisp 2017-03-08 15:24:04 -08:00
editors [master] Add dependency cl. Fixes google/protobuf#295. 2016-08-05 15:13:12 +08:00
examples Integrate from internal code base. 2016-07-13 13:48:40 -07:00
java Merge pull request #2602 from GreatFruitOmsk/issue-2428 2017-03-08 15:28:34 -08:00
javanano Prefer the term "3-Clause BSD License" over "New BSD License" 2017-02-28 09:58:24 +01:00
jenkins Rename encode/decode to serializeToString/mergeFromString (#2795) 2017-03-08 14:31:34 -08:00
js Use closurebuilder.py in favor of calcdeps.py for compiling JavaScript 2017-03-01 07:43:11 -08:00
m4 Fixed cross compilations with the Autotools build 2017-01-03 13:14:39 -08:00
more_tests Add makefile for extended tests to be run before release. 2010-01-12 22:45:15 +00:00
objectivec Handing threading race resolving methods. 2017-03-02 16:34:11 -05:00
php Rename encode/decode to serializeToString/mergeFromString (#2795) 2017-03-08 14:31:34 -08:00
protoc-artifacts Prefer the term "3-Clause BSD License" over "New BSD License" 2017-02-28 09:58:24 +01:00
python Merge pull request #2613 from aausch/fix_memory_leak 2017-03-06 16:48:54 -08:00
ruby Ruby: wrap calls to memcpy so that gem is compatible with pre-2.14 glibc 2017-03-09 10:03:22 -08:00
src Use per-type table to lookup JSON name. 2017-03-09 16:30:15 -08:00
third_party Added C++ benchmark. (#1525) 2016-09-23 11:07:45 -07:00
util/python Remove hack for building Python support with Bazel. 2016-02-25 12:52:21 -08:00
.gitignore Add conformance test for php (#2655) 2017-02-01 12:47:58 -08:00
.gitmodules Added C++ benchmark. (#1525) 2016-09-23 11:07:45 -07:00
.travis.yml Add python compatibility tests against v2.5.0 amd run on Travis. 2017-01-26 11:05:16 -08:00
appveyor.bat Rename UNICODE to protobuf_UNICODE 2016-09-01 17:18:22 -07:00
appveyor.yml Use "appveyor DownloadFile" 2016-10-10 11:44:21 -07:00
autogen.sh Update gmock links. 2016-08-25 14:28:59 -07:00
BUILD Merge pull request #2751 from keveman/master 2017-03-06 10:41:19 -08:00
CHANGES.txt Prefer the term "3-Clause BSD License" over "New BSD License" 2017-02-28 09:58:24 +01:00
composer.json Fixed issue with autoloading - Invalid paths (#2538) 2016-12-28 13:33:36 -08:00
configure.ac Merge 3.2.x branch into master (#2648) 2017-01-31 09:17:32 -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_changelog.py generate_changelog.py: flush output so piping works correctly. 2016-12-09 16:13:18 -08:00
generate_descriptor_proto.sh Fix #2071 replacing /bin/sh with bash 2016-09-07 14:46:50 +10:00
gmock.BUILD Update repo to use google test 2016-09-09 13:10:56 -04:00
LICENSE Add support for POWER Linux 2015-11-03 14:49:42 -08:00
Makefile.am Ruby: wrap calls to memcpy so that gem is compatible with pre-2.14 glibc 2017-03-09 10:03:22 -08:00
post_process_dist.sh Add php files for make dist. 2016-10-10 11:44:21 -07:00
protobuf-lite.pc.in Uncomment conflict fields from pkg-config files. 2015-05-12 17:50:05 +02:00
protobuf.bzl Bazel can build protobuf when it's not in the root 2017-02-08 12:19:40 -05:00
protobuf.pc.in Uncomment conflict fields from pkg-config files. 2015-05-12 17:50:05 +02:00
Protobuf.podspec Prefer the term "3-Clause BSD License" over "New BSD License" 2017-02-28 09:58:24 +01:00
README.md README.md: Make docs URL a link 2017-02-18 13:05:19 -08:00
six.BUILD Add srcs_version = "PY2AND3" in BUILD files 2015-12-03 13:16:06 -08:00
tests.sh Rename encode/decode to serializeToString/mergeFromString (#2795) 2017-03-08 14:31:34 -08:00
update_file_lists.sh Fix bugs on windows 2015-08-25 17:58:48 -07:00
WORKSPACE Fix gson dependency. 2016-09-21 22:51:36 +00:00

Protocol Buffers - Google's data interchange format

Build Status Build status Build Status 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 php

Usage

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

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