Skip to content

Commit

Permalink
CI: Build for both Mac on Intel and ARM
Browse files Browse the repository at this point in the history
  • Loading branch information
DeinAlptraum committed Sep 23, 2024
1 parent 02fc76b commit a30116d
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 8 deletions.
28 changes: 20 additions & 8 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -101,8 +101,12 @@ jobs:
if-no-files-found: error

build_mac:
name: Build for MacOS
runs-on: macos-13
name: Build for MacOS (${{ matrix.os }})
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [macos-13, macos-14]
fail-fast: false

steps:
- name: Get Number of CPU Cores
Expand All @@ -112,6 +116,13 @@ jobs:
uses: actions/checkout@v4
with:
submodules: true
- name: Determine Arch
run: |
if [ "${{ matrix.os }}" = "macos-13" ]; then
echo "arch=x86" >> $GITHUB_ENV
else
echo "arch=ARM" >> $GITHUB_ENV
fi
- name: Install Dependencies
run: |
brew unlink [email protected] && brew link --overwrite [email protected]
Expand Down Expand Up @@ -151,18 +162,18 @@ jobs:
qmake6 UltraStar-Manager.pro
make -j$${{ steps.cpu-cores.outputs.count }}
cd ../bin/release
mv UltraStar-Manager.dmg MAC-UltraStar-Manager.dmg
mv UltraStar-Manager.dmg MAC-${{ env.arch }}-UltraStar-Manager.dmg
- name: Upload Portable Artifact
uses: actions/upload-artifact@v4
with:
name: MAC-UltraStar-Manager-portable
name: MAC-${{ env.arch }}-UltraStar-Manager-portable
path: bin/release
if-no-files-found: error
- name: Upload Image Artifact
uses: actions/upload-artifact@v4
with:
name: MAC-UltraStar-Manager-image
path: bin/release/MAC-UltraStar-Manager.dmg
name: MAC-${{ env.arch }}-UltraStar-Manager-image
path: bin/release/MAC-${{ env.arch }}-UltraStar-Manager.dmg
if-no-files-found: error

build_linux:
Expand Down Expand Up @@ -240,12 +251,13 @@ jobs:
pattern: "*"
- name: Prepare Artifacts
run: |
zip -r MAC-UltraStar-Manager-portable.zip MAC-UltraStar-Manager-portable
zip -r MAC-x86-UltraStar-Manager-portable.zip MAC-x86-UltraStar-Manager-portable
zip -r MAC-ARM-UltraStar-Manager-portable.zip MAC-ARM-UltraStar-Manager-portable
zip -r WIN64-UltraStar-Manager-portable.zip WIN64-UltraStar-Manager-portable
mv WIN64-UltraStar-Manager-installer/UltraStar-Manager* WIN64-UltraStar-Manager-installer/WIN64-UltraStar-Manager-setup.exe
- name: Create Release
uses: ncipollo/release-action@v1
with:
artifacts: "LINUX-UltraStar-Manager-appimage/*, MAC-UltraStar-Manager-image/*, MAC-UltraStar-Manager-portable.zip, WIN64-UltraStar-Manager-installer/*, WIN64-UltraStar-Manager-portable.zip"
artifacts: "LINUX-UltraStar-Manager-appimage/*, MAC-x86-UltraStar-Manager-image/*, MAC-x86-UltraStar-Manager-portable.zip, MAC-ARM-UltraStar-Manager-image/*, MAC-ARM-UltraStar-Manager-portable.zip, WIN64-UltraStar-Manager-installer/*, WIN64-UltraStar-Manager-portable.zip"
draft: true
artifactErrorsFailBuild: true
3 changes: 3 additions & 0 deletions src/UltraStar-Manager.pro
Original file line number Diff line number Diff line change
Expand Up @@ -342,6 +342,9 @@ macx {
# Run macdeployqt to bundle the required Qt libraries with the application
QMAKE_POST_LINK += macdeployqt ../bin/release/UltraStar-Manager.app -libpath=../lib/MacOS -always-overwrite -verbose=3 $$escape_expand(\\n\\t)

# Add Ad-Hoc code signature to allow ARM Macs to run it
QMAKE_POST_LINK += codesign --force --deep --sign - --preserve-metadata=entitlements,requirements,flags,runtime ../bin/release/UltraStar-Manager.app $$escape_expand(\\n\\t)

# Create a fancy Mac disk image
QMAKE_POST_LINK += create-dmg --volname UltraStar-Manager --volicon resources/UltraStar-Manager.icns --app-drop-link 350 170 --background ../setup/macx/img/UltraStar-Manager_bg.png --hide-extension UltraStar-Manager.app --window-size 500 300 --text-size 14 --icon-size 64 --icon UltraStar-Manager.app 150 170 --no-internet-enable --skip-jenkins "../bin/release/UltraStar-Manager.dmg" ../bin/release/UltraStar-Manager.app/
}

0 comments on commit a30116d

Please sign in to comment.