mirror of
https://github.com/protobuf-c/protobuf-c.git
synced 2025-01-14 09:17:55 +08:00
56 lines
3.1 KiB
Markdown
56 lines
3.1 KiB
Markdown
[![Build Status](https://travis-ci.org/protobuf-c/protobuf-c.png?branch=master)](https://travis-ci.org/protobuf-c/protobuf-c)
|
|
|
|
## Overview
|
|
|
|
This is `protobuf-c`, a C implementation of [Google Protocol Buffers](https://developers.google.com/protocol-buffers/). It includes `libprotobuf-c`, a pure C library that implements protobuf encoding and decoding, and `protoc-c`, a code generator that converts Protocol Buffer `.proto` files to C descriptor code, based on the original `protoc`. `protobuf-c` formerly included an RPC implementation; that code has been split out into the [protobuf-c-rpc](https://github.com/protobuf-c/protobuf-c-rpc) project.
|
|
|
|
`protobuf-c` was originally maintained by Dave Benson through version 0.15 but is now being maintained by a new team. Thanks, Dave!
|
|
|
|
## Mailing list
|
|
|
|
`protobuf-c`'s mailing list is hosted on a [Google Groups forum](https://groups.google.com/forum/#!forum/protobuf-c). Subscribe by sending an email to [protobuf-c+subscribe@googlegroups.com](mailto:protobuf-c+subscribe@googlegroups.com).
|
|
|
|
## Building
|
|
|
|
`protobuf-c` requires a C compiler, a C++ compiler, [Google Protocol Buffers](https://developers.google.com/protocol-buffers/), and `pkg-config` to be installed.
|
|
|
|
./configure && make && make install
|
|
|
|
If building from a git checkout, the `autotools` (`autoconf`, `automake`, `libtool`) must also be installed, and the build system must be generated by running the `autogen.sh` script.
|
|
|
|
./autogen.sh && ./configure && make && make install
|
|
|
|
## Synopsis
|
|
|
|
Use the `protoc-c` command to generate `.pb-c.c` and `.pb-c.h` output files from your `.proto` input file.
|
|
|
|
protoc-c --c_out=. example.proto
|
|
|
|
Include the `.pb-c.h` file from your C source code.
|
|
|
|
#include "example.pb-c.h"
|
|
|
|
Compile your C source code together with the `.pb-c.c` file. Add the output of the following command to your compile flags.
|
|
|
|
pkg-config --cflags 'libprotobuf-c >= 1.0.0'
|
|
|
|
Link against the `libprotobuf-c` support library. Add the output of the following command to your link flags.
|
|
|
|
pkg-config --libs 'libprotobuf-c >= 1.0.0'
|
|
|
|
If using autotools, the `PKG_CHECK_MODULES` macro can be used to detect the presence of `libprotobuf-c`. Add the following line to your `configure.ac` file:
|
|
|
|
PKG_CHECK_MODULES([PROTOBUF_C], [libprotobuf-c >= 1.0.0])
|
|
|
|
This will place compiler flags in the `PROTOBUF_C_CFLAGS` variable and linker flags in the `PROTOBUF_C_LDFLAGS` variable. Read [more information here](https://www.flameeyes.eu/autotools-mythbuster/pkgconfig/pkg_check_modules.html) about the `PKG_CHECK_MODULES` macro.
|
|
|
|
## Versioning
|
|
|
|
`protobuf-c` follows the [Semantic Versioning Specification](http://semver.org/).
|
|
|
|
## Contributing
|
|
|
|
Please send patches to the [protobuf-c mailing list](https://groups.google.com/forum/#!forum/protobuf-c) or by opening a GitHub pull request.
|
|
|
|
Copyright to all contributions are retained by the original author, but must be licensed under the terms of the [BSD-2-Clause](http://opensource.org/licenses/BSD-2-Clause) license. Please add a `Signed-off-by` header to your commit message (`git commit -s`) to indicate that you are licensing your contribution under these terms.
|