Skip to content

Commit

Permalink
Added cpp dir and tooling
Browse files Browse the repository at this point in the history
  • Loading branch information
stevenewald committed Oct 30, 2024
1 parent fb28652 commit 879d634
Show file tree
Hide file tree
Showing 23 changed files with 1,611 additions and 8 deletions.
191 changes: 191 additions & 0 deletions .github/workflows/cpp-ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,191 @@
name: C++ - Continuous Integration

on:
push:
branches:
- main

pull_request:
branches:
- main

jobs:
lint:
runs-on: ubuntu-22.04

steps:
- uses: actions/checkout@v3
with:
submodules: 'recursive'

- uses: actions/setup-python@v4
with: { python-version: "3.12" }

- name: Install LLVM 18
run: |
wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | sudo tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc
sudo apt-add-repository "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-18 main"
sudo apt update
sudo apt install llvm-18 llvm-18-dev llvm-18-tools clang-18 clang-tidy-18 clang-format-18 clang-tools-18 libclang-18-dev -y
- name: Install codespell
run: pip3 install codespell

- name: Lint
run: cmake -D FORMAT_COMMAND=clang-format-18 -P cmake/lint.cmake

- name: Spell check
run: cmake -P cmake/spell.cmake

sanitize:
needs: [lint]

runs-on: ubuntu-22.04


env:
CC: clang-18
CXX: clang++-18
CLANG_DIR: '/usr/lib/llvm-18/lib/cmake/clang'
LLVM_DIR: '/usr/lib/llvm-18/lib/cmake/llvm'

steps:
- uses: actions/checkout@v3
with:
submodules: 'recursive'

- name: Install Python
uses: actions/setup-python@v4
with: { python-version: "3.12" }

- name: Install Python Dev
uses: actions/setup-python@v4
with: { python-version: "3.12-dev" }

- name: Install LLVM 18
run: |
wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | sudo tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc
sudo apt-add-repository "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-18 main"
sudo apt update
sudo apt install llvm-18 llvm-18-dev llvm-18-tools clang-18 clang-tidy-18 clang-tools-18 libclang-18-dev -y
- name: Install Cache Conan dependencies
id: cache-conan
uses: actions/cache@v3
env:
cache-name: cache-conan-deps
with:
path: ~/.conan2
key: ${{ runner.os }}-builder-${{ env.cache-name }}-${{ hashFiles('conanfile.py') }}
restore-keys: ${{ runner.os }}-builder-${{ env.cache-name }}-

- name: Install dependencies
run: |
pip3 install conan numpy
sudo apt install libssl-dev -y
bash < ../.github/scripts/conan-profile.sh
conan install . -s build_type=Release -b missing
- name: Configure
run: cmake --preset=ci-sanitize

- name: Build
run: cmake --build build/sanitize -j

- name: Test
working-directory: src/cppsrc/build/sanitize
env:
ASAN_OPTIONS: "strict_string_checks=1:\
detect_stack_use_after_return=1:\
check_initialization_order=1:\
strict_init_order=1:\
detect_leaks=1"
UBSAN_OPTIONS: print_stacktrace=1
run: ctest --output-on-failure --no-tests=error -j 2

tests:
needs: [lint]

strategy:
matrix:
os: [ubuntu-22.04]

runs-on: ${{ matrix.os }}


env:
CC: clang-18
CXX: clang++-18
CLANG_DIR: '/usr/lib/llvm-18/lib/cmake/clang'
LLVM_DIR: '/usr/lib/llvm-18/lib/cmake/llvm'

steps:
- uses: actions/checkout@v3
with:
submodules: 'recursive'

- name: Install LLVM 18
run: |
wget -qO- https://apt.llvm.org/llvm-snapshot.gpg.key | sudo tee /etc/apt/trusted.gpg.d/apt.llvm.org.asc
sudo apt-add-repository "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-18 main"
sudo apt update
sudo apt install llvm-18 llvm-18-dev llvm-18-tools clang-18 clang-tidy-18 clang-tools-18 libclang-18-dev -y
- name: Install static analyzers
if: matrix.os == 'ubuntu-22.04'
run: >-
sudo apt install cppcheck -y -q
sudo update-alternatives --install
/usr/bin/clang-tidy clang-tidy
/usr/bin/clang-tidy-18 160
- name: Install Python
uses: actions/setup-python@v4
with: { python-version: "3.12" }

- name: Install Python Dev
uses: actions/setup-python@v4
with: { python-version: "3.12-dev" }

- name: Install Cache Conan dependencies
id: cache-conan
uses: actions/cache@v3
env:
cache-name: cache-conan-deps
with:
path: ~/.conan2
key: ${{ runner.os }}-builder-${{ env.cache-name }}-${{ hashFiles('conanfile.py') }}
restore-keys: ${{ runner.os }}-builder-${{ env.cache-name }}-

- name: Install dependencies
shell: bash
run: |
pip3 install conan numpy
sudo apt install libssl-dev -y
bash < ../.github/scripts/conan-profile.sh
conan install . -s build_type=Release -b missing
- name: Setup MultiToolTask
if: matrix.os == 'windows-2022'
run: |
Add-Content "$env:GITHUB_ENV" 'UseMultiToolTask=true'
Add-Content "$env:GITHUB_ENV" 'EnforceProcessCountAcrossBuilds=true'
- name: Configure
shell: pwsh
run: cmake "--preset=ci-$("${{ matrix.os }}".split("-")[0])"

- name: Build
run: cmake --build build --config Release -j

- name: Install
run: cmake --install build --config Release --prefix prefix

- name: Test
run: ctest --output-on-failure --no-tests=error -C Release -j 2

3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,6 @@ __pycache__
.mypy_cache
.DS_Store
.env
conan/
build/
**/compile_commands.json
62 changes: 62 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
cmake_minimum_required(VERSION 3.14)

include(cmake/prelude.cmake)

project(
desk_monorepo
VERSION 0.1.0
DESCRIPTION "Short description"
HOMEPAGE_URL "https://example.com/"
LANGUAGES CXX
)

include(cmake/project-is-top-level.cmake)
include(cmake/variables.cmake)

# ---- Declare library ----

add_library(
desk_monorepo_lib OBJECT
src/cppsrc/src/lib.cpp
)

target_include_directories(
desk_monorepo_lib ${warning_guard}
PUBLIC
"\$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/src/cppsrc/src>"
)

target_compile_features(desk_monorepo_lib PUBLIC cxx_std_20)

find_package(fmt REQUIRED)
target_link_libraries(desk_monorepo_lib PRIVATE fmt::fmt)

# ---- Declare executable ----

add_executable(desk_monorepo_exe src/cppsrc/src/main.cpp)
add_executable(desk_monorepo::exe ALIAS desk_monorepo_exe)

set_property(TARGET desk_monorepo_exe PROPERTY OUTPUT_NAME desk_monorepo)

target_compile_features(desk_monorepo_exe PRIVATE cxx_std_20)

target_link_libraries(desk_monorepo_exe PRIVATE desk_monorepo_lib)

# ---- Install rules ----

if(NOT CMAKE_SKIP_INSTALL_RULES)
include(cmake/install-rules.cmake)
endif()

# ---- Developer mode ----

if(NOT desk_monorepo_DEVELOPER_MODE)
return()
elseif(NOT PROJECT_IS_TOP_LEVEL)
message(
AUTHOR_WARNING
"Developer mode is intended for developers of desk_monorepo"
)
endif()

include(cmake/dev-mode.cmake)
Loading

0 comments on commit 879d634

Please sign in to comment.