Skip to content

MelamudMichael/up-cpp

 
 

Repository files navigation

Uprotocol C++ SDK

Welcome!

This is the C++ library that extends up-core-api to provide serializers, validators, and language specific interface definitions for uProtocol.

IMPORTANT NOTE: This project is under active development

The core functional factory methods that make it more intuitive to create URIs that are used to configure source and sink (destination) elements in the uProtocol and additional helper methods.

Getting Started

The library is built and packaged using conan dependency management.

Requirements:

  • Compiler: GCC/G++ 11 or Clang 13
  • Conan : 1.59 or latest 2.X
  • Ubuntu 22.04

How to Use the Library

To add up-cpp to your conan build dependencies, simply add the following to your conanfile.txt:

[requires]
up-cpp/0.1

[generators]
CMakeDeps
CMakeToolchain

[layout]
cmake_layout

NOTE: If using conan version 1.59 Ensure that the conan profile is configured to use ABI 11 (libstdc++11: New ABI.) standards according to https://docs.conan.io/en/1.60/howtos/manage_gcc_abi.html

How to Build

The following steps are only required to locally build and test up-cpp, if you are a user of up-cpp, you only need to follow the How to Use the Library section above.

Setup SDK local repository, build and test

$ git clone https://github.com/eclipse-uprotocol/up-cpp.git
$ git submodule update --init --recursive

Building locally

$ cd up-cpp
$ mkdir build
$ cd build

$ conan install .. -o build_testing=True
$ cmake -S .. -DCMAKE_TOOLCHAIN_FILE=conan_toolchain.cmake -DCMAKE_BUILD_TYPE=Release -DBUILD_SHARED_LIBS=ON  -DCMAKE_INSTALL_PREFIX=install
$ cmake --build . --target install -- -j 

Creating conan package locally

If you need to create a release package for conan, please follow the steps below.

$ cd up-cpp
$ conan create . --build=missing

Show your support

Give a ⭐️ if this project helped you!

About

uProtocol C++ SDK

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 95.1%
  • CMake 4.3%
  • Python 0.6%