Compare commits

...

9 Commits

Author SHA1 Message Date
351d07b85f Simplification
All checks were successful
Docker Builders / build-base-builder (push) Successful in 43s
Docker Builders / build-cpp-builder (push) Successful in 5m40s
Docker Builders / build-bigfoot-builder (push) Successful in 45m19s
2026-01-29 20:45:32 +00:00
200ccab096 fallback packages 2026-01-29 20:45:32 +00:00
4da5f54fa0 fallback packages 2026-01-29 20:45:32 +00:00
2598ea7d1b Fix infer download link 2026-01-29 20:45:32 +00:00
87dd11e8ec Typo 2026-01-29 20:45:32 +00:00
b0709db3c1 Include CPPCheck 2026-01-29 20:45:32 +00:00
4e761aac65 Include Infer 2026-01-29 20:45:32 +00:00
7b4ff02c49 Remove GCC Coverage 2026-01-29 20:45:32 +00:00
49ae8fcf78 Merge pull request 'CI' (#2) from Development into main
All checks were successful
Docker Builders / build-base-builder (push) Successful in 50s
Docker Builders / build-cpp-builder (push) Successful in 5m14s
Docker Builders / build-bigfoot-builder (push) Successful in 45m33s
Docker Builders / build-bigfootcoverage-builder (push) Successful in 53m57s
Reviewed-on: #2
2026-01-27 11:17:33 +00:00
4 changed files with 25 additions and 69 deletions

View File

@@ -11,7 +11,6 @@ env:
BASE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbasebuilder BASE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbasebuilder
CPP_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxcppbuilder CPP_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxcppbuilder
BIGFOOT_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootbuilder BIGFOOT_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootbuilder
BIGFOOT_COVERAGE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootcoveragebuilder
jobs: jobs:
build-base-builder: build-base-builder:
@@ -76,7 +75,6 @@ jobs:
tags: ${{ env.CPP_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }} tags: ${{ env.CPP_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }}
build-args: | build-args: |
BASE_BUILDER=${{ env.BASE_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }} BASE_BUILDER=${{ env.BASE_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }}
CONAN_PROFILE_BRANCH=${{ env.BRANCH_NAME }}
build-bigfoot-builder: build-bigfoot-builder:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@@ -113,7 +111,6 @@ jobs:
CONAN_RELEASE_PROFILE=clang CONAN_RELEASE_PROFILE=clang
CONAN_RELWITHDEBINFO_PROFILE=clangd CONAN_RELWITHDEBINFO_PROFILE=clangd
CONAN_DEBUG_PROFILE=clangd CONAN_DEBUG_PROFILE=clangd
PACKAGES_CHANNEL=${{ env.BRANCH_NAME_LOWER }}
- name: Push built packages - name: Push built packages
env: env:
@@ -127,40 +124,3 @@ jobs:
-e CONAN_PASSWORD=${ARTIFACTORY_PASSWORD} \ -e CONAN_PASSWORD=${ARTIFACTORY_PASSWORD} \
${BIGFOOT_BUILDER_TAG}:${BRANCH_NAME_LOWER} \ ${BIGFOOT_BUILDER_TAG}:${BRANCH_NAME_LOWER} \
conan upload '*' --remote=bigfootpackages --force --confirm conan upload '*' --remote=bigfootpackages --force --confirm
build-bigfootcoverage-builder:
runs-on: ubuntu-latest
timeout-minutes: 360
needs: build-cpp-builder
steps:
- name: Set ENV
run: |
echo "BRANCH_NAME_LOWER=$(echo $GITHUB_REF_NAME | tr '[:upper:]' '[:lower:]')" >> $GITHUB_ENV
echo "BRANCH_NAME=$(echo $GITHUB_REF_NAME)" >> $GITHUB_ENV
- name: Checkout
uses: actions/checkout@v6
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to the Container registry
uses: docker/login-action@v3
with:
registry: ${{ vars.DOCKER_REGISTRY }}
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_TOKEN }}
- name: Build and push bigfootcoverage builder
uses: docker/build-push-action@v5
with:
context: ./Linux/BigfootBuilder
push: true
tags: ${{ env.BIGFOOT_COVERAGE_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }}
build-args: |
BASE_BUILDER=${{ env.CPP_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }}
CONAN_RELEASE_PROFILE=gcc_coverage
CONAN_RELWITHDEBINFO_PROFILE=gcc_coverage
CONAN_DEBUG_PROFILE=gcc_coverage
PACKAGES_CHANNEL=${{ env.BRANCH_NAME_LOWER }}

View File

@@ -5,7 +5,6 @@ FROM $BASE_BUILDER
ARG CONAN_RELEASE_PROFILE ARG CONAN_RELEASE_PROFILE
ARG CONAN_RELWITHDEBINFO_PROFILE ARG CONAN_RELWITHDEBINFO_PROFILE
ARG CONAN_DEBUG_PROFILE ARG CONAN_DEBUG_PROFILE
ARG PACKAGES_CHANNEL
RUN apt-get update \ RUN apt-get update \
&& apt-get install -y \ && apt-get install -y \
@@ -28,7 +27,7 @@ RUN apt-get update \
COPY conanfile.py BigfootDependencies/conanfile.py COPY conanfile.py BigfootDependencies/conanfile.py
RUN ccache --zero-stats \ RUN ccache --zero-stats \
&& conan install ./BigfootDependencies -o Requirements/*:packages_channel=${PACKAGES_CHANNEL} --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELEASE_PROFILE} -pr:b=${CONAN_RELEASE_PROFILE} -s build_type=Release \ && conan install ./BigfootDependencies --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELEASE_PROFILE} -pr:b=${CONAN_RELEASE_PROFILE} -s build_type=Release \
&& conan install ./BigfootDependencies -o Requirements/*:packages_channel=${PACKAGES_CHANNEL} --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELWITHDEBINFO_PROFILE} -pr:b=${CONAN_RELWITHDEBINFO_PROFILE} -s build_type=RelWithDebInfo \ && conan install ./BigfootDependencies --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELWITHDEBINFO_PROFILE} -pr:b=${CONAN_RELWITHDEBINFO_PROFILE} -s build_type=RelWithDebInfo \
&& conan install ./BigfootDependencies -o Requirements/*:packages_channel=${PACKAGES_CHANNEL} --remote=bigfootpackages --build="*" -pr:h=${CONAN_DEBUG_PROFILE} -pr:b=${CONAN_DEBUG_PROFILE} -s build_type=Debug \ && conan install ./BigfootDependencies --remote=bigfootpackages --build="*" -pr:h=${CONAN_DEBUG_PROFILE} -pr:b=${CONAN_DEBUG_PROFILE} -s build_type=Debug \
&& ccache --show-stats && ccache --show-stats

View File

@@ -3,13 +3,6 @@ from conan import ConanFile
class RequirementsConan(ConanFile): class RequirementsConan(ConanFile):
name = "Requirements" name = "Requirements"
options = {
"packages_channel": ["ANY"]
}
default_options = {
"packages_channel": "main"
}
def configure(self): def configure(self):
self.options['mimalloc'].override = True self.options['mimalloc'].override = True
self.options['mimalloc'].shared = True self.options['mimalloc'].shared = True
@@ -25,38 +18,38 @@ class RequirementsConan(ConanFile):
self.options["benchmark"].enable_lto = True self.options["benchmark"].enable_lto = True
def requirements(self): def requirements(self):
self.requires(f"eastl/3.27.01@bigfootdev/{self.options.packages_channel}") self.requires(f"eastl/3.27.01@bigfootdev/main")
self.requires(f"unordered_dense/4.8.1@bigfootdev/{self.options.packages_channel}") self.requires(f"unordered_dense/4.8.1@bigfootdev/main")
self.requires(f"mimalloc/3.1.5@bigfootdev/{self.options.packages_channel}") self.requires(f"mimalloc/3.1.5@bigfootdev/main")
self.requires(f"stduuid/1.2.3@bigfootdev/{self.options.packages_channel}") self.requires(f"stduuid/1.2.3@bigfootdev/main")
self.requires(f"sqlite3/3.51.0@bigfootdev/{self.options.packages_channel}") self.requires(f"sqlite3/3.51.0@bigfootdev/main")
self.requires("cli11/2.6.0") self.requires("cli11/2.6.0")
self.requires(f"rapidhash/3.0@bigfootdev/{self.options.packages_channel}") self.requires(f"rapidhash/3.0@bigfootdev/main")
self.requires("effolkronium-random/1.5.0") self.requires("effolkronium-random/1.5.0")
self.requires(f"flatbuffers/25.12.19@bigfootdev/{self.options.packages_channel}") self.requires(f"flatbuffers/25.12.19@bigfootdev/main")
self.requires("quill/11.0.2") self.requires("quill/11.0.2")
self.requires("tracy/0.12.2") self.requires("tracy/0.12.2")
self.requires("cpptrace/1.0.4") self.requires("cpptrace/1.0.4")
self.requires("glm/1.0.1") self.requires("glm/1.0.1")
self.requires(f"lodepng/cci.20250727@bigfootdev/{self.options.packages_channel}") self.requires(f"lodepng/cci.20250727@bigfootdev/main")
self.requires("imgui/1.92.5-docking") self.requires("imgui/1.92.5-docking")
self.requires("glfw/3.4") self.requires("glfw/3.4")
self.requires("vulkan-headers/1.4.313.0") self.requires("vulkan-headers/1.4.313.0")
self.requires(f"vulkan-validationlayers/1.4.313.0@bigfootdev/{self.options.packages_channel}") self.requires(f"vulkan-validationlayers/1.4.313.0@bigfootdev/main")
self.requires("spirv-cross/1.4.313.0") self.requires("spirv-cross/1.4.313.0")
self.requires(f"vulkan-memory-allocator/3.3.0@bigfootdev/{self.options.packages_channel}") self.requires(f"vulkan-memory-allocator/3.3.0@bigfootdev/main")
self.requires("gtest/1.17.0") self.requires("gtest/1.17.0")
self.requires(f"pixelmatch-cpp17/1.0.3@bigfootdev/{self.options.packages_channel}") self.requires(f"pixelmatch-cpp17/1.0.3@bigfootdev/main")
self.requires("stb/cci.20240531", override=True) self.requires("stb/cci.20240531", override=True)
self.requires(f"shaderc/2025.3@bigfootdev/{self.options.packages_channel}") self.requires(f"shaderc/2025.3@bigfootdev/main")
self.requires("assimp/6.0.2") self.requires("assimp/6.0.2")
self.requires(f"meshoptimizer/1.0@bigfootdev/{self.options.packages_channel}") self.requires(f"meshoptimizer/1.0@bigfootdev/main")
self.requires("libsquish/1.15") self.requires("libsquish/1.15")
self.requires("benchmark/1.9.4") self.requires("benchmark/1.9.4")

View File

@@ -4,8 +4,6 @@ ARG BASE_BUILDER
# Base image # Base image
FROM $BASE_BUILDER FROM $BASE_BUILDER
ARG CONAN_PROFILE_BRANCH
# Environment variables for ccache and pipx # Environment variables for ccache and pipx
ENV CCACHE_DIR=/ccache \ ENV CCACHE_DIR=/ccache \
CCACHE_COMPRESS=1 \ CCACHE_COMPRESS=1 \
@@ -16,6 +14,7 @@ ENV CCACHE_DIR=/ccache \
# Install system dependencies, clang, and pipx # Install system dependencies, clang, and pipx
RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \
build-essential \ build-essential \
cppcheck \
ccache \ ccache \
cmake \ cmake \
ninja-build \ ninja-build \
@@ -31,7 +30,6 @@ RUN apt-get update && apt-get install -y \
&& wget https://apt.llvm.org/llvm.sh -O /tmp/llvm.sh \ && wget https://apt.llvm.org/llvm.sh -O /tmp/llvm.sh \
&& chmod +x /tmp/llvm.sh \ && chmod +x /tmp/llvm.sh \
&& /tmp/llvm.sh 18 all \ && /tmp/llvm.sh 18 all \
&& apt-get install -y clang-tools-18 \
\ \
# Symlinks for clang 18 tools # Symlinks for clang 18 tools
&& ln -sf /usr/bin/clang-18 /usr/bin/clang \ && ln -sf /usr/bin/clang-18 /usr/bin/clang \
@@ -40,6 +38,7 @@ RUN apt-get update && apt-get install -y \
&& ln -sf /usr/bin/llvm-cov-18 /usr/bin/llvm-cov \ && ln -sf /usr/bin/llvm-cov-18 /usr/bin/llvm-cov \
&& ln -sf /usr/bin/clang-format-18 /usr/bin/clang-format \ && ln -sf /usr/bin/clang-format-18 /usr/bin/clang-format \
&& ln -sf /usr/bin/clang-tidy-18 /usr/bin/clang-tidy \ && ln -sf /usr/bin/clang-tidy-18 /usr/bin/clang-tidy \
&& ln -sf /usr/bin/run-clang-tidy-18 /usr/bin/run-clang-tidy \
&& ln -sf /usr/bin/llvm-ar-18 /usr/bin/llvm-ar \ && ln -sf /usr/bin/llvm-ar-18 /usr/bin/llvm-ar \
&& ln -sf /usr/bin/llvm-nm-18 /usr/bin/llvm-nm \ && ln -sf /usr/bin/llvm-nm-18 /usr/bin/llvm-nm \
&& ln -sf /usr/bin/llvm-ranlib-18 /usr/bin/llvm-ranlib \ && ln -sf /usr/bin/llvm-ranlib-18 /usr/bin/llvm-ranlib \
@@ -47,6 +46,11 @@ RUN apt-get update && apt-get install -y \
# Reset ccache stats # Reset ccache stats
&& ccache --zero-stats && ccache --zero-stats
RUN VERSION=1.2.0; \
curl -sSL "https://github.com/facebook/infer/releases/download/v$VERSION/infer-linux-x86_64-v$VERSION.tar.xz" \
| sudo tar -C /opt -xJ && \
sudo ln -s "/opt/infer-linux64-v$VERSION/bin/infer" /usr/local/bin/infer
# Install pipx and Conan # Install pipx and Conan
RUN pipx ensurepath \ RUN pipx ensurepath \
&& pipx install conan && pipx install conan
@@ -65,7 +69,7 @@ RUN git clone --branch v2.40.4 https://github.com/rui314/mold.git /tmp/mold \
&& rm -rf /tmp/mold && rm -rf /tmp/mold
# Configure Conan with custom profiles and remote # Configure Conan with custom profiles and remote
RUN conan config install https://git.romainboullard.com/BigfootDev/ConanProfiles.git --args="--branch $CONAN_PROFILE_BRANCH" \ RUN conan config install https://git.romainboullard.com/BigfootDev/ConanProfiles.git --args="--branch main" \
&& conan remote add bigfootpackages https://conan.romainboullard.com/artifactory/api/conan/BigfootPackages \ && conan remote add bigfootpackages https://conan.romainboullard.com/artifactory/api/conan/BigfootPackages \
&& conan remote disable conancenter && conan remote disable conancenter