release #63
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: release | |
# Only do the release on x.y.z tags. | |
on: | |
push: | |
tags: | |
- "v[0-9]+.[0-9]+.[0-9]+" | |
- "v[0-9]+.[0-9]+.[0-9]+-rc.[0-9]+" | |
# We need this to be able to create releases. | |
permissions: | |
contents: write | |
jobs: | |
# The create-release job runs purely to initialize the GitHub release itself, | |
# and names the release after the `x.y.z` tag that was pushed. It's separate | |
# from building the release so that we only create the release once. | |
create-release: | |
name: create-release | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v4 | |
- name: Get the release version from the tag | |
if: env.VERSION == '' | |
run: echo "VERSION=${{ github.ref_name }}" >> $GITHUB_ENV | |
- name: Show the version | |
run: | | |
echo "version is: $VERSION" | |
- name: Check that tag version and Cargo.toml version are the same | |
shell: bash | |
run: | | |
if ! grep -q "version = \"$(echo $VERSION | sed 's/v\(.*\)-.*/\1/')\"" Cargo.toml; then | |
echo "version does not match Cargo.toml" >&2 | |
exit 1 | |
fi | |
- name: Create GitHub release | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
run: gh release create $VERSION --verify-tag --draft --title $VERSION | |
outputs: | |
version: ${{ env.VERSION }} | |
build-release: | |
name: build-release | |
needs: ["create-release"] | |
runs-on: ${{ matrix.os }} | |
env: | |
# For some builds, we use cross to test on 32-bit and big-endian | |
# systems. | |
CARGO: cargo | |
# When CARGO is set to CROSS, this is set to `--target matrix.target`. | |
TARGET_FLAGS: | |
# When CARGO is set to CROSS, TARGET_DIR includes matrix.target. | |
TARGET_DIR: ./target | |
# Bump this as appropriate. We pin to a version to make sure CI | |
# continues to work as cross releases in the past have broken things | |
# in subtle ways. | |
CROSS_VERSION: v0.2.5 | |
# Emit backtraces on panics. | |
RUST_BACKTRACE: 1 | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- build: linux | |
os: ubuntu-latest | |
rust: nightly | |
target: x86_64-unknown-linux-gnu | |
strip: x86_64-linux-gnu-strip | |
# - build: macos | |
# os: macos-latest | |
# rust: nightly | |
# target: x86_64-apple-darwin | |
# - build: win-msvc | |
# os: windows-latest | |
# rust: nightly | |
# target: x86_64-pc-windows-msvc | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v4 | |
- name: Install Rust | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ matrix.rust }} | |
target: ${{ matrix.target }} | |
- name: Use Cross | |
if: matrix.os == 'ubuntu-latest' && matrix.target != '' | |
shell: bash | |
run: | | |
# In the past, new releases of 'cross' have broken CI. So for now, we | |
# pin it. We also use their pre-compiled binary releases because cross | |
# has over 100 dependencies and takes a bit to compile. | |
dir="$RUNNER_TEMP/cross-download" | |
mkdir "$dir" | |
echo "$dir" >> $GITHUB_PATH | |
cd "$dir" | |
curl -LO "https://github.com/cross-rs/cross/releases/download/$CROSS_VERSION/cross-x86_64-unknown-linux-musl.tar.gz" | |
tar xf cross-x86_64-unknown-linux-musl.tar.gz | |
echo "CARGO=cross" >> $GITHUB_ENV | |
- name: Set target variables | |
shell: bash | |
run: | | |
echo "TARGET_FLAGS=--target ${{ matrix.target }}" >> $GITHUB_ENV | |
echo "TARGET_DIR=./target/${{ matrix.target }}" >> $GITHUB_ENV | |
- name: Show command used for Cargo | |
shell: bash | |
run: | | |
echo "cargo command is: ${{ env.CARGO }}" | |
echo "target flag is: ${{ env.TARGET_FLAGS }}" | |
echo "target dir is: ${{ env.TARGET_DIR }}" | |
- name: Build release binary | |
shell: bash | |
run: | | |
${{ env.CARGO }} build --verbose --release ${{ env.TARGET_FLAGS }} | |
if [ "${{ matrix.os }}" = "windows-latest" ]; then | |
bin="target/${{ matrix.target }}/release/afrim-wish.exe" | |
else | |
bin="target/${{ matrix.target }}/release/afrim-wish" | |
fi | |
echo "BIN=$bin" >> $GITHUB_ENV | |
- name: Strip release binary (macos) | |
if: matrix.os == 'macos-latest' | |
shell: bash | |
run: strip "$BIN" | |
- name: Strip release binary (cross) | |
if: env.CARGO == 'cross' | |
shell: bash | |
run: | | |
docker run --rm -v \ | |
"$PWD/target:/target:Z" \ | |
"ghcr.io/cross-rs/${{ matrix.target }}:main" \ | |
"${{ matrix.strip }}" \ | |
"/$BIN" | |
- name: Determine archive name | |
shell: bash | |
run: | | |
version="${{ needs.create-release.outputs.version }}" | |
echo "ARCHIVE=afrim-wish-$version-${{ matrix.target }}" >> $GITHUB_ENV | |
- name: Creating directory for archive | |
shell: bash | |
run: | | |
mkdir -p "$ARCHIVE" | |
cp "$BIN" "$ARCHIVE"/ | |
cp {LICENSE,demo.gif,CHANGELOG.md} "$ARCHIVE"/ | |
- name: Build archive (Windows) | |
shell: bash | |
if: matrix.os == 'windows-latest' | |
run: | | |
7z a "$ARCHIVE.zip" "$ARCHIVE" | |
certutil -hashfile "$ARCHIVE.zip" SHA256 > "$ARCHIVE.zip.sha256" | |
echo "ASSET=$ARCHIVE.zip" >> $GITHUB_ENV | |
echo "ASSET_SUM=$ARCHIVE.zip.sha256" >> $GITHUB_ENV | |
- name: Build archive (Unix) | |
shell: bash | |
if: matrix.os != 'windows-latest' | |
run: | | |
tar czf "$ARCHIVE.tar.gz" "$ARCHIVE" | |
shasum -a 256 "$ARCHIVE.tar.gz" > "$ARCHIVE.tar.gz.sha256" | |
echo "ASSET=$ARCHIVE.tar.gz" >> $GITHUB_ENV | |
echo "ASSET_SUM=$ARCHIVE.tar.gz.sha256" >> $GITHUB_ENV | |
- name: Upload release archive | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
shell: bash | |
run: | | |
version="${{ needs.create-release.outputs.version }}" | |
gh release upload "$version" ${{ env.ASSET }} ${{ env.ASSET_SUM }} |