No Description

Joshua Haberman 3dd3238189 Merge pull request #1306 from silviulica/master 9 years ago
benchmarks fb77cc9d9f More cleanup, based around searches for "Google.ProtocolBuffers" 10 years ago
cmake fe96a215d9 Clarified that 'nmake' must be run before 'nmake check'. 9 years ago
conformance 78da66698b Changed Ruby to properly camelCase its JSON by default. 9 years ago
csharp ad2d775e1b Replace StringBuilder with TextWriter in JsonFormatter 9 years ago
editors 5db217305f down-integrate internal changes 10 years ago
examples 3ee2e20539 Merge pull request #1144 from dongjoon-hyun/remove_redundant_the 9 years ago
java 7a9040fe7f Remove redundant `the` in comments. 9 years ago
javanano 7d075a44c1 Update version number and fix javadoc errors. 9 years ago
js c9f8a1b006 Moved CommonJS-specific files into commonjs directory 9 years ago
m4 fe066bd514 Merge pull request #789 from motahan/solaris64_fix 9 years ago
more_tests 7db148f92a Add makefile for extended tests to be run before release. 16 years ago
objectivec 36650a07cf HeaderDoc support in the library and generated sources 9 years ago
protoc-artifacts 7b08d49e9d Fix typos in README.md/CHANGES.txt 9 years ago
python 3dd3238189 Merge pull request #1306 from silviulica/master 9 years ago
ruby e70f9256af Merge pull request #1139 from haberman/rubyjsoncamel 9 years ago
src 36650a07cf HeaderDoc support in the library and generated sources 9 years ago
util 985c968443 Remove hack for building Python support with Bazel. 9 years ago
.gitignore 5477f8cdba Manually down-integrate python JSON struct support from internal code base. 9 years ago
.travis.yml e0dd14cd3c List python_cpp as failing on OS X 9 years ago
BUILD 985c968443 Remove hack for building Python support with Bazel. 9 years ago
CHANGES.txt 81e75c1f99 Some fixes for the most recent release notes. 9 years ago
CONTRIBUTORS.txt 49bc8c0963 Add nano proto authors and update LICENSE file to include Android.mk. 11 years ago
LICENSE 2a50e67c78 Add support for POWER Linux 10 years ago
Makefile.am 35227b4f31 Removed the generated Ruby file from Makefile.am. 9 years ago
Protobuf.podspec f492dd8aa4 Include 'source' attribute in the podspec 9 years ago
README.md e5ec85e7a5 Fix typos in README.md 9 years ago
WORKSPACE 985c968443 Remove hack for building Python support with Bazel. 9 years ago
appveyor.bat c3aa4c2675 Improved SHARED build from CMake project 10 years ago
appveyor.yml e841bac4fc Down-integrate from internal code base. 10 years ago
autogen.sh c0a7ea4d2f Add support for arguments. 10 years ago
configure.ac b7610f129d Add missing files to EXTRA_DIST. 10 years ago
generate_descriptor_proto.sh 957e877d52 Generate C# code whenever descriptor.proto changes 9 years ago
gmock.BUILD cc42db83d3 Fix headers for gmock.BUILD 10 years ago
post_process_dist.sh 9dcd24df10 Add js to post_process_dist.sh. 10 years ago
protobuf-lite.pc.in 37e7a3c4b8 Uncomment conflict fields from pkg-config files. 10 years ago
protobuf.bzl 985c968443 Remove hack for building Python support with Bazel. 9 years ago
protobuf.pc.in 37e7a3c4b8 Uncomment conflict fields from pkg-config files. 10 years ago
six.BUILD 29799238c2 Add srcs_version = "PY2AND3" in BUILD files 10 years ago
travis.sh 8c784506aa Disable the xctool updates 9 years ago
update_file_lists.sh ff7bdad231 Fix bugs on windows 10 years ago

README.md

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/