README.md 4.56 KB
Newer Older
temporal's avatar
temporal committed
1
Protocol Buffers - Google's data interchange format
2 3 4 5
===================================================

[![Build Status](https://travis-ci.org/google/protobuf.svg?branch=master)](https://travis-ci.org/google/protobuf)

temporal's avatar
temporal committed
6 7 8 9
Copyright 2008 Google Inc.

This directory contains the Java Protocol Buffers runtime library.

temporal's avatar
temporal committed
10 11 12 13
Installation - With Maven
=========================

The Protocol Buffers build is managed using Maven.  If you would
14
rather build without Maven, see below.
temporal's avatar
temporal committed
15 16 17 18 19

1) Install Apache Maven if you don't have it:

     http://maven.apache.org/

20 21 22 23
2) Build the C++ code, or obtain a binary distribution of protoc (see
   the toplevel [README.md](../README.md)). If you install a binary
   distribution, make sure that it is the same version as this package.
   If in doubt, run:
temporal's avatar
temporal committed
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46

     $ protoc --version

   You will need to place the protoc executable in ../src.  (If you
   built it yourself, it should already be there.)

3) Run the tests:

     $ mvn test

   If some tests fail, this library may not work correctly on your
   system.  Continue at your own risk.

4) Install the library into your Maven repository:

     $ mvn install

5) If you do not use Maven to manage your own build, you can build a
   .jar file to use:

     $ mvn package

   The .jar will be placed in the "target" directory.
kenton@google.com's avatar
kenton@google.com committed
47

48
The above instructions will install 3 maven artifacts:
49

50 51 52 53 54 55 56 57 58
  * protobuf-java: The core Java Protocol Buffers library. Most users only
                   need this artifact.
  * protobuf-lite: The lite version of core Java Protobuf Buffers library. It
                   is a subset of the core library and is used together with
                   the 'lite' code generator flag to reduce generated code size
                   for mobile.
  * protobuf-java-util: Utilities to work with protos. It contains JSON support
                        as well as utilities to work with proto3 well-known
                        types.
temporal's avatar
temporal committed
59

temporal's avatar
temporal committed
60 61 62 63 64
Installation - Without Maven
============================

If you would rather not install Maven to build the library, you may
follow these instructions instead.  Note that these instructions skip
65 66
running unit tests and only describes how to install the core protobuf
library (without the util package).
temporal's avatar
temporal committed
67 68 69 70 71 72 73 74 75 76 77 78

1) Build the C++ code, or obtain a binary distribution of protoc.  If
   you install a binary distribution, make sure that it is the same
   version as this package.  If in doubt, run:

     $ protoc --version

   If you built the C++ code without installing, the compiler binary
   should be located in ../src.

2) Invoke protoc to build DescriptorProtos.java:

79
     $ protoc --java_out=core/src/main/java -I../src \
temporal's avatar
temporal committed
80 81
         ../src/google/protobuf/descriptor.proto

82
3) Compile the code in core/src/main/java using whatever means you prefer.
temporal's avatar
temporal committed
83 84 85

4) Install the classes wherever you prefer.

86 87 88 89 90
Compatibility Notice
====================

* Protobuf minor version releases are backwards-compatible. If your code
  can build/run against the old version, it's expected to build/run against
91
  the new version as well. Both binary compatibility and source compatibility
92 93 94 95 96 97 98 99 100
  are guaranteed for minor version releases if the user follows the guideline
  described in this section.

* Protobuf major version releases may also be backwards-compatbile with the
  last release of the previous major version. See the release notice for more
  details.

* APIs marked with the @ExperimentalApi annotation are subject to change. They
  can be modified in any way, or even removed, at any time. Don't use them if
101
  compatibility is needed. If your code is a library itself (i.e. it is used on
102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
  the CLASSPATH of users outside your own control), you should not use
  experimental APIs, unless you repackage them (e.g. using ProGuard).

* Deprecated non-experimental APIs will be removed two years after the release
  in which they are first deprecated. You must fix your references before this
  time. If you don't, any manner of breakage could result (you are not
  guaranteed a compilation error).

* Protobuf message interfaces/classes are designed to be subclassed by protobuf
  generated code only. Do not subclass these message interfaces/classes
  yourself. We may add new methods to the message interfaces/classes which will
  break your own subclasses.

* Don't use any method/class that is marked as "used by generated code only".
  Such methods/classes are subject to change.

* Protobuf LITE runtime APIs are not stable yet. They are subject to change even
  in minor version releases.

Documentation
=============
temporal's avatar
temporal committed
123 124 125 126

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

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