From 214c1ee6e8a663212eaf416dd13f926a3c8ced9a Mon Sep 17 00:00:00 2001 From: wpbonelli Date: Thu, 22 Feb 2024 22:02:19 -0500 Subject: [PATCH] ci(release): statically linked gfortran build for ARM macs (#1643) * second try at ARM mac dist, replacing 95aec27 * add statically linked distribution built with gfortran * link static libgfortran and libquadmath by hiding dylibs * -static* flags don't seem to work on macOS * set LDFLAGS for macos >= 13 --- .github/workflows/release.yml | 44 ++++++++++++++++++++++---- .github/workflows/release_dispatch.yml | 2 +- 2 files changed, 39 insertions(+), 7 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 689c93d8dd8..6737e9d9359 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -63,9 +63,17 @@ jobs: matrix: include: - os: ${{ inputs.linux_version }} - - os: macos-12 + compiler: ${{ inputs.compiler_toolchain }} + version: ${{ inputs.compiler_version }} + - os: macos-13 + compiler: ${{ inputs.compiler_toolchain }} + version: ${{ inputs.compiler_version }} - os: macos-14 + compiler: gcc + version: 13 - os: windows-2022 + compiler: ${{ inputs.compiler_toolchain }} + version: ${{ inputs.compiler_version }} defaults: run: shell: bash -l {0} @@ -90,12 +98,13 @@ jobs: bash powershell - - name: Setup ${{ inputs.compiler_toolchain }} ${{ inputs.compiler_version }} + - name: Setup ${{ matrix.compiler }} ${{ matrix.version }} + id: setup-fortran uses: fortran-lang/setup-fortran@v1 with: - compiler: ${{ inputs.compiler_toolchain }} - version: ${{ inputs.compiler_version }} - + compiler: ${{ matrix.compiler }} + version: ${{ matrix.version }} + - name: Set version number id: set_version run: | @@ -122,6 +131,22 @@ jobs: fi eval "$cmd" + # for statically linked gfortran ARM mac build + - name: Hide dylibs (macOS) + if: matrix.os == 'macos-14' + run: | + mv /opt/homebrew/opt/gcc/lib/gcc/current/libgfortran.5.dylib /opt/homebrew/opt/gcc/lib/gcc/current/libgfortran.5.dylib.bak + mv /opt/homebrew/opt/gcc/lib/gcc/current/libquadmath.0.dylib /opt/homebrew/opt/gcc/lib/gcc/current/libquadmath.0.dylib.bak + + - name: Set LDFLAGS (macOS) + if: runner.os == 'macOS' + run: | + os_ver=$(sw_vers -productVersion | cut -d'.' -f1) + if (( "$os_ver" > 12 )); then + ldflags="$LDFLAGS -Wl,-ld_classic" + echo "LDFLAGS=$ldflags" >> $GITHUB_ENV + fi + - name: Build binaries if: runner.os != 'Windows' working-directory: modflow6 @@ -145,6 +170,13 @@ jobs: ostag=$(python -c "from modflow_devtools.ostags import get_ostag; print(get_ostag())") echo "ostag=$ostag" >> $GITHUB_OUTPUT + - name: Check architecture (macOS) + working-directory: modflow6/bin + if: runner.os == 'macOS' + run: | + otool -L mf6 + lipo -info mf6 + - name: Upload binaries uses: actions/upload-artifact@v3 with: @@ -412,7 +444,7 @@ jobs: matrix: include: - os: ubuntu-22.04 - - os: macos-12 + - os: macos-13 - os: macos-14 - os: windows-2022 defaults: diff --git a/.github/workflows/release_dispatch.yml b/.github/workflows/release_dispatch.yml index 654d6acd292..4c7cb5679fd 100644 --- a/.github/workflows/release_dispatch.yml +++ b/.github/workflows/release_dispatch.yml @@ -130,7 +130,7 @@ jobs: branch: ${{ needs.set_options.outputs.branch }} developmode: false full: true - run_tests: ${{ inputs.run_tests == '' || inputs.run_tests == 'true' }} + run_tests: ${{ inputs.run_tests }} version: ${{ needs.set_options.outputs.version }} pr: name: Draft release PR