Update 3 files
This commit is contained in:
@@ -24,6 +24,7 @@ ENV CCACHE_MAXSIZE=2G
|
|||||||
|
|
||||||
# Copy source files (this invalidates cache when source changes)
|
# Copy source files (this invalidates cache when source changes)
|
||||||
COPY src/ src/
|
COPY src/ src/
|
||||||
|
COPY CMakeLists.txt ./
|
||||||
|
|
||||||
# Configure project (this step is cached unless CMakeLists.txt changes)
|
# Configure project (this step is cached unless CMakeLists.txt changes)
|
||||||
RUN --mount=type=cache,target=/ccache \
|
RUN --mount=type=cache,target=/ccache \
|
||||||
@@ -47,9 +48,9 @@ RUN --mount=type=cache,target=/ccache \
|
|||||||
${CMAKE_TOOLCHAIN_FILE:+-DCMAKE_TOOLCHAIN_FILE=$CMAKE_TOOLCHAIN_FILE}
|
${CMAKE_TOOLCHAIN_FILE:+-DCMAKE_TOOLCHAIN_FILE=$CMAKE_TOOLCHAIN_FILE}
|
||||||
|
|
||||||
# Run prebuild script
|
# Run prebuild script
|
||||||
RUN --mount=type=cache,target=/ccache \
|
#RUN --mount=type=cache,target=/ccache \
|
||||||
--mount=type=cache,target=/build \
|
# --mount=type=cache,target=/build \
|
||||||
cmake --build /build --target run_prebuild_script
|
# cmake --build /build --target run_prebuild_script
|
||||||
|
|
||||||
# Build project (ccache will help here when only some files change)
|
# Build project (ccache will help here when only some files change)
|
||||||
RUN --mount=type=cache,target=/ccache \
|
RUN --mount=type=cache,target=/ccache \
|
||||||
|
66
build.sh
66
build.sh
@@ -1,58 +1,28 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
# Get script directory - handle different execution contexts
|
|
||||||
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
|
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
|
||||||
PROJECT="$(basename "${SCRIPT_DIR}")"
|
PROJECT="$(basename "${SCRIPT_DIR}")"
|
||||||
|
|
||||||
# Debug output for CI
|
rm -rf "${SCRIPT_DIR}/output"
|
||||||
echo "${PROJECT} build script running from: ${SCRIPT_DIR}"
|
mkdir -p "${SCRIPT_DIR}/output"
|
||||||
|
|
||||||
# handle running locally, or docker in docker via gitea runner.
|
# make sure we have the latest base image.
|
||||||
if [ -n "${GITEA_CONTAINER_NAME:-}" ]; then
|
docker pull gitea.jde.nz/public/dropshell-build-base:latest
|
||||||
echo "We're in a gitea container: ${GITEA_CONTAINER_NAME}"
|
|
||||||
VOLUME_OPTS=("--volumes-from=${GITEA_CONTAINER_NAME}")
|
# Build with or without cache based on NO_CACHE environment variable
|
||||||
WORKING_DIR=("-w" "${GITHUB_WORKSPACE}")
|
CACHE_FLAG=""
|
||||||
BUILD_DIR="${GITHUB_WORKSPACE}/build"
|
if [ "${NO_CACHE:-false}" = "true" ]; then
|
||||||
OUTPUT_DIR="${GITHUB_WORKSPACE}/output"
|
CACHE_FLAG="--no-cache"
|
||||||
else
|
|
||||||
VOLUME_OPTS=("-v" "${SCRIPT_DIR}:/app")
|
|
||||||
WORKING_DIR=("-w" "/app")
|
|
||||||
BUILD_DIR="${SCRIPT_DIR}/build"
|
|
||||||
OUTPUT_DIR="${SCRIPT_DIR}/output"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Create output directory
|
docker build \
|
||||||
mkdir -p "${OUTPUT_DIR}"
|
${CACHE_FLAG} \
|
||||||
|
-t "${PROJECT}-build" \
|
||||||
# Create build directory with proper permissions
|
-f "${SCRIPT_DIR}/Dockerfile.dropshell-build" \
|
||||||
mkdir -p "${BUILD_DIR}"
|
--build-arg PROJECT="${PROJECT}" \
|
||||||
|
--build-arg CMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE:-DEBUG}" \
|
||||||
# Run build in container with mounted directories
|
--output "${SCRIPT_DIR}/output" \
|
||||||
# Note: We run as root in the container and then chown the results
|
"${SCRIPT_DIR}"
|
||||||
COMMAND_TO_RUN="mkdir -p ./build && \
|
|
||||||
cmake -G Ninja -S . -B ./build \
|
|
||||||
-DCMAKE_BUILD_TYPE=\${CMAKE_BUILD_TYPE} \
|
|
||||||
-DPROJECT_NAME=${PROJECT} && \
|
|
||||||
cmake --build ./build && \
|
|
||||||
chown -R $(id -u):$(id -g) ./build"
|
|
||||||
|
|
||||||
echo "Building in new docker container"
|
|
||||||
docker run --rm \
|
|
||||||
"${VOLUME_OPTS[@]}" \
|
|
||||||
"${WORKING_DIR[@]}" \
|
|
||||||
-e CMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE:-Debug}" \
|
|
||||||
gitea.jde.nz/public/dropshell-build-base:latest \
|
|
||||||
bash -c "${COMMAND_TO_RUN}"
|
|
||||||
|
|
||||||
# Copy built executable to output directory
|
|
||||||
if [ -f "${BUILD_DIR}/${PROJECT}" ]; then
|
|
||||||
cp "${BUILD_DIR}/${PROJECT}" "${OUTPUT_DIR}/"
|
|
||||||
echo "✓ Build successful - ${PROJECT} copied to ${OUTPUT_DIR}/"
|
|
||||||
else
|
|
||||||
echo "✗ Build failed - ${PROJECT} not found in ${BUILD_DIR}/"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Build complete"
|
|
||||||
|
|
||||||
|
@@ -6,6 +6,7 @@ SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
|
|||||||
ARCH=$(uname -m)
|
ARCH=$(uname -m)
|
||||||
TEMP_DIR="${SCRIPT_DIR}/temp"
|
TEMP_DIR="${SCRIPT_DIR}/temp"
|
||||||
SOS="${TEMP_DIR}/sos"
|
SOS="${TEMP_DIR}/sos"
|
||||||
|
PROJECT="$(basename "${SCRIPT_DIR}")"
|
||||||
|
|
||||||
echo "Publishing simple-object-server to gitea.jde.nz/public/simple-object-server:latest"
|
echo "Publishing simple-object-server to gitea.jde.nz/public/simple-object-server:latest"
|
||||||
|
|
||||||
@@ -22,8 +23,6 @@ mkdir -p "${SCRIPT_DIR}/output"
|
|||||||
|
|
||||||
# build release version
|
# build release version
|
||||||
export CMAKE_BUILD_TYPE="Release"
|
export CMAKE_BUILD_TYPE="Release"
|
||||||
export PROJECT="simple-object-server"
|
|
||||||
|
|
||||||
"${SCRIPT_DIR}/build.sh"
|
"${SCRIPT_DIR}/build.sh"
|
||||||
|
|
||||||
[ -f "${SCRIPT_DIR}/output/simple-object-server" ] || die "Build failed."
|
[ -f "${SCRIPT_DIR}/output/simple-object-server" ] || die "Build failed."
|
||||||
|
Reference in New Issue
Block a user