From 59f78c1be09f0fd663da2a751cc5a7073e67ae43 Mon Sep 17 00:00:00 2001 From: Ian Butterworth Date: Sun, 17 Nov 2024 22:44:31 -0500 Subject: [PATCH 1/4] add warning if requesting x64 on apple silicon runners --- dist/index.js | 3 +++ lib/setup-julia.js | 3 +++ src/setup-julia.ts | 4 ++++ 3 files changed, 10 insertions(+) diff --git a/dist/index.js b/dist/index.js index fa1564be..7b763e8d 100644 --- a/dist/index.js +++ b/dist/index.js @@ -580,6 +580,9 @@ function run() { if (!originalArchInput) { // if `originalArchInput` is an empty string throw new Error(`Arch input must not be null`); } + if (originalArchInput == 'x64' && os.platform() == 'darwin' && os.arch() == 'arm64') { + core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).'); + } let processedArchInput; if (originalArchInput == "default") { // If the user sets the `arch` input to `default`, then we use the diff --git a/lib/setup-julia.js b/lib/setup-julia.js index 471adfd0..087b0f2d 100644 --- a/lib/setup-julia.js +++ b/lib/setup-julia.js @@ -88,6 +88,9 @@ function run() { if (!originalArchInput) { // if `originalArchInput` is an empty string throw new Error(`Arch input must not be null`); } + if (originalArchInput == 'x64' && os.platform() == 'darwin' && os.arch() == 'arm64') { + core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).'); + } let processedArchInput; if (originalArchInput == "default") { // If the user sets the `arch` input to `default`, then we use the diff --git a/src/setup-julia.ts b/src/setup-julia.ts index 9ff3990a..8ea8c621 100644 --- a/src/setup-julia.ts +++ b/src/setup-julia.ts @@ -62,6 +62,10 @@ async function run() { throw new Error(`Arch input must not be null`) } + if (originalArchInput == 'x64' && os.platform() == 'darwin' && os.arch() == 'arm64') { + core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).') + } + let processedArchInput: string; if (originalArchInput == "default") { // If the user sets the `arch` input to `default`, then we use the From ab088f0aa37447b3a76d712593782ccdb68abbb7 Mon Sep 17 00:00:00 2001 From: Ian Butterworth Date: Sun, 17 Nov 2024 22:59:30 -0500 Subject: [PATCH 2/4] add some explicit aarch64 macOS builds --- .github/workflows/example-builds.yml | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/.github/workflows/example-builds.yml b/.github/workflows/example-builds.yml index 62caf58d..862fc369 100644 --- a/.github/workflows/example-builds.yml +++ b/.github/workflows/example-builds.yml @@ -27,6 +27,13 @@ jobs: exclude: - os: macOS-latest julia-arch: x86 + include: + - os: macOS-latest + julia-arch: aarch64 + julia-version: 'lts' + - os: macOS-latest + julia-arch: aarch64 + julia-version: '1' steps: - uses: actions/checkout@v4 From ee74250afecc0f2686d3de644bcf0697f8bfc5bd Mon Sep 17 00:00:00 2001 From: Ian Butterworth Date: Sun, 17 Nov 2024 23:07:32 -0500 Subject: [PATCH 3/4] update readme --- README.md | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index a20b3d50..045e39a6 100644 --- a/README.md +++ b/README.md @@ -194,12 +194,18 @@ jobs: strategy: matrix: julia-version: ['1.0', '1.2.0', '^1.3.0-rc1'] - julia-arch: [x64, x86] + julia-arch: [x64, x86, aarch64] os: [ubuntu-latest, windows-latest, macOS-latest] - # 32-bit Julia binaries are not available on macOS + # exclude unavailable/unwanted architectures exclude: - os: macOS-latest julia-arch: x86 + - os: macOS-latest + julia-arch: x64 # can be run but via rosetta on apple silicon runners + - os: ubuntu-latest + julia-arch: aarch64 + - os: windows-latest + julia-arch: aarch64 steps: - uses: actions/checkout@v4 From f6eae2576ebc88a8341f3857eda6f99fce3013f8 Mon Sep 17 00:00:00 2001 From: Ian Butterworth Date: Sun, 17 Nov 2024 23:32:06 -0500 Subject: [PATCH 4/4] suggestion --- dist/index.js | 2 +- lib/setup-julia.js | 2 +- src/setup-julia.ts | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/dist/index.js b/dist/index.js index 7b763e8d..638ebd1b 100644 --- a/dist/index.js +++ b/dist/index.js @@ -581,7 +581,7 @@ function run() { throw new Error(`Arch input must not be null`); } if (originalArchInput == 'x64' && os.platform() == 'darwin' && os.arch() == 'arm64') { - core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).'); + core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 (Apple Silicon) architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).'); } let processedArchInput; if (originalArchInput == "default") { diff --git a/lib/setup-julia.js b/lib/setup-julia.js index 087b0f2d..cb5e5c88 100644 --- a/lib/setup-julia.js +++ b/lib/setup-julia.js @@ -89,7 +89,7 @@ function run() { throw new Error(`Arch input must not be null`); } if (originalArchInput == 'x64' && os.platform() == 'darwin' && os.arch() == 'arm64') { - core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).'); + core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 (Apple Silicon) architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).'); } let processedArchInput; if (originalArchInput == "default") { diff --git a/src/setup-julia.ts b/src/setup-julia.ts index 8ea8c621..587dc67b 100644 --- a/src/setup-julia.ts +++ b/src/setup-julia.ts @@ -63,7 +63,7 @@ async function run() { } if (originalArchInput == 'x64' && os.platform() == 'darwin' && os.arch() == 'arm64') { - core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).') + core.warning('[setup-julia] x64 arch has been requested on a macOS runner that has an arm64 (Apple Silicon) architecture. You may have meant to use the "aarch64" arch instead (or left it unspecified for the correct default).') } let processedArchInput: string;