Compare commits
7 Commits
v2025.0625
...
v2025.0625
Author | SHA1 | Date | |
---|---|---|---|
884609f661 | |||
a5a36c179b | |||
42b51ef0be | |||
f094d532cf | |||
fffa88482a | |||
54af706032 | |||
ef7470dcce |
@ -2,6 +2,15 @@
|
|||||||
set -uo pipefail # Remove -e to handle errors manually
|
set -uo pipefail # Remove -e to handle errors manually
|
||||||
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
|
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
|
||||||
|
|
||||||
|
docker builder prune -f
|
||||||
|
|
||||||
|
|
||||||
|
# Colors for output
|
||||||
|
RED='\033[0;31m'
|
||||||
|
GREEN='\033[0;32m'
|
||||||
|
YELLOW='\033[1;33m'
|
||||||
|
NC='\033[0m' # No Color
|
||||||
|
|
||||||
# Arrays to track results
|
# Arrays to track results
|
||||||
declare -A BUILD_RESULTS
|
declare -A BUILD_RESULTS
|
||||||
declare -A TEST_RESULTS
|
declare -A TEST_RESULTS
|
||||||
@ -106,13 +115,35 @@ function buildtestpublish() {
|
|||||||
cd "$dir" || echo "Failed to cd to $dir"
|
cd "$dir" || echo "Failed to cd to $dir"
|
||||||
|
|
||||||
subtitle "🔨 BUILDING $TOOLNAME_UPPER 🔨"
|
subtitle "🔨 BUILDING $TOOLNAME_UPPER 🔨"
|
||||||
dothis build "$dir" "$TOOLNAME"
|
if dothis build "$dir" "$TOOLNAME"; then
|
||||||
|
BUILD_SUCCESS=true
|
||||||
|
else
|
||||||
|
BUILD_SUCCESS=false
|
||||||
|
fi
|
||||||
|
|
||||||
subtitle "🔍 TESTING $TOOLNAME_UPPER 🔍"
|
subtitle "🔍 TESTING $TOOLNAME_UPPER 🔍"
|
||||||
dothis test "$dir" "$TOOLNAME"
|
if [ "$BUILD_SUCCESS" = true ]; then
|
||||||
|
if dothis test "$dir" "$TOOLNAME"; then
|
||||||
|
TEST_SUCCESS=true
|
||||||
|
else
|
||||||
|
TEST_SUCCESS=false
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Skipping tests - build failed"
|
||||||
|
TEST_RESULTS["$TOOLNAME"]="SKIP"
|
||||||
|
TEST_SUCCESS=false
|
||||||
|
fi
|
||||||
|
|
||||||
subtitle "📦 PUBLISHING $TOOLNAME_UPPER 📦"
|
subtitle "📦 PUBLISHING $TOOLNAME_UPPER 📦"
|
||||||
|
if [ "$BUILD_SUCCESS" = true ] && [ "$TEST_SUCCESS" = true ]; then
|
||||||
dothis publish "$dir" "$TOOLNAME"
|
dothis publish "$dir" "$TOOLNAME"
|
||||||
|
elif [ "$BUILD_SUCCESS" = true ] && [ "${TEST_RESULTS[$TOOLNAME]}" = "SKIP" ]; then
|
||||||
|
# If tests are skipped (no test script), allow publish if build succeeded
|
||||||
|
dothis publish "$dir" "$TOOLNAME"
|
||||||
|
else
|
||||||
|
echo "Skipping publish - build or tests failed"
|
||||||
|
PUBLISH_RESULTS["$TOOLNAME"]="SKIP"
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Done"
|
echo "Done"
|
||||||
}
|
}
|
||||||
@ -166,9 +197,36 @@ function print_summary() {
|
|||||||
local test_status="${TEST_RESULTS[$project]:-'-'}"
|
local test_status="${TEST_RESULTS[$project]:-'-'}"
|
||||||
local publish_status="${PUBLISH_RESULTS[$project]:-'-'}"
|
local publish_status="${PUBLISH_RESULTS[$project]:-'-'}"
|
||||||
|
|
||||||
printf "│ %-*s │ %-7s │ %-7s │ %-7s │\n" \
|
# Format status with proper spacing and colors for Unicode characters
|
||||||
|
local build_col test_col publish_col
|
||||||
|
|
||||||
|
# Format build status with colors
|
||||||
|
case "$build_status" in
|
||||||
|
"✓") build_col=$(printf " %s✓%s " "$GREEN" "$NC") ;;
|
||||||
|
"✗") build_col=$(printf " %s✗%s " "$RED" "$NC") ;;
|
||||||
|
"SKIP") build_col=$(printf " %s-%s " "$YELLOW" "$NC") ;;
|
||||||
|
*) build_col=" - " ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Format test status with colors
|
||||||
|
case "$test_status" in
|
||||||
|
"✓") test_col=$(printf " %s✓%s " "$GREEN" "$NC") ;;
|
||||||
|
"✗") test_col=$(printf " %s✗%s " "$RED" "$NC") ;;
|
||||||
|
"SKIP") test_col=$(printf " %s-%s " "$YELLOW" "$NC") ;;
|
||||||
|
*) test_col=" - " ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Format publish status with colors
|
||||||
|
case "$publish_status" in
|
||||||
|
"✓") publish_col=$(printf " %s✓%s " "$GREEN" "$NC") ;;
|
||||||
|
"✗") publish_col=$(printf " %s✗%s " "$RED" "$NC") ;;
|
||||||
|
"SKIP") publish_col=$(printf " %s-%s " "$YELLOW" "$NC") ;;
|
||||||
|
*) publish_col=" - " ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
printf "│ %-*s │%b│%b│%b│\n" \
|
||||||
$max_project_width "$project" \
|
$max_project_width "$project" \
|
||||||
"$build_status" "$test_status" "$publish_status"
|
"$build_col" "$test_col" "$publish_col"
|
||||||
done
|
done
|
||||||
|
|
||||||
# Print bottom border
|
# Print bottom border
|
||||||
|
@ -17,12 +17,19 @@ Examples:
|
|||||||
dehydrate src/ output/ Creates _src.cpp and _src.hpp in output/
|
dehydrate src/ output/ Creates _src.cpp and _src.hpp in output/
|
||||||
dehydrate -u Updates dehydrate to the latest version
|
dehydrate -u Updates dehydrate to the latest version
|
||||||
dehydrate -v Shows version number
|
dehydrate -v Shows version number
|
||||||
|
dehydrate version Shows version number
|
||||||
)";
|
)";
|
||||||
|
|
||||||
Args parse_args(int argc, char* argv[]) {
|
Args parse_args(int argc, char* argv[]) {
|
||||||
Args args;
|
Args args;
|
||||||
int idx = 1;
|
int idx = 1;
|
||||||
|
|
||||||
|
// Check for "version" as first argument (no dash)
|
||||||
|
if (argc > 1 && std::string(argv[1]) == "version") {
|
||||||
|
args.version = true;
|
||||||
|
return args;
|
||||||
|
}
|
||||||
|
|
||||||
// Parse flags
|
// Parse flags
|
||||||
while (idx < argc && argv[idx][0] == '-') {
|
while (idx < argc && argv[idx][0] == '-') {
|
||||||
std::string flag = argv[idx];
|
std::string flag = argv[idx];
|
||||||
|
@ -16,39 +16,48 @@ rm -f dehydrate_test
|
|||||||
|
|
||||||
# Build the test program using Docker
|
# Build the test program using Docker
|
||||||
# The Docker container supports both amd64 and arm64 architectures
|
# The Docker container supports both amd64 and arm64 architectures
|
||||||
docker run --rm \
|
echo "Building dehydrate test executable..."
|
||||||
-v "$PROJECT_DIR":/workdir \
|
|
||||||
-w /workdir/test \
|
|
||||||
gitea.jde.nz/public/dropshell-build-base:latest \
|
|
||||||
bash -c "
|
|
||||||
# Verify we can find the source file
|
|
||||||
if [ ! -f dehydrate_test.cpp ]; then
|
|
||||||
echo 'ERROR: dehydrate_test.cpp not found in current directory'
|
|
||||||
echo 'Working directory:' && pwd
|
|
||||||
echo 'Available files:' && ls -la
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Clean any existing binary and compile
|
# Use docker cp approach since volume mounting may not work in CI
|
||||||
rm -f dehydrate_test
|
CONTAINER_NAME="dehydrate-test-build-$$"
|
||||||
if ! g++ -std=c++23 -static dehydrate_test.cpp -o dehydrate_test; then
|
|
||||||
|
# Start container in detached mode
|
||||||
|
docker run -d --name "$CONTAINER_NAME" \
|
||||||
|
gitea.jde.nz/public/dropshell-build-base:latest \
|
||||||
|
sleep 60
|
||||||
|
|
||||||
|
# Copy source file into container
|
||||||
|
docker cp dehydrate_test.cpp "$CONTAINER_NAME":/dehydrate_test.cpp
|
||||||
|
|
||||||
|
# Compile in container
|
||||||
|
docker exec "$CONTAINER_NAME" bash -c "
|
||||||
|
echo 'Compiling dehydrate test...'
|
||||||
|
if ! g++ -std=c++23 -static /dehydrate_test.cpp -o /dehydrate_test; then
|
||||||
echo 'ERROR: Compilation failed'
|
echo 'ERROR: Compilation failed'
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Verify binary was created and is executable
|
# Verify binary was created
|
||||||
if [ ! -f dehydrate_test ]; then
|
if [ ! -f /dehydrate_test ]; then
|
||||||
echo 'ERROR: Binary was not created'
|
echo 'ERROR: Binary was not created'
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Quick architecture check - just verify the binary format
|
# Quick architecture check
|
||||||
if ! file dehydrate_test | grep -q 'executable'; then
|
if ! file /dehydrate_test | grep -q 'executable'; then
|
||||||
echo 'ERROR: Generated file is not an executable'
|
echo 'ERROR: Generated file is not an executable'
|
||||||
file dehydrate_test
|
file /dehydrate_test
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
"
|
|
||||||
|
echo 'Compilation successful'
|
||||||
|
"
|
||||||
|
|
||||||
|
# Copy binary back to host
|
||||||
|
docker cp "$CONTAINER_NAME":/dehydrate_test ./dehydrate_test
|
||||||
|
|
||||||
|
# Clean up container
|
||||||
|
docker rm -f "$CONTAINER_NAME"
|
||||||
|
|
||||||
# Check if compilation succeeded
|
# Check if compilation succeeded
|
||||||
if [ ! -f "./dehydrate_test" ]; then
|
if [ ! -f "./dehydrate_test" ]; then
|
||||||
|
Reference in New Issue
Block a user