-
-
Notifications
You must be signed in to change notification settings - Fork 351
Fix 32-bit Windows releases so they are the correct architecture #1475
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from all commits
Commits
Show all changes
16 commits
Select commit
Hold shift + click to select a range
edd1c43
Use bash for everything on all platforms in release workflow
EliahKagan 3e779d9
Remove some commented-out code in the workflow
EliahKagan d7e9269
Remove confusing EXE_NAME environment variable
EliahKagan 564bdc9
Copy from target-specific build directories even on Windows
EliahKagan 418d71f
Reveal what kind of file the executables are when making archives
EliahKagan 286e388
Minor changes from ripgrep workflow + simplify + clarify quoting
EliahKagan a4b5cb9
Only use `cross` on Linux
EliahKagan f6a71f0
Set $TARGET_FLAGS and $TARGET_DIR even without `cross`
EliahKagan cf379f6
Update and clarify comments on job-level env.TARGET_*
EliahKagan cb10aae
Don't check matrix.target for cross + do related prep
EliahKagan 8f43a92
Set $TARGET_FLAGS and $TARGET_DIR from matrix
EliahKagan fbafff3
Really use `cross` only when cross-compiling on Linux
EliahKagan 79f9ec0
Don't set CARGO=cross too early
EliahKagan d6769a6
Use shell expansions for env vars where clearer
EliahKagan a647598
Don't use `--` argument to `strip`
EliahKagan 3c3a831
Go back to always using `cross` on Linux
EliahKagan File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,63 +1,60 @@ | ||
# The way this works is a little weird. But basically, the create-release job | ||
# runs purely to initialize the GitHub release itself. Once done, the upload | ||
# URL of the release is saved as an artifact. | ||
# | ||
# The build-release job runs only once create-release is finished. It gets | ||
# the release upload URL by downloading the corresponding artifact (which was | ||
# uploaded by create-release). It then builds the release executables for each | ||
# supported platform and attaches them as release assets to the previously | ||
# created release. | ||
# | ||
# The key here is that we create the release only once. | ||
# This is largely adapted from past and recent versions of the ripgrep release workflow. | ||
# https://github.com/BurntSushi/ripgrep/blob/master/.github/workflows/release.yml | ||
|
||
name: release | ||
|
||
env: | ||
RUST_BACKTRACE: 1 | ||
CARGO_TERM_COLOR: always | ||
CLICOLOR: 1 | ||
|
||
on: | ||
workflow_dispatch: | ||
push: | ||
# Enable when testing release infrastructure on a branch. | ||
# branches: | ||
# - fix-releases | ||
tags: | ||
- "v.*" | ||
- 'v*' | ||
|
||
env: | ||
RUST_BACKTRACE: 1 | ||
CARGO_TERM_COLOR: always | ||
CLICOLOR: 1 | ||
|
||
defaults: | ||
run: | ||
shell: bash | ||
|
||
jobs: | ||
# The create-release job runs purely to initialize the GitHub release itself, | ||
# and names the release after the version 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 | ||
# env: | ||
# # Set to force version number, e.g., when no tag exists. | ||
# ARTIFACT_VERSION: TEST-0.0.0 | ||
# VERSION: TEST-0.0.0 | ||
steps: | ||
- name: Create artifacts directory | ||
run: mkdir artifacts | ||
|
||
- name: Get the release version from the tag | ||
if: env.ARTIFACT_VERSION == '' | ||
run: | | ||
echo "ARTIFACT_VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV | ||
echo "version is: ${{ env.ARTIFACT_VERSION }}" | ||
if: env.VERSION == '' | ||
run: echo 'VERSION=${{ github.ref_name }}' >> "$GITHUB_ENV" | ||
|
||
- name: Create GitHub release | ||
id: release | ||
uses: ncipollo/release-action@v1 | ||
with: | ||
tag: ${{ env.ARTIFACT_VERSION }} | ||
name: ${{ env.ARTIFACT_VERSION }} | ||
tag: ${{ env.VERSION }} | ||
name: ${{ env.VERSION }} | ||
allowUpdates: true | ||
omitBody: true | ||
omitPrereleaseDuringUpdate: true | ||
token: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Save release upload URL to artifact | ||
run: echo "${{ steps.release.outputs.upload_url }}" > artifacts/release-upload-url | ||
run: echo '${{ steps.release.outputs.upload_url }}' > artifacts/release-upload-url | ||
|
||
- name: Save version number to artifact | ||
run: echo "${{ env.ARTIFACT_VERSION }}" > artifacts/release-version | ||
run: echo "$VERSION" > artifacts/release-version | ||
|
||
- name: Upload artifacts | ||
uses: actions/upload-artifact@v4 | ||
|
@@ -67,23 +64,13 @@ jobs: | |
|
||
build-release: | ||
name: build-release | ||
needs: [ "create-release" ] | ||
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 | ||
# Emit backtraces on panics. | ||
RUST_BACKTRACE: 1 | ||
# The name of the executable to expect | ||
EXE_NAME: ein | ||
|
||
needs: [ create-release ] | ||
|
||
strategy: | ||
matrix: | ||
build: [ linux, linux-arm, macos, win-msvc, win-gnu, win32-msvc ] | ||
feature: [ "small", "lean", "max", "max-pure" ] | ||
feature: [ small, lean, max, max-pure ] | ||
include: | ||
- build: linux | ||
os: ubuntu-latest | ||
|
@@ -127,11 +114,16 @@ jobs: | |
feature: max | ||
|
||
runs-on: ${{ matrix.os }} | ||
|
||
env: | ||
CARGO: cargo # Sometimes changes to `cross` later (such as when building linux-arm). | ||
TARGET_FLAGS: --target=${{ matrix.target }} | ||
TARGET_DIR: ./target/${{ matrix.target }} | ||
RUST_BACKTRACE: 1 # Emit backtraces on panics. | ||
|
||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 1 | ||
|
||
- name: Install packages (Ubuntu) | ||
# Because openssl doesn't work on musl by default, we resort to max-pure. And that won't need any dependency, so we can skip this.continue-on-error | ||
|
@@ -147,18 +139,16 @@ jobs: | |
targets: ${{ matrix.target }} | ||
|
||
- name: Use Cross | ||
# if: matrix.os != 'windows-latest' | ||
if: matrix.os == 'ubuntu-latest' | ||
run: | | ||
cargo install cross | ||
echo "CARGO=cross" >> $GITHUB_ENV | ||
echo "TARGET_FLAGS=--target ${{ matrix.target }}" >> $GITHUB_ENV | ||
echo "TARGET_DIR=./target/${{ matrix.target }}" >> $GITHUB_ENV | ||
echo 'CARGO=cross' >> "$GITHUB_ENV" | ||
|
||
- name: Show command used for Cargo | ||
run: | | ||
echo "cargo command is: ${{ env.CARGO }}" | ||
echo "target flag is: ${{ env.TARGET_FLAGS }}" | ||
echo "target dir is: ${{ env.TARGET_DIR }}" | ||
echo "cargo command is: $CARGO" | ||
echo "target flag is: $TARGET_FLAGS" | ||
echo "target dir is: $TARGET_DIR" | ||
|
||
- name: Get release download URL | ||
uses: actions/download-artifact@v4 | ||
|
@@ -167,21 +157,17 @@ jobs: | |
path: artifacts | ||
|
||
- name: Set release upload URL and release version | ||
shell: bash | ||
run: | | ||
release_upload_url="$(cat artifacts/release-upload-url)" | ||
echo "RELEASE_UPLOAD_URL=$release_upload_url" >> $GITHUB_ENV | ||
echo "release upload url: $RELEASE_UPLOAD_URL" | ||
release_version="$(cat artifacts/release-version)" | ||
echo "RELEASE_VERSION=$release_version" >> $GITHUB_ENV | ||
echo "release version: $RELEASE_VERSION" | ||
echo "UPLOAD_URL=$(< artifacts/release-upload-url)" >> "$GITHUB_ENV" | ||
echo "VERSION=$(< artifacts/release-version)" >> "$GITHUB_ENV" | ||
|
||
- name: Build release binary | ||
run: ${{ env.CARGO }} build --verbose --release ${{ env.TARGET_FLAGS }} --no-default-features --features ${{ matrix.feature }} | ||
run: | | ||
"$CARGO" build --verbose --release "$TARGET_FLAGS" --no-default-features --features ${{ matrix.feature }} | ||
|
||
- name: Strip release binary (linux and macos) | ||
if: matrix.build == 'linux' || matrix.build == 'macos' | ||
run: strip target/${{ matrix.target }}/release/${{ env.EXE_NAME }} target/${{ matrix.target }}/release/gix | ||
run: strip "$TARGET_DIR"/release/{ein,gix} | ||
|
||
- name: Strip release binary (arm) | ||
if: matrix.build == 'linux-arm' | ||
|
@@ -190,32 +176,34 @@ jobs: | |
"$PWD/target:/target:Z" \ | ||
rustembedded/cross:arm-unknown-linux-gnueabihf \ | ||
arm-linux-gnueabihf-strip \ | ||
/target/arm-unknown-linux-gnueabihf/release/${{ env.EXE_NAME }} \ | ||
/target/arm-unknown-linux-gnueabihf/release/ein \ | ||
/target/arm-unknown-linux-gnueabihf/release/gix | ||
|
||
- name: Build archive | ||
shell: bash | ||
run: | | ||
staging="gitoxide-${{ matrix.feature }}-${{ env.RELEASE_VERSION }}-${{ matrix.target }}" | ||
mkdir -p "$staging" | ||
staging='gitoxide-${{ matrix.feature }}-${{ env.VERSION }}-${{ matrix.target }}' | ||
mkdir -p -- "$staging" | ||
|
||
cp {README.md,LICENSE-*,CHANGELOG.md} "$staging/" | ||
|
||
if [ "${{ matrix.os }}" = "windows-latest" ]; then | ||
cp target/release/${{ env.EXE_NAME }}.exe target/release/gix.exe "$staging/" | ||
if [ '${{ matrix.os }}' = 'windows-latest' ]; then | ||
file -- "$TARGET_DIR"/release/{ein,gix}.exe | ||
cp -- "$TARGET_DIR"/release/{ein,gix}.exe "$staging/" | ||
7z a "$staging.zip" "$staging" | ||
echo "ASSET=$staging.zip" >> $GITHUB_ENV | ||
echo "ASSET=$staging.zip" >> "$GITHUB_ENV" | ||
else | ||
cp target/${{ matrix.target }}/release/${{ env.EXE_NAME }} target/${{ matrix.target }}/release/gix "$staging/" | ||
file -- "$TARGET_DIR"/release/{ein,gix} | ||
cp -- "$TARGET_DIR"/release/{ein,gix} "$staging/" | ||
tar czf "$staging.tar.gz" "$staging" | ||
echo "ASSET=$staging.tar.gz" >> $GITHUB_ENV | ||
echo "ASSET=$staging.tar.gz" >> "$GITHUB_ENV" | ||
fi | ||
|
||
- name: Upload release archive | ||
uses: actions/[email protected] | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
with: | ||
upload_url: ${{ env.RELEASE_UPLOAD_URL }} | ||
upload_url: ${{ env.UPLOAD_URL }} | ||
asset_path: ${{ env.ASSET }} | ||
asset_name: ${{ env.ASSET }} | ||
asset_content_type: application/octet-stream |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.