Skip to content

willat343/cppbox

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

51 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

cppbox

Collection of general-purpose C++ functions, classes and utilities

Core Library

Dependency Version Description
CMake >= 3.21 CMake Build Tool
cmakebox >= 0.0.1 CMake Functions and Utilities

There are several ways to include cppbox within your project:

  • [Preferred] Via FetchContent allowing package to be built as a submodule.
  • Via find_package, requiring package to be installed to the system, locally, or to a catkin workspace.

Include via FetchContent

It is recommended to leverage the functionality of cmakebox by including the following lines in the CMakeLists.txt (replace X.Y.Z with version):

set(CMAKEBOX_VERSION "0.0.1")
FetchContent_Declare(
    cmakebox
    GIT_REPOSITORY [email protected]:willat343/cmakebox.git
    GIT_TAG v${CMAKEBOX_VERSION}
)
FetchContent_MakeAvailable(cmakebox)
list(APPEND CMAKE_MODULE_PATH "${cmakebox_SOURCE_DIR}/cmake")
include(CMakeBox)

set(CPPBOX_VERSION "X.Y.Z")
import_dependency(
    cppbox
    TARGET cppbox::cppbox
    VERSION ${CPPBOX_VERSION}
    GIT_REPOSITORY [email protected]:willat343/cppbox
    GIT_TAG v${CPPBOX_VERSION}
)

Without relying on cmakebox, this can be achieved with (replace X.Y.Z with version):

set(CPPBOX_VERSION "X.Y.Z")
FetchContent_Declare(
    cppbox
    GIT_REPOSITORY [email protected]:willat343/cppbox
    GIT_TAG        v${CPPBOX_VERSION}
)
FetchContent_MakeAvailable(cppbox)

Include via Install

Clone

git clone [email protected]:willat343/cppbox.git
cd cppbox

Configure

For system install:

cmake -S . -B build

For local install:

cmake -S . -B build -DCMAKE_INSTALL_DIR=$HOME/.local

Build

cmake --build build -j

Install

sudo cmake --build build --target install

Include

Include with the following lines in the CMakeLists.txt:

find_package(cppbox REQUIRED)
target_link_libraries(<target> PUBLIC cppbox::cppbox)

Uninstall

sudo cmake --build build --target uninstall

Include in Catkin Workspace

A package.xml is supplied to facilitate an isolated installation within a catkin workspace (e.g. for ROS applications).

Clone

cd /path/to/catkin_ws/src
git clone [email protected]:willat343/cppbox.git

Build

cd /path/to/catkin_ws
catkin build cppbox

Include

To use the package in a downstream project, one should add to their package.xml:

<depend>cppbox</depend>

One can then include cppbox package by includeing in the CMakeLists.txt:

find_package(cppbox REQUIRED)
target_link_libraries(<target> PUBLIC cppbox::cppbox)

Clean

cd /path/to/catkin_ws
catkin clean cppbox

About

Collection of general-purpose C++ functions, classes and utilities

Resources

Stars

Watchers

Forks

Packages

No packages published