Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
wpbonelli committed Feb 23, 2024
1 parent fa29361 commit 00ecf29
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 6 deletions.
50 changes: 45 additions & 5 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -63,9 +63,17 @@ jobs:
matrix:
include:
- os: ${{ inputs.linux_version }}
compiler: ${{ inputs.compiler_toolchain }}
version: ${{ inputs.compiler_version }}
- os: macos-12
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}
Expand All @@ -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: |
Expand All @@ -122,13 +131,39 @@ 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
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
run: |
if [[ "$RUNNER_OS" == "macOS" ]]; then
os_ver=$(sw_vers -productVersion | cut -d'.' -f1)
if (( "$os_ver" > 12 )); then
export LDFLAGS="$LDFLAGS -Wl,-ld_classic"
fi
fi
meson setup builddir -Ddebug=false --prefix=$(pwd) --libdir=bin
meson install -C builddir
meson test --verbose --no-rebuild -C builddir
if [[ "$RUNNER_OS" == "macOS" ]]; then
ostool -L bin/mf6
lipo -info bin/mf6
fi
- name: Build binaries (Windows)
if: runner.os == 'Windows'
Expand All @@ -145,6 +180,11 @@ 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: lipo -info mf6

- name: Upload binaries
uses: actions/upload-artifact@v3
with:
Expand Down Expand Up @@ -412,7 +452,7 @@ jobs:
matrix:
include:
- os: ubuntu-22.04
- os: macos-12
- os: macos-13
- os: macos-14
- os: windows-2022
defaults:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/release_dispatch.yml
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ jobs:
echo "version=$ver" >> $GITHUB_OUTPUT
make_dist:
name: Make distribution
uses: MODFLOW-USGS/modflow6/.github/workflows/release.yml@develop
uses: wpbonelli/modflow6/.github/workflows/release.yml@release-ci
needs: set_options
with:
# If the workflow is manually triggered, the maintainer must manually set approve=true to approve a release.
Expand Down

0 comments on commit 00ecf29

Please sign in to comment.