Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
519fbe94
Commit
519fbe94
authored
Mar 18, 2015
by
Jisi Liu
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #245 from numberten/patch-1
Rename README.txt to README.md
parents
d8866ed5
0481bf32
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
62 additions
and
32 deletions
+62
-32
Makefile.am
Makefile.am
+3
-3
README.md
java/README.md
+7
-1
README.md
javanano/README.md
+41
-22
README.md
python/README.md
+11
-6
No files found.
Makefile.am
View file @
519fbe94
...
...
@@ -152,7 +152,7 @@ java_EXTRA_DIST= \
java/src/test/java/com/google/protobuf/test_check_utf8_size.proto
\
java/src/test/java/com/google/protobuf/test_custom_options.proto
\
java/pom.xml
\
java/README.
txt
java/README.
md
javanano_EXTRA_DIST
=
\
javanano/src/main/java/com/google/protobuf/nano/CodedOutputByteBufferNano.java
\
...
...
@@ -190,7 +190,7 @@ javanano_EXTRA_DIST=
javanano/src/test/java/com/google/protobuf/nano/unittest_multiple_nano.proto
\
javanano/src/test/java/com/google/protobuf/nano/unittest_enum_class_multiple_nano.proto
\
javanano/src/test/java/com/google/protobuf/nano/map_test.proto
\
javanano/README.
txt
\
javanano/README.
md
\
javanano/pom.xml
...
...
@@ -277,7 +277,7 @@ python_EXTRA_DIST= \
python/setup.py
\
python/mox.py
\
python/stubout.py
\
python/README.
txt
python/README.
md
ruby_EXTRA_DIST
=
\
ruby/README.md
\
...
...
java/README.
txt
→
java/README.
md
View file @
519fbe94
Protocol Buffers - Google's data interchange format
===================================================
[
![Build Status
](
https://travis-ci.org/google/protobuf.svg?branch=master
)
](https://travis-ci.org/google/protobuf)
Copyright 2008 Google Inc.
This directory contains the Java Protocol Buffers runtime library.
...
...
@@ -50,17 +54,19 @@ http://maven.apache.org/guides/introduction/introduction-to-profiles.html)
E.g. to install the lite version of the jar, you would run:
$ mvn install -P lite
$ mvn install -P lite
The resulting artifact has the 'lite' classifier. To reference it
for dependency resolution, you would specify it as:
```
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>${version}</version>
<classifier>lite</classifier>
</dependency>
```
Installation - Without Maven
============================
...
...
javanano/README.
txt
→
javanano/README.
md
View file @
519fbe94
Protocol Buffers - Google's data interchange format
===================================================
[
![Build Status
](
https://travis-ci.org/google/protobuf.svg?branch=master
)
](https://travis-ci.org/google/protobuf)
Copyright 2008 Google Inc.
This directory contains the Java Protocol Buffers Nano runtime library.
Installation - With Maven
=========================
-------------------------
The Protocol Buffers build is managed using Maven. If you would
rather build without Maven, see below.
...
...
@@ -41,7 +45,7 @@ rather build without Maven, see below.
The .jar will be placed in the "target" directory.
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
...
...
@@ -66,7 +70,7 @@ running unit tests.
4) Install the classes wherever you prefer.
Nano version
============================
------------
JavaNano is a special code generator and runtime library designed specially for
resource-restricted systems, like Android. It is very resource-friendly in both
...
...
@@ -130,7 +134,9 @@ penalty. This is not a problem if the field has no default or is an
empty default.
Nano Generator options
----------------------
```
java_package -> <file-name>|<package-name>
java_outer_classname -> <file-name>|<package-name>
java_multiple_files -> true or false
...
...
@@ -139,8 +145,10 @@ optional_field_style -> default or accessors
enum_style -> c or java
ignore_services -> true or false
parcelable_messages -> true or false
```
**java_package=\<file-name\>|\<package-name\>**
(no default)
java_package=<file-name>|<package-name> (no default)
This allows overriding the 'java_package' option value
for the given file from the command line. Use multiple
java_package options to override the option for multiple
...
...
@@ -149,7 +157,8 @@ java_package=<file-name>|<package-name> (no default)
the same option defined in the file if present, or the
proto package if present, or the default Java package.
java_outer_classname=<file-name>|<outer-classname> (no default)
**java_outer_classname=\<file-name\>|\<outer-classname\>**
(no default)
This allows overriding the 'java_outer_classname' option
for the given file from the command line. Use multiple
java_outer_classname options to override the option for
...
...
@@ -160,7 +169,8 @@ java_outer_classname=<file-name>|<outer-classname> (no default)
outer class will nest all classes and integer constants
generated from file-scope messages and enums.
java_multiple_files={true,false} (no default)
**java_multiple_files={true,false}**
(no default)
This allows overriding the 'java_multiple_files' option
in all source files and their imported files from the
command line. The final value of this option for each
...
...
@@ -178,10 +188,11 @@ java_multiple_files={true,false} (no default)
incorrect references to the imported messages and enum
constants.
java_nano_generate_has={true,false} (default: false)
**java_nano_generate_has={true,false}**
(default: false)
DEPRECATED. Use optional_field_style=accessors.
If true, generates a public boolean variable has
<fieldname
>
If true, generates a public boolean variable has
\<
fieldname
\
>
accompanying each optional or required field (not present for
repeated fields, groups or messages). It is set to false initially
and upon clear(). If parseFrom(...) reads the field from the wire,
...
...
@@ -195,20 +206,21 @@ java_nano_generate_has={true,false} (default: false)
many cases reading the default works and determining whether the
field was received over the wire is irrelevant.
optional_field_style={default,accessors,reftypes} (default: default)
**optional_field_style={default,accessors,reftypes}**
(default: default)
Defines the style of the generated code for fields.
* default
*
*
default
In the default style, optional fields translate into public mutable
Java fields, and the serialization process is as discussed in the
"IMPORTANT" section above.
* accessors
*
*
accessors
When set to 'accessors', each optional field is encapsulated behind
4 accessors, namely get
<fieldname>(), set<fieldname>(), has<fieldname
>()
and clear
<fieldname
>() methods, with the standard semantics. The hazzer's
4 accessors, namely get
\<
fieldname
\>
(), set
\<
fieldname
\>
(), has
\<
fieldname
\
>
()
and clear
\<
fieldname
\
>
() methods, with the standard semantics. The hazzer's
return value determines whether a field is serialized, so this style is
useful when you need to serialize a field with the default value, or check
if a field has been explicitly set to its default value from the wire.
...
...
@@ -224,7 +236,7 @@ optional_field_style={default,accessors,reftypes} (default: default)
reducing the final code size.
TODO(maxtroy): find ProGuard config that would work the best.
* reftypes
*
*
reftypes
When set to 'reftypes', each proto field is generated as a public Java
field. For primitive types, these fields use the Java reference types
...
...
@@ -254,10 +266,11 @@ optional_field_style={default,accessors,reftypes} (default: default)
required field (you have no reason to), you can only use
java_nano_generate_has=true.
enum_style={c,java} (default: c)
**enum_style={c,java}**
(default: c)
Defines where to put the int constants generated from enum members.
* c
*
*
c
Use C-style, so the enum constants are available at the scope where
the enum is defined. A file-scope enum's members are referenced like
...
...
@@ -265,7 +278,7 @@ enum_style={c,java} (default: c)
referenced as 'Message.ENUM_VALUE'. The enum name is unavailable.
This complies with the Micro code generator's behavior.
* java
*
*
java
Use Java-style, so the enum constants are available under the enum
name and referenced like 'EnumName.ENUM_VALUE' (they are still int
...
...
@@ -277,18 +290,21 @@ enum_style={c,java} (default: c)
compiler inlines all referenced enum constants into the call sites,
the interface remains unused and can be removed by ProGuard.
ignore_services={true,false} (default: false)
**ignore_services={true,false}**
(default: false)
Skips services definitions.
Nano doesn't support services. By default, if a service is defined
it will generate a compilation error. If this flag is set to true,
services will be silently ignored, instead.
parcelable_messages={true,false} (default: false)
**parcelable_messages={true,false}**
(default: false)
Android-specific option to generate Parcelable messages.
To use nano protobufs within the Android repo:
----------------------------------------------
-
Set 'LOCAL_PROTOC_OPTIMIZE_TYPE := nano' in your local .mk file.
When building a Java library or an app (package) target, the build
...
...
@@ -313,17 +329,20 @@ To use nano protobufs within the Android repo:
the two above.
To use nano protobufs outside of Android repo:
----------------------------------------------
-
Link with the generated jar file
<protobuf-root
>java/target/protobuf-java-2.3.0-nano.jar.
\<
protobuf-root
\
>
java/target/protobuf-java-2.3.0-nano.jar.
-
Invoke with --javanano_out, e.g.:
```
./protoc '--javanano_out=\
java_package=src/proto/simple-data.proto|my_package,\
java_outer_classname=src/proto/simple-data.proto|OuterName\
:.' src/proto/simple-data.proto
```
Contributing to nano:
---------------------
Please add/edit tests in NanoTest.java.
...
...
@@ -348,7 +367,7 @@ Please run the following steps to test:
-
"make -j12" and check for build errors
Usage
=====
-----
The complete documentation for Protocol Buffers is available via the
web at:
...
...
python/README.
txt
→
python/README.
md
View file @
519fbe94
Protocol Buffers - Google's data interchange format
===================================================
[
![Build Status
](
https://travis-ci.org/google/protobuf.svg?branch=master
)
](https://travis-ci.org/google/protobuf)
Copyright 2008 Google Inc.
This directory contains the Python Protocol Buffers runtime library.
...
...
@@ -65,9 +69,11 @@ Installation
5) Install:
$ python setup.py install
or:
$ python setup.py install --cpp_implementation
$ python setup.py install
or:
$ python setup.py install --cpp_implementation
This step may require superuser privileges.
NOTE: To use C++ implementation, you need to install C++ protobuf runtime
...
...
@@ -93,8 +99,8 @@ To use the C++ implementation, you need to:
parent directory.
2) Export an environment variable:
$ export PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=cpp
$ export PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION_VERSION=2
$ export PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=cpp
$ export PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION_VERSION=2
You need to export this variable before running setup.py script to build and
install the extension. You must also set the variable at runtime, otherwise
...
...
@@ -103,4 +109,3 @@ change the default so that C++ implementation is used whenever it is available.
It is strongly recommended to run
`python setup.py test`
after setting the
variable to "cpp", so the tests will be against C++ implemented Python
messages.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment