Skip to content

Minimalist protocol buffer decoder and encoder in C++

License

Notifications You must be signed in to change notification settings

summershrimp/protozero

Repository files navigation

protozero

Minimalistic protocol buffer decoder and encoder in C++.

Designed for high performance. Suitable for writing zero copy parsers and encoders with minimal need for run-time allocation of memory.

Low-level: this is designed to be a building block for writing a very customized decoder for a stable protobuf schema. If your protobuf schema is changing frequently or lazy decoding is not critical for your application then this approach offers no value: just use the decoding API available via the C++ API that can be generated via the Google Protobufs protoc program.

Travis Build Status Appveyor Build Status Coverage Status

Depends

How it works

The protozero code does not read .proto files used by the usual Protobuf implementations. The developer using protozero has to manually "translate" the .proto description into code. This means there is no way to access any of the information from the .proto description. This results in a few restrictions:

  • The names of the fields are not available.
  • Enum names are not available, you'll have to use the values they are defined with.
  • Default values are not available.
  • Field types have to be hardcoded. The library does not know which types to expect, so the user of the library has to supply the right types. Some checks are made using assert(), but mostly the user has to take care of that.

The library will make sure not to overrun the buffer it was given, but basically all other checks have to be made in user code!

See the tutorial for more information on how to use it.

Call make doc to build the Doxygen documentation. (You'll need Doxygen installed.) Then open doc/html/index.html in your browser to read it.

Limitations

  • The current implementation does not support big-endian machines. Fixed sized integers and floats/doubles will not decode properly.
  • A protobuf message has to fit into memory completely, otherwise it can not be parsed with this library. There is no streaming support.
  • The length of a string, bytes, or submessage can't be more than 2^31-1.
  • The Google Protobuf spec documents that a non-repeated field can actually appear several times in a message and the implementation is required to return the value of the last version of that field in this case. pbf_reader.hpp does not enforce this. If this feature is needed in your case, you have to do this yourself.
  • There is no specific support for maps but they can be used as described in the "Backwards compatibility" section of https://developers.google.com/protocol-buffers/docs/proto3#maps.

Tests

Extensive tests are included. Call

make test

to build all tests and run them.

You can also use gyp to build the tests:

gyp --depth=. --build=Release
./out/Release/tests

This will clobber the Makefile from the repository! Instead of Release you can use Debug for a debug build.

Coverage report

To get a coverage report compile and link with --coverage:

CXXFLAGS="--coverage" LDFLAGS="--coverage" make test

If you are using g++ use gcov to generate a report (results are in *.gcov files):

gcov -lp test/run_all_tests.o test/t/*/runtest.o

If you are using clang++ use llvm-cov instead:

llvm-cov gcov -lp test/run_all_tests.o test/t/*/runtest.o

If you are using g++ you can use gcovr to generate nice HTML output:

mkdir -p coverage
gcovr -r . --html --html-details -o coverage/index.html

Open coverage/index.html in your browser to see the report.

Cppcheck

For extra checks with Cppcheck you can call

make check

About

Minimalist protocol buffer decoder and encoder in C++

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 98.6%
  • CMake 1.3%
  • Shell 0.1%