Protocol Buffers - Google's data interchange format
Find a file
Emmanuel Odeke 769b693564
compiler/cli: PrintHelpText prints to stdout instead of stderr
Fixes #698.

PrintHelpText now prints to standard output instead of to standard error.
The purpose of this CL is to make it easy for users to grep for matches
otherwise stderr output has to be awkwardly redirectly to stdout
using this shell trick  `2>&1`, for example
```shell
protoc --help 2>&1 | grep cpp
```

of which we shouldn't be making users have to work that hard just to
get use of --help.

+ Exhibits:
* Before:
```shell
$ protoc --help | grep cpp
Usage: protoc [OPTION] PROTO_FILES
Parse PROTO_FILES and generate output based on the options given:
  -IPATH, --proto_path=PATH   Specify the directory in which to search
for
                              imports.  May be specified multiple times;
                              directories will be searched in order.  If
not
                              given, the current working directory is
used.
  --version                   Show version info and exit.
  -h, --help                  Show this text and exit.
  --encode=MESSAGE_TYPE       Read a text-format message of the given
type
                              from standard input and write it in binary
                              to standard output.  The message type must
                              be defined in PROTO_FILES or their
imports.
  --decode=MESSAGE_TYPE       Read a binary message of the given type
from
                              standard input and write it in text format
                              to standard output.  The message type must
                              be defined in PROTO_FILES or their
imports.
  --decode_raw                Read an arbitrary protocol message from
                              standard input and write the raw tag/value
                              pairs in text format to standard output.
No
                              PROTO_FILES should be given when using
this
                              flag.
  -oFILE,                     Writes a FileDescriptorSet (a protocol
buffer,
    --descriptor_set_out=FILE defined in descriptor.proto) containing
all of
                              the input files to FILE.
  --include_imports           When using --descriptor_set_out, also
include
                              all dependencies of the input files in the
                              set, so that the set is self-contained.
  --include_source_info       When using --descriptor_set_out, do not
strip
                              SourceCodeInfo from the
FileDescriptorProto.
                              This results in vastly larger descriptors
that
                              include information about the original
                              location of each decl in the source file
as
                              well as surrounding comments.
  --dependency_out=FILE       Write a dependency output file in the
format
                              expected by make. This writes the
transitive
                              set of input file paths to FILE
  --error_format=FORMAT       Set the format in which to print errors.
                              FORMAT may be 'gcc' (the default) or
'msvs'
                              (Microsoft Visual Studio format).
  --print_free_field_numbers  Print the free field numbers of the
messages
                              defined in the given proto files. Groups
share
                              the same field number space with the
parent
                              message. Extension ranges are counted as
                              occupied fields numbers.

  --plugin=EXECUTABLE         Specifies a plugin executable to use.
                              Normally, protoc searches the PATH for
                              plugins, but you may specify additional
                              executables not in the path using this
flag.
                              Additionally, EXECUTABLE may be of the
form
                              NAME=PATH, in which case the given plugin
name
                              is mapped to the given executable even if
                              the executable's own name differs.
  --cpp_out=OUT_DIR           Generate C++ header and source.
  --csharp_out=OUT_DIR        Generate C# source file.
  --java_out=OUT_DIR          Generate Java source file.
  --javanano_out=OUT_DIR      Generate Java Nano source file.
  --js_out=OUT_DIR            Generate JavaScript source.
  --objc_out=OUT_DIR          Generate Objective C header and source.
  --python_out=OUT_DIR        Generate Python source file.
  --ruby_out=OUT_DIR          Generate Ruby source file.
```

* After:
```shell
$ protoc --help | grep cpp
  --plugin=EXECUTABLE         Specifies a plugin executable to use.
                              Normally, protoc searches the PATH for
                              plugins, but you may specify additional
                              executables not in the path using this
flag.
                              Additionally, EXECUTABLE may be of the
form
                              NAME=PATH, in which case the given plugin
name
                              is mapped to the given executable even if
                              the executable's own name differs.
  --cpp_out=OUT_DIR           Generate C++ header and source.
  --csharp_out=OUT_DIR        Generate C# source file.
  --java_out=OUT_DIR          Generate Java source file.
  --javanano_out=OUT_DIR      Generate Java Nano source file.
  --js_out=OUT_DIR            Generate JavaScript source.
  --objc_out=OUT_DIR          Generate Objective C header and source.
  --python_out=OUT_DIR        Generate Python source file.
  --ruby_out=OUT_DIR          Generate Ruby source file.
```
2017-03-08 11:42:11 -07: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 Implement json encoding decoding for php. (#2682) 2017-02-08 10:27:54 -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 Add bazel protobuf resources 2017-02-01 07:16:22 -07: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 Prefer the term "3-Clause BSD License" over "New BSD License" 2017-02-28 09:58:24 +01:00
javanano Prefer the term "3-Clause BSD License" over "New BSD License" 2017-02-28 09:58:24 +01:00
jenkins Update commit id in Dockerfile to trigger update. (#2467) 2016-12-08 14:39:20 -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 Add mergeFrom method on Message (#2766) 2017-03-01 10:39:48 -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 Merge pull request #2755 from xfxyjwf/rubycomp 2017-03-02 14:33:02 -08:00
src compiler/cli: PrintHelpText prints to stdout instead of stderr 2017-03-08 11:42:11 -07: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 Add Ruby compatibilty test against 3.0.0. 2017-02-27 17:38:54 -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 Merge pull request #2701 from anandolee/master 2017-02-13 10:54: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/