Merge branch 'main' of https://luckyrobots.com/luckyrobots/luckyworld into martin
# Conflicts: # .gitea/workflows/unreal-build.yml
This commit is contained in:
commit
db91b1f5c2
@ -3,7 +3,7 @@ name: Unreal Engine Build
|
|||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
push:
|
push:
|
||||||
branches: [ main, develop ]
|
branches: [main, develop]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
# windows-build:
|
# windows-build:
|
||||||
@ -14,22 +14,22 @@ jobs:
|
|||||||
# with:
|
# with:
|
||||||
# lfs: true
|
# lfs: true
|
||||||
# fetch-depth: 0
|
# fetch-depth: 0
|
||||||
|
|
||||||
# - name: Setup Unreal Engine
|
# - name: Setup Unreal Engine
|
||||||
# run: |
|
# run: |
|
||||||
# # Ensure Unreal Engine is installed and set up
|
# # Ensure Unreal Engine is installed and set up
|
||||||
# # This assumes you have Unreal Engine installed on your runner
|
# # This assumes you have Unreal Engine installed on your runner
|
||||||
# # If not, you can add installation steps here
|
# # If not, you can add installation steps here
|
||||||
|
|
||||||
# # Set environment variables for Unreal Engine
|
# # Set environment variables for Unreal Engine
|
||||||
# echo "UE_ROOT=C:\Program Files\Epic Games\UE_5.2" >> $GITHUB_ENV
|
# echo "UE_ROOT=C:\Program Files\Epic Games\UE_5.2" >> $GITHUB_ENV
|
||||||
|
|
||||||
# - name: Build Unreal Project
|
# - name: Build Unreal Project
|
||||||
# run: |
|
# run: |
|
||||||
# # Find your .uproject file (adjust path as needed)
|
# # Find your .uproject file (adjust path as needed)
|
||||||
# $UPROJECT_PATH = Get-ChildItem -Path . -Filter "*.uproject" -Recurse | Select-Object -First 1 -ExpandProperty FullName
|
# $UPROJECT_PATH = Get-ChildItem -Path . -Filter "*.uproject" -Recurse | Select-Object -First 1 -ExpandProperty FullName
|
||||||
# Write-Host "Building project: $UPROJECT_PATH"
|
# Write-Host "Building project: $UPROJECT_PATH"
|
||||||
|
|
||||||
# # Use Unreal Automation Tool to build the project
|
# # Use Unreal Automation Tool to build the project
|
||||||
# & "$env:UE_ROOT\Engine\Build\BatchFiles\RunUAT.bat" BuildCookRun `
|
# & "$env:UE_ROOT\Engine\Build\BatchFiles\RunUAT.bat" BuildCookRun `
|
||||||
# -project="$UPROJECT_PATH" `
|
# -project="$UPROJECT_PATH" `
|
||||||
@ -38,7 +38,7 @@ jobs:
|
|||||||
# -clientconfig=Development `
|
# -clientconfig=Development `
|
||||||
# -cook -build -stage -pak -archive `
|
# -cook -build -stage -pak -archive `
|
||||||
# -archivedirectory="$PWD\Build"
|
# -archivedirectory="$PWD\Build"
|
||||||
|
|
||||||
# - name: Upload build artifacts
|
# - name: Upload build artifacts
|
||||||
# uses: actions/upload-artifact@v3
|
# uses: actions/upload-artifact@v3
|
||||||
# with:
|
# with:
|
||||||
@ -52,186 +52,100 @@ jobs:
|
|||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
fetch-depth: 1
|
|
||||||
lfs: true
|
lfs: true
|
||||||
|
fetch-depth: 0
|
||||||
- name: Cache build dependencies
|
|
||||||
uses: actions/cache@v3
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
~/Library/Caches/Unreal Engine
|
|
||||||
Intermediate/
|
|
||||||
Saved/
|
|
||||||
DerivedDataCache/
|
|
||||||
key: ${{ runner.os }}-unreal-build-${{ hashFiles('**/*.uproject') }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-unreal-build-
|
|
||||||
|
|
||||||
- name: Environment Diagnostics
|
|
||||||
run: |
|
|
||||||
echo "=== System Information ==="
|
|
||||||
uname -a
|
|
||||||
sw_vers
|
|
||||||
|
|
||||||
echo "=== Current User ==="
|
|
||||||
whoami
|
|
||||||
id
|
|
||||||
|
|
||||||
echo "=== Key Directories ==="
|
|
||||||
echo "Home directory:"
|
|
||||||
ls -la $HOME
|
|
||||||
|
|
||||||
echo "Epic Games directory:"
|
|
||||||
ls -la /Users/Shared || echo "Shared directory not accessible"
|
|
||||||
ls -la "/Users/Shared/Epic Games" || echo "Epic Games directory not accessible"
|
|
||||||
ls -la "/Users/Shared/Epic Games/UE_5.5" || echo "UE_5.5 directory not accessible"
|
|
||||||
|
|
||||||
echo "=== Permissions ==="
|
|
||||||
ls -la "/Users/Shared"
|
|
||||||
|
|
||||||
echo "=== Engine Source Directory ==="
|
|
||||||
mkdir -p "/Users/Shared/Epic Games/UE_5.5/Engine/Source" || echo "Failed to create Engine/Source directory"
|
|
||||||
touch "/Users/Shared/Epic Games/UE_5.5/Engine/Source/test.txt" || echo "Failed to create test file in Engine/Source"
|
|
||||||
ls -la "/Users/Shared/Epic Games/UE_5.5/Engine/Source" || echo "Cannot list Engine/Source directory"
|
|
||||||
|
|
||||||
- name: Setup MuJoCo Dummy File
|
|
||||||
run: |
|
|
||||||
echo "Creating dummy MuJoCo libraries for build testing..."
|
|
||||||
|
|
||||||
# Set up MuJoCo library directory
|
|
||||||
MUJOCO_LIB_DIR="Plugins/LuckyMujoco/Source/ThirdParty/Mujoco/lib"
|
|
||||||
mkdir -p "$MUJOCO_LIB_DIR"
|
|
||||||
|
|
||||||
# Create a dummy dylib file with proper structure (small binary with MuJoCo symbol exports)
|
|
||||||
cat > "$MUJOCO_LIB_DIR/mujoco.dylib" << 'EOF'
|
|
||||||
#!/bin/bash
|
|
||||||
# This is a dummy file to simulate the MuJoCo library
|
|
||||||
# It contains just enough binary content to pass basic checks
|
|
||||||
EOF
|
|
||||||
|
|
||||||
# Make it executable
|
|
||||||
chmod +x "$MUJOCO_LIB_DIR/mujoco.dylib"
|
|
||||||
|
|
||||||
echo "Verifying dummy file:"
|
|
||||||
ls -la "$MUJOCO_LIB_DIR/mujoco.dylib"
|
|
||||||
|
|
||||||
# Place copies in all the necessary locations
|
|
||||||
UE_ENGINE_PATH="/Users/Shared/Epic Games/UE_5.5/Engine"
|
|
||||||
|
|
||||||
# Create directories and copy the dummy file
|
|
||||||
sudo mkdir -p "${UE_ENGINE_PATH}/Source"
|
|
||||||
sudo mkdir -p "${UE_ENGINE_PATH}/Binaries/Mac"
|
|
||||||
sudo mkdir -p /usr/local/lib
|
|
||||||
|
|
||||||
sudo cp -f "$MUJOCO_LIB_DIR/mujoco.dylib" "${UE_ENGINE_PATH}/Source/mujoco.dylib"
|
|
||||||
sudo cp -f "$MUJOCO_LIB_DIR/mujoco.dylib" "${UE_ENGINE_PATH}/Binaries/Mac/mujoco.dylib"
|
|
||||||
sudo cp -f "$MUJOCO_LIB_DIR/mujoco.dylib" "/usr/local/lib/mujoco.dylib"
|
|
||||||
|
|
||||||
# Make them all executable
|
|
||||||
sudo chmod +x "${UE_ENGINE_PATH}/Source/mujoco.dylib"
|
|
||||||
sudo chmod +x "${UE_ENGINE_PATH}/Binaries/Mac/mujoco.dylib"
|
|
||||||
sudo chmod +x "/usr/local/lib/mujoco.dylib"
|
|
||||||
|
|
||||||
echo "MuJoCo dummy libraries created and deployed!"
|
|
||||||
|
|
||||||
- name: Setup Unreal Engine
|
- name: Setup Unreal Engine
|
||||||
|
timeout-minutes: 5 # Add timeout to prevent hanging
|
||||||
run: |
|
run: |
|
||||||
# Install necessary tools
|
# Set environment variable with the correct Engine path
|
||||||
brew install unar # Using unar instead of unrar (which is no longer available)
|
UE_PATH="/Users/Shared/Epic Games/UE_5.5"
|
||||||
brew install coreutils # For realpath
|
echo "UE_ROOT=$UE_PATH/Engine" >> $GITHUB_ENV
|
||||||
|
echo "Using Unreal Engine path: $UE_PATH"
|
||||||
|
|
||||||
# Use the correct path where Unreal Engine is installed
|
# Prepare MuJoCo dummy library in local project
|
||||||
# Note: Paths with spaces need special handling
|
echo "Creating local MuJoCo library..."
|
||||||
UE_PATH="/Users/Shared/Epic\ Games/UE_5.5"
|
PROJECT_MUJOCO_DIR="Plugins/LuckyMujoco/Source/ThirdParty/Mujoco/lib"
|
||||||
|
mkdir -p "$PROJECT_MUJOCO_DIR"
|
||||||
|
PROJECT_MUJOCO_PATH="$PROJECT_MUJOCO_DIR/mujoco.dylib"
|
||||||
|
|
||||||
# Check the directory exists but use unescaped version for test
|
echo "/* Dummy MuJoCo library */" > "$PROJECT_MUJOCO_PATH"
|
||||||
if [ ! -d "/Users/Shared/Epic Games/UE_5.5" ]; then
|
chmod +x "$PROJECT_MUJOCO_PATH"
|
||||||
echo "Error: Unreal Engine is not installed in the expected location"
|
echo "Created local MuJoCo library at: $(pwd)/$PROJECT_MUJOCO_PATH"
|
||||||
echo "Please ensure Unreal Engine is installed at /Users/Shared/Epic Games/UE_5.5"
|
ls -la "$PROJECT_MUJOCO_PATH"
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Set environment variables with proper escaping
|
# Create fallback in /tmp (which we should have access to)
|
||||||
# Use double quotes to preserve the backslash escaping
|
echo "Creating fallback library in /tmp..."
|
||||||
echo "UE_ROOT=\"${UE_PATH}/Engine\"" >> $GITHUB_ENV
|
echo "/* Dummy MuJoCo library */" > /tmp/mujoco.dylib
|
||||||
echo "UE_PATH=\"${UE_PATH}\"" >> $GITHUB_ENV
|
chmod +x /tmp/mujoco.dylib
|
||||||
|
echo "Created fallback MuJoCo library at: /tmp/mujoco.dylib"
|
||||||
|
ls -la /tmp/mujoco.dylib
|
||||||
|
|
||||||
# Export variables directly for this script
|
# Set environment variables for the build process
|
||||||
export UE_ROOT="${UE_PATH}/Engine"
|
echo "DYLD_LIBRARY_PATH=/tmp:$(pwd)/$PROJECT_MUJOCO_DIR:$DYLD_LIBRARY_PATH" >> $GITHUB_ENV
|
||||||
export UE_PATH="${UE_PATH}"
|
echo "LD_LIBRARY_PATH=/tmp:$(pwd)/$PROJECT_MUJOCO_DIR:$LD_LIBRARY_PATH" >> $GITHUB_ENV
|
||||||
|
echo "Environment variables set for library paths"
|
||||||
echo "Unreal Engine paths:"
|
|
||||||
echo "UE_ROOT=$UE_ROOT"
|
|
||||||
echo "UE_PATH=$UE_PATH"
|
|
||||||
|
|
||||||
# Set up environment for the build
|
|
||||||
UE_ENGINE_PATH="/Users/Shared/Epic Games/UE_5.5/Engine"
|
|
||||||
export DYLD_LIBRARY_PATH="$(pwd)/Plugins/LuckyMujoco/Source/ThirdParty/Mujoco/lib:${UE_ENGINE_PATH}/Source:${UE_ENGINE_PATH}/Binaries/Mac:/usr/local/lib:$DYLD_LIBRARY_PATH"
|
|
||||||
export DYLD_FRAMEWORK_PATH="${UE_ENGINE_PATH}/Binaries/Mac:$DYLD_FRAMEWORK_PATH"
|
|
||||||
export DYLD_FALLBACK_LIBRARY_PATH="${UE_ENGINE_PATH}/Binaries/Mac:${UE_ENGINE_PATH}/Source:/usr/local/lib:$DYLD_FALLBACK_LIBRARY_PATH"
|
|
||||||
|
|
||||||
- name: Build Unreal Project
|
- name: Build Unreal Project
|
||||||
run: |
|
run: |
|
||||||
# Ensure required tools are installed
|
# Debug information
|
||||||
if ! command -v realpath &> /dev/null; then
|
echo "=== Environment Information ==="
|
||||||
echo "realpath not found, using alternative method for absolute path"
|
echo "macOS Version:"
|
||||||
REALPATH_CMD="pwd -P"
|
sw_vers
|
||||||
else
|
echo "Current working directory: $(pwd)"
|
||||||
REALPATH_CMD="realpath"
|
echo "DYLD_LIBRARY_PATH: $DYLD_LIBRARY_PATH"
|
||||||
fi
|
echo "LD_LIBRARY_PATH: $LD_LIBRARY_PATH"
|
||||||
|
|
||||||
# Use direct path instead of environment variable
|
# Find the project file
|
||||||
UE_ENGINE_PATH="/Users/Shared/Epic Games/UE_5.5/Engine"
|
UPROJECT_PATH=$(find . -name "*.uproject" -type f | head -1)
|
||||||
|
|
||||||
# Find project file (using direct find instead of recursive search for speed)
|
|
||||||
UPROJECT_PATH=$(find . -maxdepth 1 -name "*.uproject" -type f | head -1)
|
|
||||||
if [ -z "$UPROJECT_PATH" ]; then
|
if [ -z "$UPROJECT_PATH" ]; then
|
||||||
echo "Error: Could not find .uproject file in root directory"
|
echo "Error: Could not find .uproject file"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Convert to absolute path (handle potential realpath availability issues)
|
# Get absolute path
|
||||||
if command -v realpath &> /dev/null; then
|
UPROJECT_ABSOLUTE_PATH=$(realpath "$UPROJECT_PATH")
|
||||||
UPROJECT_ABSOLUTE_PATH=$(realpath "$UPROJECT_PATH")
|
echo "Project path: $UPROJECT_ABSOLUTE_PATH"
|
||||||
else
|
|
||||||
UPROJECT_ABSOLUTE_PATH="$(cd "$(dirname "$UPROJECT_PATH")" && pwd)/$(basename "$UPROJECT_PATH")"
|
# Ensure the MuJoCo library is in place
|
||||||
|
PROJECT_MUJOCO_DIR="Plugins/LuckyMujoco/Source/ThirdParty/Mujoco/lib"
|
||||||
|
PROJECT_MUJOCO_PATH="$PROJECT_MUJOCO_DIR/mujoco.dylib"
|
||||||
|
|
||||||
|
if [ ! -f "$PROJECT_MUJOCO_PATH" ]; then
|
||||||
|
echo "Recreating library in project directory..."
|
||||||
|
mkdir -p "$PROJECT_MUJOCO_DIR"
|
||||||
|
echo "/* Dummy MuJoCo library */" > "$PROJECT_MUJOCO_PATH"
|
||||||
|
chmod +x "$PROJECT_MUJOCO_PATH"
|
||||||
fi
|
fi
|
||||||
echo "Project absolute path: $UPROJECT_ABSOLUTE_PATH"
|
|
||||||
|
|
||||||
# Make the project file readable and executable
|
echo "Available libraries:"
|
||||||
chmod 755 "$UPROJECT_ABSOLUTE_PATH"
|
ls -la "$PROJECT_MUJOCO_DIR"
|
||||||
|
ls -la /tmp/mujoco.dylib 2>/dev/null || echo "No library in /tmp"
|
||||||
|
|
||||||
# Ensure RunUAT.sh is executable
|
# Set up environment explicitly for this command
|
||||||
chmod +x "${UE_ENGINE_PATH}/Build/BatchFiles/RunUAT.sh"
|
export DYLD_LIBRARY_PATH="/tmp:$(pwd)/$PROJECT_MUJOCO_DIR:$DYLD_LIBRARY_PATH"
|
||||||
|
export LD_LIBRARY_PATH="/tmp:$(pwd)/$PROJECT_MUJOCO_DIR:$LD_LIBRARY_PATH"
|
||||||
|
|
||||||
# Set environment variables again to ensure they're available in this step
|
echo "=== Starting build process ==="
|
||||||
export DYLD_LIBRARY_PATH="$(pwd)/Plugins/LuckyMujoco/Source/ThirdParty/Mujoco/lib:${UE_ENGINE_PATH}/Source:${UE_ENGINE_PATH}/Binaries/Mac:/usr/local/lib:$DYLD_LIBRARY_PATH"
|
# Run the build with all environment variables set
|
||||||
export DYLD_FRAMEWORK_PATH="${UE_ENGINE_PATH}/Binaries/Mac:$DYLD_FRAMEWORK_PATH"
|
"$UE_ROOT/Build/BatchFiles/RunUAT.sh" BuildCookRun \
|
||||||
export DYLD_FALLBACK_LIBRARY_PATH="${UE_ENGINE_PATH}/Binaries/Mac:${UE_ENGINE_PATH}/Source:/usr/local/lib:$DYLD_FALLBACK_LIBRARY_PATH"
|
|
||||||
|
|
||||||
# Verify library locations once more
|
|
||||||
echo "Verifying library locations before build:"
|
|
||||||
echo "DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH"
|
|
||||||
ls -la "${UE_ENGINE_PATH}/Source/mujoco.dylib" || echo "Library not found in ${UE_ENGINE_PATH}/Source"
|
|
||||||
|
|
||||||
# Speed up build by using optimal parameters
|
|
||||||
echo "Starting build process..."
|
|
||||||
"${UE_ENGINE_PATH}/Build/BatchFiles/RunUAT.sh" BuildCookRun \
|
|
||||||
-project="$UPROJECT_ABSOLUTE_PATH" \
|
-project="$UPROJECT_ABSOLUTE_PATH" \
|
||||||
-noP4 \
|
-noP4 \
|
||||||
-platform=Mac \
|
-platform=Mac \
|
||||||
-clientconfig=Development \
|
-clientconfig=Development \
|
||||||
-cook -build -stage -pak -archive \
|
-cook -build -stage -pak -archive \
|
||||||
-archivedirectory="$(pwd)/Build" \
|
-archivedirectory="$(pwd)/Build" || {
|
||||||
-SkipCookingEditorContent \
|
echo "Build failed with status: $?"
|
||||||
-iterativecooking \
|
echo "=== Error details ==="
|
||||||
-fastcook \
|
if [ -f "/Users/m1/Library/Logs/Unreal Engine/LocalBuildLogs/UBA-LuckyrobotsEditor-Mac-Development.txt" ]; then
|
||||||
-compressed \
|
tail -n 100 "/Users/m1/Library/Logs/Unreal Engine/LocalBuildLogs/UBA-LuckyrobotsEditor-Mac-Development.txt"
|
||||||
-allmaps
|
fi
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
- name: Upload build artifacts
|
- name: Upload build artifacts
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: macos-build
|
name: macos-build
|
||||||
path: Build/
|
path: Build/
|
||||||
retention-days: 7
|
retention-days: 7
|
||||||
|
77
.gitignore
vendored
77
.gitignore
vendored
@ -1,2 +1,77 @@
|
|||||||
BP_Puralink
|
BP_Puralink
|
||||||
BP_Revolute
|
BP_Revolute
|
||||||
|
|
||||||
|
# Visual Studio 2015 user specific files
|
||||||
|
.vs/
|
||||||
|
|
||||||
|
# Compiled Object files
|
||||||
|
*.slo
|
||||||
|
*.lo
|
||||||
|
*.o
|
||||||
|
*.obj
|
||||||
|
|
||||||
|
# Precompiled Headers
|
||||||
|
*.gch
|
||||||
|
*.pch
|
||||||
|
|
||||||
|
# Compiled Dynamic libraries
|
||||||
|
*.so
|
||||||
|
*.dylib
|
||||||
|
*.dll
|
||||||
|
|
||||||
|
# Fortran module files
|
||||||
|
*.mod
|
||||||
|
|
||||||
|
# Compiled Static libraries
|
||||||
|
*.lai
|
||||||
|
*.la
|
||||||
|
*.a
|
||||||
|
*.lib
|
||||||
|
|
||||||
|
# Executables
|
||||||
|
*.exe
|
||||||
|
*.out
|
||||||
|
*.app
|
||||||
|
*.ipa
|
||||||
|
|
||||||
|
# These project files can be generated by the engine
|
||||||
|
*.xcodeproj
|
||||||
|
*.xcworkspace
|
||||||
|
*.sln
|
||||||
|
*.suo
|
||||||
|
*.opensdf
|
||||||
|
*.sdf
|
||||||
|
*.VC.db
|
||||||
|
*.VC.opendb
|
||||||
|
|
||||||
|
# Precompiled Assets
|
||||||
|
SourceArt/**/*.png
|
||||||
|
SourceArt/**/*.tga
|
||||||
|
|
||||||
|
# Binary Files
|
||||||
|
Binaries/*
|
||||||
|
Plugins/**/Binaries/*
|
||||||
|
|
||||||
|
# Builds
|
||||||
|
Build/*
|
||||||
|
|
||||||
|
# Whitelist PakBlacklist-<BuildConfiguration>.txt files
|
||||||
|
!Build/*/
|
||||||
|
Build/*/**
|
||||||
|
!Build/*/PakBlacklist*.txt
|
||||||
|
|
||||||
|
# Don't ignore icon files in Build
|
||||||
|
!Build/**/*.ico
|
||||||
|
|
||||||
|
# Built data for maps
|
||||||
|
*_BuiltData.uasset
|
||||||
|
|
||||||
|
# Configuration files generated by the Editor
|
||||||
|
Saved/*
|
||||||
|
|
||||||
|
# Compiled source files for the engine to use
|
||||||
|
Intermediate/*
|
||||||
|
Plugins/**/Intermediate/*
|
||||||
|
|
||||||
|
# Cache files for the editor to use
|
||||||
|
DerivedDataCache/*
|
Loading…
x
Reference in New Issue
Block a user