Nav apraksta

Toby Schneider 4fd7bdee48 Update options.md 7 gadi atpakaļ
.github 778478b2a5 Add github issue templates 7 gadi atpakaļ
benchmarks afe98de32a Replace repo links. 7 gadi atpakaļ
cmake afe98de32a Replace repo links. 7 gadi atpakaļ
conformance afe98de32a Replace repo links. 7 gadi atpakaļ
csharp afe98de32a Replace repo links. 7 gadi atpakaļ
docs 4fd7bdee48 Update options.md 7 gadi atpakaļ
editors 979107ec7a Improve fix for https://github.com/google/protobuf/issues/295 8 gadi atpakaļ
examples afe98de32a Replace repo links. 7 gadi atpakaļ
java afe98de32a Replace repo links. 7 gadi atpakaļ
js afe98de32a Replace repo links. 7 gadi atpakaļ
kokoro 409f954673 Revert changed links in Dockerfiles. 7 gadi atpakaļ
m4 478751903a Merge pull request #1333 from cgull/pkg-config-issue 7 gadi atpakaļ
objectivec afe98de32a Replace repo links. 7 gadi atpakaļ
php afe98de32a Replace repo links. 7 gadi atpakaļ
protoc-artifacts afe98de32a Replace repo links. 7 gadi atpakaļ
python afe98de32a Replace repo links. 7 gadi atpakaļ
ruby afe98de32a Replace repo links. 7 gadi atpakaļ
src afe98de32a Replace repo links. 7 gadi atpakaļ
third_party 3c5442a95d Include googletest as a submodule (#3993) 7 gadi atpakaļ
util 985c968443 Remove hack for building Python support with Bazel. 9 gadi atpakaļ
.gitignore 9c7655c9fc Ignore python .egg file to make git status clean #5004 7 gadi atpakaļ
.gitmodules 3c5442a95d Include googletest as a submodule (#3993) 7 gadi atpakaļ
BUILD bde4eaf137 Update build files. 7 gadi atpakaļ
CHANGES.txt afe98de32a Replace repo links. 7 gadi atpakaļ
CONTRIBUTORS.txt 49bc8c0963 Add nano proto authors and update LICENSE file to include Android.mk. 11 gadi atpakaļ
LICENSE 9e080f7ac0 Cleanup LICENSE file. 7 gadi atpakaļ
Makefile.am acd5b05e9f Fix failing tests. 7 gadi atpakaļ
Protobuf.podspec afe98de32a Replace repo links. 7 gadi atpakaļ
README.md afe98de32a Replace repo links. 7 gadi atpakaļ
WORKSPACE 91707246eb Merge pull request #4168 from jin/master 7 gadi atpakaļ
appveyor.bat feb183d895 Appveyor MinGW build 7 gadi atpakaļ
appveyor.yml 82d3d7d250 Merge branch '3.6.x' into merge-3-6-x 7 gadi atpakaļ
autogen.sh 9de4e64cf2 Add cpp tests under release docker image. 7 gadi atpakaļ
composer.json 21b0e5587c Update PHP descriptors (#3391) 8 gadi atpakaļ
configure.ac 94d55e5292 Merge branch '3.6.x' into merge-3-6-x 7 gadi atpakaļ
generate_changelog.py afe98de32a Replace repo links. 7 gadi atpakaļ
generate_descriptor_proto.sh 09354db143 Merge from Google internal for 3.4 release 8 gadi atpakaļ
post_process_dist.sh 9b77e9efe1 Removed javanano from post_process_dist.sh 7 gadi atpakaļ
protobuf-lite.pc.in 37e7a3c4b8 Uncomment conflict fields from pkg-config files. 10 gadi atpakaļ
protobuf.bzl d5f0dac497 Change deprecated Bazel single file attr param 7 gadi atpakaļ
protobuf.pc.in 37e7a3c4b8 Uncomment conflict fields from pkg-config files. 10 gadi atpakaļ
six.BUILD 29799238c2 Add srcs_version = "PY2AND3" in BUILD files 10 gadi atpakaļ
tests.sh a0a17e24d7 Fix go tests. 7 gadi atpakaļ
update_file_lists.sh 2bd7f516e5 fix duplicate mkdir in update_file_lists.sh 7 gadi atpakaļ

README.md

Protocol Buffers - Google's data interchange format

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

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

Quick Start

The best way to learn how to use protobuf is to follow the tutorials in our developer guide:

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

If you want to learn from code examples, take a look at the examples in the examples directory.

Documentation

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

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