From 59214d92138b858f5c71a40002a21dcee0e127fe Mon Sep 17 00:00:00 2001 From: Jackson Goode Date: Wed, 3 Jul 2024 13:22:46 -0700 Subject: [PATCH] Fix for QEMU --- .github/workflows/build.yml | 42 +++++++++++++++++++++++++++++-------- 1 file changed, 33 insertions(+), 9 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 89e6816d..18716f46 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -30,10 +30,13 @@ jobs: strategy: fail-fast: false matrix: - os: [ubuntu-latest, macOS-latest, windows-latest] include: - os: ubuntu-latest - arch: [x86_64, aarch64] + arch: x86_64 + - os: ubuntu-latest + arch: aarch64 + - os: macOS-latest + - os: windows-latest runs-on: ${{ matrix.os }} env: @@ -47,7 +50,11 @@ jobs: - name: Install Linux Dependencies if: runner.os == 'Linux' - run: sudo apt-get update && sudo apt-get install -y libgtk-3-dev libssl-dev libasound2-dev + run: | + sudo apt-get update && sudo apt-get install -y libgtk-3-dev libssl-dev libasound2-dev + if [ "${{ matrix.arch }}" == "aarch64" ]; then + sudo apt-get install -y qemu-user-static gcc-aarch64-linux-gnu + fi - name: Run Tests run: cargo test @@ -62,6 +69,9 @@ jobs: run: | rustup target add aarch64-unknown-linux-gnu cargo build --release --target x86_64-unknown-linux-gnu --target aarch64-unknown-linux-gnu + env: + CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER: aarch64-linux-gnu-gcc + CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_RUNNER: qemu-aarch64-static - name: Build Release (macOS) if: runner.os == 'macOS' @@ -129,18 +139,27 @@ jobs: deb: runs-on: ubuntu-latest needs: build + strategy: + matrix: + arch: [amd64, arm64] steps: - name: Checkout Repository uses: actions/checkout@v4 - - name: Download Linux Binary + - name: Download Linux Binaries uses: actions/download-artifact@v4 with: name: psst-gui - path: ${{runner.workspace}} + path: ${{runner.workspace}}/binaries - name: Move Binary - run: mkdir -p ${{runner.workspace}}/pkg/usr/bin/; mv ${{runner.workspace}}/psst-gui $_ + run: | + mkdir -p ${{runner.workspace}}/pkg/usr/bin/ + if [ "${{ matrix.arch }}" == "amd64" ]; then + mv ${{runner.workspace}}/binaries/x86_64-unknown-linux-gnu/release/psst-gui ${{runner.workspace}}/pkg/usr/bin/ + else + mv ${{runner.workspace}}/binaries/aarch64-unknown-linux-gnu/release/psst-gui ${{runner.workspace}}/pkg/usr/bin/ + fi - name: Move Desktop Entry run: mkdir -p ${{runner.workspace}}/pkg/usr/share/applications/; mv .pkg/psst.desktop $_ @@ -164,18 +183,23 @@ jobs: run: mkdir -p ${{runner.workspace}}/pkg/usr/share/doc/psst-gui/; mv .pkg/copyright $_ - name: Move Package Config - run: mkdir -p ${{runner.workspace}}/pkg/; mv .pkg/DEBIAN $_/ + run: | + mkdir -p ${{runner.workspace}}/pkg/ + cp -r .pkg/DEBIAN $_/ + sed -i 's/Architecture: amd64/Architecture: ${{ matrix.arch }}/' ${{runner.workspace}}/pkg/DEBIAN/control - name: Set Version run: "echo Version: $(git rev-list --count HEAD) >> ${{runner.workspace}}/pkg/DEBIAN/control" - name: Build Package - run: cat ${{runner.workspace}}/pkg/DEBIAN/control && dpkg-deb -b ${{runner.workspace}}/pkg/ psst_$(git rev-list --count HEAD)_amd64.deb + run: | + cat ${{runner.workspace}}/pkg/DEBIAN/control + dpkg-deb -b ${{runner.workspace}}/pkg/ psst_$(git rev-list --count HEAD)_${{ matrix.arch }}.deb - name: Upload Debian Package uses: actions/upload-artifact@v4 with: - name: psst-deb + name: psst-deb-${{ matrix.arch }} path: "*.deb" appimage: