Protocol Buffers - Google's data interchange format (grpc依赖) https://developers.google.com/protocol-buffers/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Josh Haberman ca5f951137 More fixes for google3 import. 6 years ago
google/protobuf Merge branch 'arrayapi' into defcleanup 6 years ago
kokoro/ubuntu Make Bazel print output for failed tests. 6 years ago
tests Merge branch 'arrayapi' into defcleanup 6 years ago
third_party/lunit Removed the JIT. Nobody was actually using it, and table-driven should achieve 80-90% of the perf. 6 years ago
tools More fixes for google3 import. 6 years ago
upb Fixes for Google import. 6 years ago
upbc Merge branch 'arrayapi' into defcleanup 6 years ago
.gitignore Implement json decoding for Any message. (#130) 6 years ago
.gitmodules
BUILD More fixes for google3 import. 6 years ago
CMakeLists.txt Removed old-style C++ handlers that relied on UB in favor of more normal ones. 6 years ago
CONTRIBUTING.md
DESIGN.md
LICENSE
README.md
WORKSPACE Updates to build system for upb C++ compiler. 6 years ago
build_defs.bzl More fixes for google3 import. 6 years ago
lua.BUILD
ragel.BUILD Added missing files from Bazel build. 6 years ago
travis.sh

README.md

μpb - a small protobuf implementation in C

Build Status Coverage Status

μpb is a small protobuf implementation written in C.

API and ABI are both subject to change! Please do not distribute as a shared library for this reason (for now at least).

Building the core libraries

The core libraries are pure C99 and have no dependencies.

$ make

This will create a separate C library for each core library in lib/. They are built separately to help your binaries slim, so you don't need to link in things you neither want or need.

Other useful targets:

$ make tests
$ make test

C and C++ API

The public C/C++ API is defined by all of the .h files in upb/ except .int.h files (which are internal-only).

Lua bindings

Lua bindings provide μpb's functionality to Lua programs. The bindings target Lua 5.1, Lua 5.2, LuaJIT, and (soon) Lua 5.3.

To build the Lua bindings, the Lua libraries must be installed. Once they are installed, run:

$ make lua

Note that if the Lua headers are not in a standard place, you may need to pass custom flags:

$ make lua USER_CPPFLAGS=`pkg-config lua5.2 --cflags`

To test the Lua bindings:

$ make testlua

Contact

Author: Josh Haberman (jhaberman@gmail.com, haberman@google.com)