From 33dfa0192ce8aded902df4f436325ce768f45569 Mon Sep 17 00:00:00 2001 From: kaniol-lck <375520360@qq.com> Date: Mon, 8 Jul 2024 16:10:55 +0800 Subject: [PATCH] ci for macos, with Qt6.7.1[QTBUG-117225], #99 --- .github/workflows/ci.yml | 134 +++++++++++++++++++-------------------- modmanager.pro | 14 +++- 2 files changed, 80 insertions(+), 68 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ab7391f..7049263 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -20,6 +20,7 @@ jobs: needs: - build-on-ubuntu - build-on-win-mingw + - build-on-osx steps: - uses: actions/checkout@v2 with: @@ -41,7 +42,7 @@ jobs: zip -q -r ModManager-${{ env.VERSION }}-x64-packed.zip * mv ModManager-${{ env.VERSION }}-x64-packed.zip /home/runner/work/modmanager/modmanager/etc/usr/publish/ModManager-${{ env.VERSION }}-x64-packed.zip mv /home/runner/work/modmanager/modmanager/etc/usr/artifacts/ModManager-${{ env.VERSION }}-x64-Installer.exe/ModManager-Installer.exe /home/runner/work/modmanager/modmanager/etc/usr/publish/ModManager-${{ env.VERSION }}-x64-Installer.exe - # mv /home/runner/work/modmanager/modmanager/etc/usr/artifacts/ModManager-${{ env.VERSION }}.dmg/modmanager.dmg /home/runner/work/modmanager/modmanager/etc/usr/publish/ModManager-${{ env.VERSION }}.dmg + mv /home/runner/work/modmanager/modmanager/etc/usr/artifacts/ModManager-${{ env.VERSION }}.dmg/modmanager.dmg /home/runner/work/modmanager/modmanager/etc/usr/publish/ModManager-${{ env.VERSION }}.dmg mv /home/runner/work/modmanager/modmanager/etc/usr/artifacts/ModManager-${{ env.VERSION }}-x86_64.AppImage/Mod_Manager-${{ env.VERSION }}-x86_64.AppImage /home/runner/work/modmanager/modmanager/etc/usr/publish/ModManager-${{ env.VERSION }}.AppImage - name: Get short commit sha id: get_short_sha @@ -261,69 +262,68 @@ jobs: asset_name: ModManager-${{ env.VERSION }}-x64-Installer.exe tag: ${{ github.ref }} overwrite: true - # build-on-osx: - # name: Build On OSX - # runs-on: ${{ matrix.os }} - # strategy: - # fail-fast: false - # matrix: - # os: [macOS-latest] - # qt_ver: [6.7.1] - # qt_arch: [clang_64] - # steps: - # - name: Install Qt - # uses: jurplel/install-qt-action@v4 - # with: - # aqtversion: '==2.1.*' - # version: ${{ matrix.qt_ver }} - # host: 'mac' - # target: 'desktop' - # arch: ${{ matrix.qt_arch }} - # modules: 'qtwebengine' - # - name: Install libaria2 - # run: | - # wget "https://github.com/kaniol-lck/aria2/releases/download/libaria2-release-1.36.0/libaria2-clang-macos-10.15.zip" - # unzip *.zip - # csrutil status - # sudo cp -r lib/ usr/local/lib/ - # sudo cp -r include/aria2/ usr/local/include/ - # rm -rf lib/ include/ *.zip - # - name: Install dependencies - # run: | - # brew install quazip gnu-sed aria2 - # - uses: actions/checkout@v2 - # with: - # fetch-depth: 1 - # - name: Set Env - # shell: bash - # run: | - # export RAW_VERSION=$(grep -o '".*"' src/version.h | sed 's/"//g') - # export VERSION=$RAW_VERSION-build.$GITHUB_RUN_NUMBER - # echo "RAW_VERSION=${RAW_VERSION}" >> $GITHUB_ENV - # echo "VERSION=${VERSION}" >> $GITHUB_ENV - # - name: Modify version number - # if: ${{ !startsWith(github.event.ref, 'refs/tags/') }} - # shell: bash - # run: | - # gsed -i "s/$RAW_VERSION/$VERSION/" src/version.h - # - name: build macos - # run: | - # qmake - # make - # - name: package - # run: | - # macdeployqt modmanager.app -qmldir=. -verbose=1 -dmg - # shell: sh - # - uses: actions/upload-artifact@v2 - # with: - # name: ModManager-${{ env.VERSION }}.dmg - # path: modmanager.dmg - # - name: uploadRelease - # if: startsWith(github.event.ref, 'refs/tags/') - # uses: svenstaro/upload-release-action@v2 - # with: - # repo_token: ${{ secrets.GITHUB_TOKEN }} - # file: modmanager.dmg - # asset_name: ModManager-${{ env.VERSION }}.dmg - # tag: ${{ github.ref }} - # overwrite: true + build-on-osx: + name: Build On OSX + runs-on: ${{ matrix.os }} + strategy: + fail-fast: false + matrix: + os: [macOS-13] + qt_ver: [6.7.1] + qt_arch: [clang_64] + steps: + - name: Install Qt + uses: jurplel/install-qt-action@v4 + with: + version: ${{ matrix.qt_ver }} + host: 'mac' + target: 'desktop' + arch: ${{ matrix.qt_arch }} + modules: 'qt5compat' + - name: Install libaria2 + run: | + wget "https://github.com/kaniol-lck/aria2/releases/download/release-1.36.0/libaria2-clang-macos-10.15.zip" + unzip *.zip + csrutil status + sudo cp -r lib/ /usr/local/lib/ + sudo cp -r include/ /usr/local/include/ + rm -rf lib/ include/ *.zip + - name: Install dependencies + run: | + brew install quazip gnu-sed aria2 + - uses: actions/checkout@v2 + with: + fetch-depth: 1 + - name: Set Env + shell: bash + run: | + export RAW_VERSION=$(grep -o '".*"' src/version.h | sed 's/"//g') + export VERSION=$RAW_VERSION-build.$GITHUB_RUN_NUMBER + echo "RAW_VERSION=${RAW_VERSION}" >> $GITHUB_ENV + echo "VERSION=${VERSION}" >> $GITHUB_ENV + - name: Modify version number + if: ${{ !startsWith(github.event.ref, 'refs/tags/') }} + shell: bash + run: | + gsed -i "s/$RAW_VERSION/$VERSION/" src/version.h + - name: build macos + run: | + qmake + make + - name: package + run: | + macdeployqt modmanager.app -qmldir=. -verbose=1 -dmg + shell: sh + - uses: actions/upload-artifact@v2 + with: + name: ModManager-${{ env.VERSION }}.dmg + path: modmanager.dmg + - name: uploadRelease + if: startsWith(github.event.ref, 'refs/tags/') + uses: svenstaro/upload-release-action@v2 + with: + repo_token: ${{ secrets.GITHUB_TOKEN }} + file: modmanager.dmg + asset_name: ModManager-${{ env.VERSION }}.dmg + tag: ${{ github.ref }} + overwrite: true diff --git a/modmanager.pro b/modmanager.pro index 5b0a72c..fc2375a 100644 --- a/modmanager.pro +++ b/modmanager.pro @@ -86,7 +86,7 @@ DISTFILES += \ win32: RC_ICONS = package/modmanager.ico #dependencies -unix { +unix:!macx { message("unix-like build") message(HEADERS) @@ -107,10 +107,22 @@ unix { # equals(QT_MAJOR_VERSION, 6): PKGCONFIG += libaria2 quazip1-qt6 } +macx { + message("macos build") + + INCLUDEPATH += /usr/local/include + LIBS += -L/usr/local/lib -laria2 + equals(QT_MAJOR_VERSION,5):INCLUDEPATH += /usr/local/include/QuaZip-Qt5-1.4/quazip + equals(QT_MAJOR_VERSION,6):INCLUDEPATH += /usr/local/include/QuaZip-Qt6-1.4/quazip + equals(QT_MAJOR_VERSION,5):LIBS += -L/usr/local/lib -lquazip1-qt5 + equals(QT_MAJOR_VERSION,6):LIBS += -L/usr/local/lib -lquazip1-qt6 +} + win32 { #native blur LIBS += -ldwmapi + QMAKE_CXXFLAGS += $$system($$pkgConfigExecutable() --cflags libaria2) LIBS += $$system($$pkgConfigExecutable() --libs libaria2 | sed 's/\/lib\b/\/bin/' | sed 's/-laria2/-laria2-0/') equals(QT_MAJOR_VERSION, 5){