This fix Mac extension and add Raspberry pi toolchain embbed in the file #2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: C/C++ CI | |
on: | |
workflow_dispatch: | |
push: | |
branches: ["main"] | |
pull_request: | |
branches: ["main"] | |
env: | |
LIBNAME: simple | |
jobs: | |
macos-universal-build: | |
runs-on: macos-latest | |
strategy: | |
matrix: | |
arch: [amd64, arm64] | |
precision: [32, 64] # TODO: We need to install PD64? | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
fetch-depth: 0 | |
- name: Install PureData and Deps | |
run: | | |
brew install --cask pd | |
# Add here dynamic libraries that you use (ex. fftw3, gsl, ...). | |
# Search for the name in https://brew.sh/ | |
- name: Build Object for Arm | |
if: ${{ matrix.arch == 'arm64' }} | |
run: | | |
cmake . -B build -DCMAKE_OSX_ARCHITECTURES=arm64 -DPD_FLOATSIZE=${{ matrix.precision }} | |
cmake --build build -j $(sysctl -n hw.logicalcpu) | |
- name: Build Object for Intel | |
if: ${{ matrix.arch == 'amd64' }} | |
run: | | |
cmake . -B build -DPD_FLOATSIZE=${{ matrix.precision }} -DCMAKE_OSX_ARCHITECTURES=x86_64 | |
cmake --build build -j $(sysctl -n hw.logicalcpu) | |
- name: Upload Object | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{env.LIBNAME}}-macos-${{matrix.arch}}-${{matrix.precision}} | |
path: Binaries | |
windows-build: | |
runs-on: windows-latest | |
strategy: | |
matrix: | |
compiler: [mingw, msvc] # CHANGE: Choose between a compiler, you don't need boths | |
arch: [amd64] | |
precision: [32, 64] | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
# ────────────────────────────────────── | |
- if: matrix.compiler == 'msvc' | |
name: Set up Visual Studio Build Tools | |
uses: microsoft/setup-msbuild@v2 | |
# TODO: Add vcpkg support | |
# ────────────────────────────────────── | |
- if: matrix.compiler == 'mingw' | |
name: Set up Msys2 | |
uses: msys2/setup-msys2@v2 | |
with: | |
msystem: mingw64 | |
install: make mingw-w64-x86_64-gcc mingw64/mingw-w64-x86_64-cmake | |
# Add here dynamic libraries that you use (ex. fftw3, gsl, ...). | |
# Search for the name in https://packages.msys2.org/queue | |
update: false | |
# ────────────────────────────────────── | |
- name: Install winget | |
uses: Cyberboss/install-winget@v1 | |
- name: Install PureData Float 32 | |
if: matrix.precision == '32' | |
run: | | |
winget install -e --id MillerPuckette.PureData --accept-source-agreements | |
- name: Install PureData Float 64 | |
if: matrix.precision == '64' | |
run: | | |
winget install -e --id MillerPuckette.Pd64 --accept-source-agreements | |
- name: Configure and build | |
run: | | |
cmake . -B build -DPD_FLOATSIZE=${{ matrix.precision }} | |
cmake --build build | |
- name: Upload | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{env.LIBNAME}}-f${{ matrix.precision }}-windows-${{ matrix.compiler }} | |
path: Binaries | |
linux-build: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
arch: [amd64, aarch64, arm] | |
precision: [32, 64] | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
submodules: recursive | |
fetch-depth: 0 | |
- name: PureData Sources | |
run: | | |
sudo apt update | |
sudo add-apt-repository ppa:pure-data/pure-data -y | |
sudo apt install puredata -y | |
# Add here dynamic libraries that you use (ex. fftw3, gsl, ...). | |
# search for the name in https://packages.ubuntu.com/search | |
- name: Install aarch64 gcc | |
if: matrix.arch == 'aarch64' | |
run: | | |
sudo apt install gcc-aarch64-linux-gnu -y | |
sudo apt install g++-aarch64-linux-gnu -y | |
- name: Install arm gcc | |
if: matrix.arch == 'arm' | |
run: | | |
sudo apt install gcc-arm-linux-gnueabihf -y | |
sudo apt install g++-arm-linux-gnueabihf -y | |
- name: Build Object | |
if: matrix.arch == 'amd64' | |
run: | | |
cmake . -B build -DPD_FLOATSIZE=${{ matrix.precision }} | |
cmake --build build -- -j$(nproc) | |
- name: Build Object | |
if: matrix.arch == 'aarch64' | |
run: | | |
cmake . -B build -DPD_FLOATSIZE=${{ matrix.precision }} -DCMAKE_SYSTEM_PROCESSOR=aarch64 | |
cmake --build build -- -j$(nproc) | |
- name: Build Object | |
if: matrix.arch == 'arm' | |
run: | | |
cmake . -B build -DPD_FLOATSIZE=${{ matrix.precision }} -DCMAKE_SYSTEM_PROCESSOR=arm | |
cmake --build build -- -j$(nproc) | |
- name: Upload Object | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{ env.LIBNAME }}-linux-${{matrix.arch}}-${{matrix.precision}} | |
path: Binaries | |
package-artifacts: | |
needs: [macos-universal-build, windows-build, linux-build] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Download artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
pattern: '${{ env.LIBNAME }}-*' | |
path: artifacts | |
merge-multiple: true | |
- name: Clear tmp files | |
run: rm -f artifacts/*.pdb | |
- name: Upload artifacts zip | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{env.LIBNAME}}-ALL-binaries | |
path: artifacts |