Compare commits

...

8 Commits

Author SHA1 Message Date
1f78818000 Simplification
Some checks failed
Docker Builders / build-base-builder (push) Has been cancelled
Docker Builders / build-cpp-builder (push) Has been cancelled
Docker Builders / build-bigfoot-builder (push) Has been cancelled
2026-01-29 21:45:07 +01:00
f2a3099d51 fallback packages
Some checks failed
Docker Builders / build-base-builder (push) Successful in 37s
Docker Builders / build-cpp-builder (push) Successful in 5m54s
Docker Builders / build-bigfoot-builder (push) Has been cancelled
2026-01-29 21:27:06 +01:00
08a47d15ef fallback packages
Some checks failed
Docker Builders / build-base-builder (push) Successful in 35s
Docker Builders / build-cpp-builder (push) Successful in 6m20s
Docker Builders / build-bigfoot-builder (push) Failing after 1m5s
2026-01-29 21:10:35 +01:00
fbe910c581 Fix infer download link
Some checks failed
Docker Builders / build-base-builder (push) Successful in 1m11s
Docker Builders / build-cpp-builder (push) Successful in 6m24s
Docker Builders / build-bigfoot-builder (push) Failing after 1m15s
2026-01-29 20:37:54 +01:00
04a3a317ad Typo
Some checks failed
Docker Builders / build-base-builder (push) Successful in 47s
Docker Builders / build-cpp-builder (push) Failing after 1m14s
Docker Builders / build-bigfoot-builder (push) Has been skipped
2026-01-29 20:32:32 +01:00
96fafed341 Include CPPCheck
Some checks failed
Docker Builders / build-base-builder (push) Successful in 40s
Docker Builders / build-cpp-builder (push) Failing after 21s
Docker Builders / build-bigfoot-builder (push) Has been skipped
2026-01-29 20:26:08 +01:00
14151cbd86 Include Infer
Some checks failed
Docker Builders / build-base-builder (push) Has been cancelled
Docker Builders / build-cpp-builder (push) Has been cancelled
Docker Builders / build-bigfoot-builder (push) Has been cancelled
2026-01-29 20:24:14 +01:00
b1f75fff6a Remove GCC Coverage
Some checks failed
Docker Builders / build-base-builder (push) Successful in 2m13s
Docker Builders / build-bigfoot-builder (push) Has been cancelled
Docker Builders / build-cpp-builder (push) Has been cancelled
2026-01-29 20:20:21 +01:00
4 changed files with 25 additions and 69 deletions

View File

@@ -11,7 +11,6 @@ env:
BASE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbasebuilder
CPP_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxcppbuilder
BIGFOOT_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootbuilder
BIGFOOT_COVERAGE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootcoveragebuilder
jobs:
build-base-builder:
@@ -76,7 +75,6 @@ jobs:
tags: ${{ env.CPP_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }}
build-args: |
BASE_BUILDER=${{ env.BASE_BUILDER_TAG }}:${{ env.BRANCH_NAME_LOWER }}
CONAN_PROFILE_BRANCH=${{ env.BRANCH_NAME }}
build-bigfoot-builder:
runs-on: ubuntu-latest
@@ -113,7 +111,6 @@ jobs:
CONAN_RELEASE_PROFILE=clang
CONAN_RELWITHDEBINFO_PROFILE=clangd
CONAN_DEBUG_PROFILE=clangd
PACKAGES_CHANNEL=${{ env.BRANCH_NAME_LOWER }}
- name: Push built packages
env:
@@ -127,40 +124,3 @@ jobs:
-e CONAN_PASSWORD=${ARTIFACTORY_PASSWORD} \
${BIGFOOT_BUILDER_TAG}:${BRANCH_NAME_LOWER} \
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_RELWITHDEBINFO_PROFILE
ARG CONAN_DEBUG_PROFILE
ARG PACKAGES_CHANNEL
RUN apt-get update \
&& apt-get install -y \
@@ -28,7 +27,7 @@ RUN apt-get update \
COPY conanfile.py BigfootDependencies/conanfile.py
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 -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 -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_RELEASE_PROFILE} -pr:b=${CONAN_RELEASE_PROFILE} -s build_type=Release \
&& conan install ./BigfootDependencies --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_DEBUG_PROFILE} -pr:b=${CONAN_DEBUG_PROFILE} -s build_type=Debug \
&& ccache --show-stats

View File

@@ -3,13 +3,6 @@ from conan import ConanFile
class RequirementsConan(ConanFile):
name = "Requirements"
options = {
"packages_channel": ["ANY"]
}
default_options = {
"packages_channel": "main"
}
def configure(self):
self.options['mimalloc'].override = True
self.options['mimalloc'].shared = True
@@ -25,38 +18,38 @@ class RequirementsConan(ConanFile):
self.options["benchmark"].enable_lto = True
def requirements(self):
self.requires(f"eastl/3.27.01@bigfootdev/{self.options.packages_channel}")
self.requires(f"unordered_dense/4.8.1@bigfootdev/{self.options.packages_channel}")
self.requires(f"mimalloc/3.1.5@bigfootdev/{self.options.packages_channel}")
self.requires(f"stduuid/1.2.3@bigfootdev/{self.options.packages_channel}")
self.requires(f"sqlite3/3.51.0@bigfootdev/{self.options.packages_channel}")
self.requires(f"eastl/3.27.01@bigfootdev/main")
self.requires(f"unordered_dense/4.8.1@bigfootdev/main")
self.requires(f"mimalloc/3.1.5@bigfootdev/main")
self.requires(f"stduuid/1.2.3@bigfootdev/main")
self.requires(f"sqlite3/3.51.0@bigfootdev/main")
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(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("tracy/0.12.2")
self.requires("cpptrace/1.0.4")
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("glfw/3.4")
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(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(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(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(f"meshoptimizer/1.0@bigfootdev/{self.options.packages_channel}")
self.requires(f"meshoptimizer/1.0@bigfootdev/main")
self.requires("libsquish/1.15")
self.requires("benchmark/1.9.4")

View File

@@ -4,8 +4,6 @@ ARG BASE_BUILDER
# Base image
FROM $BASE_BUILDER
ARG CONAN_PROFILE_BRANCH
# Environment variables for ccache and pipx
ENV CCACHE_DIR=/ccache \
CCACHE_COMPRESS=1 \
@@ -16,6 +14,7 @@ ENV CCACHE_DIR=/ccache \
# Install system dependencies, clang, and pipx
RUN apt-get update && apt-get install -y \
build-essential \
cppcheck \
ccache \
cmake \
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 \
&& chmod +x /tmp/llvm.sh \
&& /tmp/llvm.sh 18 all \
&& apt-get install -y clang-tools-18 \
\
# Symlinks for clang 18 tools
&& 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/clang-format-18 /usr/bin/clang-format \
&& 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-nm-18 /usr/bin/llvm-nm \
&& 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
&& 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
RUN pipx ensurepath \
&& 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
# 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 disable conancenter