74bf45f379
The example utilizes native bazel rules (proto_library, cc_proto_library, java_proto_library, java_lite_proto_library) to show how easy it is to build protobuf with bazel's native support. It also makes use of well known types which was not possible until the latest bazel 0.5.4 release and https://github.com/google/protobuf/pull/3594 .
89 lines
4.6 KiB
Markdown
89 lines
4.6 KiB
Markdown
Protocol Buffers - Google's data interchange format
|
|
===================================================
|
|
|
|
[![Build Status](https://travis-ci.org/google/protobuf.svg?branch=master)](https://travis-ci.org/google/protobuf) [![Build status](https://ci.appveyor.com/api/projects/status/73ctee6ua4w2ruin?svg=true)](https://ci.appveyor.com/project/protobuf/protobuf) [![Build Status](https://grpc-testing.appspot.com/buildStatus/icon?job=protobuf_branch)](https://grpc-testing.appspot.com/job/protobuf_branch) [![Build Status](https://grpc-testing.appspot.com/job/protobuf_branch_32/badge/icon)](https://grpc-testing.appspot.com/job/protobuf_branch_32) [![Build Status](http://ci.bazel.io/buildStatus/icon?job=protobuf)](http://ci.bazel.io/job/protobuf/)
|
|
|
|
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](https://developers.google.com/protocol-buffers/).
|
|
|
|
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](src/README.md) 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](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:
|
|
|
|
[https://repo1.maven.org/maven2/com/google/protobuf/protoc/](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](src/README.md).
|
|
|
|
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](src) |
|
|
| Java | [java](java) |
|
|
| Python | [python](python) |
|
|
| Objective-C | [objectivec](objectivec) |
|
|
| C# | [csharp](csharp) |
|
|
| JavaNano | [javanano](javanano) |
|
|
| JavaScript | [js](js) |
|
|
| Ruby | [ruby](ruby) |
|
|
| Go | [golang/protobuf](https://github.com/golang/protobuf) |
|
|
| PHP | [php](php) |
|
|
| Dart | [dart-lang/protobuf](https://github.com/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](examples) directory.
|
|
|
|
Documentation
|
|
-------------
|
|
|
|
The complete documentation for Protocol Buffers is available via the
|
|
web at:
|
|
|
|
https://developers.google.com/protocol-buffers/
|