name: MacOS Build Steps on: workflow_call: inputs: jobName: required: true type: string artifactPrefixName: required: true type: string os: required: false type: string default: macos-14 patchesUrl: required: false type: string default: https://github.com/PCSX2/pcsx2_patches/releases/latest/download fetchTags: required: false type: boolean default: false stableBuild: required: false type: boolean default: false jobs: build_macos: name: ${{ inputs.jobName }} runs-on: ${{ inputs.os }} # Set some sort of timeout in the event of run-away builds. We are limited on concurrent jobs so, get rid of them. timeout-minutes: 90 env: POWERSHELL_TELEMETRY_OPTOUT: 1 CCACHE_BASEDIR: ${{ github.workspace }} CCACHE_DIR: ${{ github.workspace }}/.ccache CCACHE_COMPRESS: true CCACHE_COMPRESSLEVEL: 9 CCACHE_MAXSIZE: 100M steps: - name: Checkout Repository uses: actions/checkout@v4 # actions/checkout elides tags, fetch them primarily for releases - name: Fetch Tags if: ${{ inputs.fetchTags }} run: git fetch --tags --no-recurse-submodules - name: Add stable release identifier file if: ${{ inputs.stableBuild == true || inputs.stableBuild == 'true' }} shell: bash run: | echo "#define DEFAULT_UPDATER_CHANNEL \"stable\"" > ./pcsx2-qt/DefaultUpdaterChannel.h cat ./pcsx2-qt/DefaultUpdaterChannel.h - name: Use Xcode 15.2 run: sudo xcode-select -s /Applications/Xcode_15.2.app - name: Prepare Artifact Metadata id: artifact-metadata shell: bash env: PREFIX: ${{ inputs.artifactPrefixName }} EVENT_NAME: ${{ github.event_name }} PR_TITLE: ${{ github.event.pull_request.title }} PR_NUM: ${{ github.event.pull_request.number }} PR_SHA: ${{ github.event.pull_request.head.sha }} run: ./.github/workflows/scripts/common/name-artifacts.sh - name: Install Packages env: HOMEBREW_NO_INSTALL_CLEANUP: 1 HOMEBREW_NO_ANALYTICS: 1 run: | if ! brew install ccache nasm; then brew update brew install ccache nasm fi - name: Cache Dependencies id: cache-deps uses: actions/cache@v4 with: path: ~/deps key: ${{ inputs.os }} deps ${{ hashFiles('.github/workflows/scripts/macos/build-dependencies.sh') }} - name: Build Dependencies if: steps.cache-deps.outputs.cache-hit != 'true' run: | .github/workflows/scripts/macos/build-dependencies.sh "$HOME/deps" - name: Download patches run: | cd bin/resources aria2c -Z "${{ inputs.patchesUrl }}/patches.zip" # -- SETUP CCACHE - https://cristianadam.eu/20200113/speeding-up-c-plus-plus-github-actions-using-ccache/ - name: Prepare ccache timestamp id: ccache_cache_timestamp run: echo "timestamp=$(date -u "+%Y-%m-%d-%H;%M;%S")" >> $GITHUB_OUTPUT - name: Cache ccache cache uses: actions/cache@v4 with: path: .ccache key: ${{ inputs.os }} ccache ${{ steps.ccache_cache_timestamp.outputs.timestamp }} restore-keys: ${{ inputs.os }} ccache - name: Generate CMake Files run: | cmake -DCMAKE_PREFIX_PATH="$HOME/deps" \ -DCMAKE_BUILD_TYPE=Release \ -DCMAKE_OSX_ARCHITECTURES="x86_64" \ -DDISABLE_ADVANCE_SIMD=ON \ -DCMAKE_INTERPROCEDURAL_OPTIMIZATION=ON \ -DUSE_LINKED_FFMPEG=ON \ -DCMAKE_C_COMPILER_LAUNCHER=ccache \ -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \ -DCMAKE_DISABLE_PRECOMPILE_HEADERS=ON \ -B build . - name: Build PCSX2 working-directory: build run: | ccache -p ccache -s ccache -z make -j$(getconf _NPROCESSORS_ONLN) # macOS doesn't use make install ccache -s # Ensure there's no global constructors in multi-isa files for dir in */CMakeFiles/GS-{avx,avx2}.dir; do if find "$dir" -name "*.o" | xargs nm | grep _GLOBAL_; then echo "::error::Multi-isa files must not have global constructors!" exit 1 fi done - name: Run Tests working-directory: build run: make -j$(getconf _NPROCESSORS_ONLN) unittests - name: Prepare Build Artifacts run: | TAG="$(git tag --points-at HEAD)" if [ -z "$TAG" ]; then APPNAME="${{ steps.artifact-metadata.outputs.artifact-name }}" else APPNAME="PCSX2-$TAG" fi mv build/pcsx2*/PCSX2.app "$APPNAME.app" tar --options xz:compression-level=9 -cvJf "${{ steps.artifact-metadata.outputs.artifact-name }}.tar.xz" "$APPNAME.app" mkdir ci-artifacts cp "${{ steps.artifact-metadata.outputs.artifact-name }}.tar.xz" ci-artifacts/macOS.tar.xz - name: Upload Artifact uses: actions/upload-artifact@v4 with: name: ${{ steps.artifact-metadata.outputs.artifact-name }} path: "*.tar.xz"