aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2025-08-07 12:38:57 +0100
committergingerBill <gingerBill@users.noreply.github.com>2025-08-07 12:38:57 +0100
commitd6bd1f144f147ce3c0905cea8425978ec4b4f82a (patch)
treebc892d8c4e345483fd7cf20d521eac3e3fff62d0
parent3de300d2f936a3702b73dabce9e877756892646f (diff)
parent09a1e170bc92a0ea48a8ee67599c2936e924fe4d (diff)
Merge branch 'master' of https://github.com/odin-lang/Odin
-rw-r--r--.github/workflows/nightly.yml75
-rwxr-xr-xci/remove_windows_binaries.sh8
2 files changed, 68 insertions, 15 deletions
diff --git a/.github/workflows/nightly.yml b/.github/workflows/nightly.yml
index eb67eb209..2c9dc30ae 100644
--- a/.github/workflows/nightly.yml
+++ b/.github/workflows/nightly.yml
@@ -47,20 +47,15 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- - uses: jirutka/setup-alpine@v1
- with:
- branch: edge
- - name: (Linux) Download LLVM
- run: |
- apk add --no-cache \
- musl-dev llvm20-dev clang20 git mold lz4 \
- libxml2-static llvm20-static zlib-static zstd-static \
- make
- shell: alpine.sh --root {0}
- - name: build odin
- # NOTE: this build does slow compile times because of musl
- run: ci/build_linux_static.sh
- shell: alpine.sh {0}
+ - name: (Linux) Download LLVM and Build Odin
+ run: |
+ docker run --rm -v "$PWD:/src" -w /src alpine sh -c '
+ apk add --no-cache \
+ musl-dev llvm20-dev clang20 git mold lz4 \
+ libxml2-static llvm20-static zlib-static zstd-static \
+ make &&
+ ./ci/build_linux_static.sh
+ '
- name: Odin run
run: ./odin run examples/demo
- name: Copy artifacts
@@ -74,6 +69,7 @@ jobs:
cp -r core $FILE
cp -r vendor $FILE
cp -r examples $FILE
+ ./ci/remove_windows_binaries.sh $FILE
# Creating a tarball so executable permissions are retained, see https://github.com/actions/upload-artifact/issues/38
tar -czvf dist.tar.gz $FILE
- name: Odin run
@@ -85,6 +81,46 @@ jobs:
with:
name: linux_artifacts
path: dist.tar.gz
+ build_linux_arm:
+ name: Linux ARM Build
+ if: github.repository == 'odin-lang/Odin'
+ runs-on: ubuntu-24.04-arm
+ steps:
+ - uses: actions/checkout@v4
+ - name: (Linux ARM) Download LLVM and Build Odin
+ run: |
+ docker run --rm -v "$PWD:/src" -w /src arm64v8/alpine sh -c '
+ apk add --no-cache \
+ musl-dev llvm20-dev clang20 git mold lz4 \
+ libxml2-static llvm20-static zlib-static zstd-static \
+ make &&
+ ./ci/build_linux_static.sh
+ '
+ - name: Odin run
+ run: ./odin run examples/demo
+ - name: Copy artifacts
+ run: |
+ FILE="odin-linux-arm64-nightly+$(date -I)"
+ mkdir $FILE
+ cp odin $FILE
+ cp LICENSE $FILE
+ cp -r shared $FILE
+ cp -r base $FILE
+ cp -r core $FILE
+ cp -r vendor $FILE
+ cp -r examples $FILE
+ ./ci/remove_windows_binaries.sh $FILE
+ # Creating a tarball so executable permissions are retained, see https://github.com/actions/upload-artifact/issues/38
+ tar -czvf dist.tar.gz $FILE
+ - name: Odin run
+ run: |
+ FILE="odin-linux-arm64-nightly+$(date -I)"
+ $FILE/odin run examples/demo
+ - name: Upload artifact
+ uses: actions/upload-artifact@v4
+ with:
+ name: linux_arm_artifacts
+ path: dist.tar.gz
build_macos:
name: MacOS Build
if: github.repository == 'odin-lang/Odin'
@@ -111,6 +147,7 @@ jobs:
cp -r core $FILE
cp -r vendor $FILE
cp -r examples $FILE
+ ./ci/remove_windows_binaries.sh $FILE
dylibbundler -b -x $FILE/odin -d $FILE/libs -od -p @executable_path/libs
# Creating a tarball so executable permissions are retained, see https://github.com/actions/upload-artifact/issues/38
tar -czvf dist.tar.gz $FILE
@@ -149,6 +186,7 @@ jobs:
cp -r core $FILE
cp -r vendor $FILE
cp -r examples $FILE
+ ./ci/remove_windows_binaries.sh $FILE
dylibbundler -b -x $FILE/odin -d $FILE/libs -od -p @executable_path/libs
# Creating a tarball so executable permissions are retained, see https://github.com/actions/upload-artifact/issues/38
tar -czvf dist.tar.gz $FILE
@@ -163,7 +201,7 @@ jobs:
path: dist.tar.gz
upload_b2:
runs-on: [ubuntu-latest]
- needs: [build_windows, build_macos, build_macos_arm, build_linux]
+ needs: [build_windows, build_macos, build_macos_arm, build_linux, build_linux_arm]
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
@@ -192,6 +230,12 @@ jobs:
name: linux_artifacts
path: linux_artifacts
+ - name: Download Ubuntu ARM artifacts
+ uses: actions/download-artifact@v4.1.7
+ with:
+ name: linux_arm_artifacts
+ path: linux_arm_artifacts
+
- name: Download macOS artifacts
uses: actions/download-artifact@v4.1.7
with:
@@ -219,6 +263,7 @@ jobs:
file linux_artifacts/dist.tar.gz
python3 ci/nightly.py artifact windows-amd64 windows_artifacts/
python3 ci/nightly.py artifact linux-amd64 linux_artifacts/dist.tar.gz
+ python3 ci/nightly.py artifact linux-arm64 linux_arm_artifacts/dist.tar.gz
python3 ci/nightly.py artifact macos-amd64 macos_artifacts/dist.tar.gz
python3 ci/nightly.py artifact macos-arm64 macos_arm_artifacts/dist.tar.gz
python3 ci/nightly.py prune
diff --git a/ci/remove_windows_binaries.sh b/ci/remove_windows_binaries.sh
new file mode 100755
index 000000000..0722fc455
--- /dev/null
+++ b/ci/remove_windows_binaries.sh
@@ -0,0 +1,8 @@
+#!/usr/bin/env sh
+
+find "$1" -type f \(\
+ -iname "*.exe" \
+ -o -iname "*.dll" \
+ -o -iname "*.lib" \
+ -o -iname "*.pdb" \
+ \) -delete