.. _nanopb_reference: Nanopb ###### `Nanopb `_ is a C implementation of Google's `Protocol Buffers `_. Requirements ************ Nanopb uses the protocol buffer compiler to generate source and header files, make sure the ``protoc`` executable is installed and available. .. tabs:: .. group-tab:: Ubuntu Use ``apt`` to install dependency: .. code-block:: shell sudo apt install protobuf-compiler .. group-tab:: macOS Use ``brew`` to install dependency: .. code-block:: shell brew install protobuf .. group-tab:: Windows Use ``choco`` to install dependency: .. code-block:: shell choco install protoc Additionally, Nanopb is an optional module and needs to be added explicitly to the workspace: .. code-block:: shell west config manifest.project-filter -- +nanopb west update west packages pip --install Configuration ************* Make sure to include ``nanopb`` within your ``CMakeLists.txt`` file as follows: .. code-block:: cmake list(APPEND CMAKE_MODULE_PATH ${ZEPHYR_BASE}/modules/nanopb) include(nanopb) Adding ``proto`` files can be done with the ``zephyr_nanopb_sources()`` CMake function which ensures the generated header and source files are created before building the specified target. Nanopb has `generator options `_ that can be used to configure messages or fields. This allows to set fixed sizes or skip fields entirely. The internal CMake generator has an extension to configure ``*.options.in`` files automatically with CMake variables. See :zephyr_file:`samples/modules/nanopb/src/simple.options.in` and :zephyr_file:`samples/modules/nanopb/CMakeLists.txt` for usage example.