Skip to content

chore: use nushell in ci #429

chore: use nushell in ci

chore: use nushell in ci #429

Workflow file for this run

name: "cargo"
on:
workflow_dispatch:
push:
branches:
- master
env:
CARGO_TERM_COLOR: always
jobs:
bindgen:
defaults:
run:
shell: nu {0}
strategy:
matrix:
os: [windows-11-preview_aarch64, windows-2025]
target: [aarch64-pc-windows-msvc, x86_64-pc-windows-msvc, i686-pc-windows-msvc]
exclude:
- os: windows-11-preview_aarch64
target: x86_64-pc-windows-msvc
- os: windows-11-preview_aarch64
target: i686-pc-windows-msvc
- os: windows-2025
target: aarch64-pc-windows-msvc
runs-on: ${{ matrix.os }}
steps:
- if: matrix.os != 'windows-11-preview_aarch64'
uses: hustcer/setup-nu@main
with:
version: '*'
- if: matrix.os == 'windows-11-preview_aarch64'
uses: robinraju/release-downloader@v1
with:
repository: 'git-for-windows/git'
tag: 'v2.48.0-rc1.windows.1'
filename: 'Git-2.48.0-rc1-arm64.exe'
- if: matrix.os == 'windows-11-preview_aarch64'
uses: robinraju/release-downloader@v1
with:
repository: 'llvm/llvm-project'
tag: 'llvmorg-19.1.5'
filename: 'LLVM-19.1.5-woa64.exe'
- name: Install nushell
if: matrix.os == 'windows-11-preview_aarch64'
shell: powershell
run: |
# install chocolatey
Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))
# install nushell
choco install nushell -y --no-progress
Add-Content -Path $env:GITHUB_PATH -Value "C:\ProgramData\chocolatey\bin"
Import-Module $env:ChocolateyInstall\helpers\chocolateyProfile.psm1
refreshenv
nu --version
- name: Use nushell
if: matrix.os == 'windows-11-preview_aarch64'
run: |
choco install visualstudio2022buildtools -y --no-progress --package-parameters "--add Microsoft.VisualStudio.Component.VC.Tools.ARM64 --add Microsoft.VisualStudio.Component.Windows11SDK.22621"
echo "Visual Studio 2022 Build Tools (aarch64) installation completed."
run-external $"($env.RUNNER_TEMP)/LLVM-19.1.5-woa64.exe" "/S" e>| split chars
echo "LLVM 19.1.5 (aarch64) installation completed."
run-external $"($env.RUNNER_TEMP)/Git-2.48.0-rc1-arm64.exe" "/VERYSILENT" e>| split chars
for path in ['C:/Program Files/Git/cmd', 'C:/Program Files/Git/bin'] {
$"{$path}" | save $env.GITHUB_PATH --append
}
echo "Git 2.48.0-rc1 (aarch64) installation completed."
http get "https://win.rustup.rs/aarch64" | save $"($env.RUNNER_TEMP)/rustup-init.exe"
run-external $"($env.RUNNER_TEMP)/rustup-init.exe" "--default-host" "aarch64-pc-windows-msvc" "--default-toolchain" "nightly" "-y" e>| split chars
echo "Rust (nightly, aarch64) installation completed."
- name: Install Rust
if: matrix.os != 'windows-11-preview_aarch64'
uses: dtolnay/rust-toolchain@nightly
with:
targets: ${{ matrix.target }}
components: rustfmt
- name: Checkout repository
uses: actions/checkout@v4
- name: Run tests and generate bindings
env:
PHNT_VERSION: PHNT_WIN11_24H2
PHNT_MODE: PHNT_MODE_USER
run: |
cargo test --release -vv -F regenerate --target ${{ matrix.target }}
- name: Extract architecture from target triple and move bindings
run: |
let $arch = '${{ matrix.target }}' | split row '-' | first
let $arch = if $arch == 'i686' { 'x86' } else { $arch }
echo $'ARCH=($arch)' | save $env.GITHUB_ENV --append
let output = glob target/i686-pc-windows-msvc/debug/build/**/${{ env.ARCH }}_bindgen.rs | first
cp $output src/ffi/${{ env.ARCH }}_bindgen.rs
echo $"Moved ($output) to src/ffi/${{ env.ARCH }}_bindgen.rs"
- name: Upload generated file as artifact
uses: actions/upload-artifact@v4
with:
name: ${{ env.ARCH }}_bindgen.rs
path: src/ffi/${{ env.ARCH }}_bindgen.rs
commit-and-push:
runs-on: ubuntu-latest
needs: bindgen
if: success() # Run only if the generate-bindgen job succeeds
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Download generated files
uses: actions/download-artifact@v4
with:
pattern: "*bindgen.rs"
path: src/ffi
merge-multiple: true
- name: Configure Git
run: |
git config user.name "GitHub Actions"
git config user.email "[email protected]"
- name: Commit and push changes
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
git add src/ffi
# Check if there are any changes to commit
if git diff --quiet --exit-code --cached; then
echo "No changes to commit."
else
git commit -m "chore: update vendored bindings"
git push --force
fi