Add an option to split generate waj file. #4
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: Pre-Release | ||
on: | ||
push: | ||
tags: | ||
- '[0-9]+.[0-9]+.[0-9]+' | ||
- '[0-9]+.[0-9]+.[0-9]+-[0-9a-zA-Z]+' | ||
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: | ||
- 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 = \"$VERSION\"" 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 --draft --verify-tag --title $VERSION | ||
outputs: | ||
version: ${{ env.VERSION }} | ||
# Now the github release has been created, we can build our binaries | ||
# and upload them to github release | ||
build-release: | ||
name: build-release | ||
needs: ['create-release'] | ||
runs-on: ${{ matrix.os }} | ||
env: | ||
# Emit backtraces on panics. | ||
RUST_BACKTRACE: 1 | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
build: [linux, macos] | ||
include: | ||
- build: linux | ||
os: ubuntu-latest | ||
- build: macos | ||
os: macos-latest | ||
steps: | ||
- name: Checkout code | ||
uses: actions/checkout@v4 | ||
- name: Download libzim | ||
run: | | ||
if [[ "${{ matrix.build }}" == "linux" ]] | ||
then | ||
ARCH="x86_64" | ||
ARCH_POST="/x86_64-linux-gnu" | ||
LIBZIM_NAME="libzim.so.9" | ||
else | ||
ARCH="arm64" | ||
ARCH_POST="" | ||
LIBZIM_NAME="libzim.9.dylib" | ||
fi | ||
VERSION="9.2.1" | ||
ARCHIVE_NAME="libzim_${{ matrix.build }}-${ARCH}-${VERSION}" | ||
wget "https://download.openzim.org/release/libzim/${ARCHIVE_NAME}.tar.gz" | ||
tar xf ${ARCHIVE_NAME}.tar.gz | ||
ARCHIVE_PATH=$(pwd)/${ARCHIVE_NAME} | ||
LIBZIM_LIB=${ARCHIVE_PATH}/lib${ARCH_POST} | ||
echo "LIBZIM_NAME=$LIBZIM_NAME" >> $GITHUB_ENV | ||
echo "LIBZIM_LIB=$LIBZIM_LIB" >> $GITHUB_ENV | ||
echo "LIBZIM_INCLUDE=${ARCHIVE_PATH}/include" >> $GITHUB_ENV | ||
echo "DYLD_LIBRARY_PATH=${LIBZIM_LIB}:$DYLD_LIBRARY_PATH" >> $GITHUB_ENV | ||
- name: Build release binary | ||
shell: bash | ||
run: | | ||
cargo build --verbose --release | ||
bin="target/release/zim2waj" | ||
echo "BIN=$bin" >> $GITHUB_ENV | ||
- name: Strip release binary (macos) | ||
if: matrix.os == 'macos-latest' | ||
shell: bash | ||
run: strip "$BIN" | ||
- name: Determine archive name | ||
shell: bash | ||
run: | | ||
version="${{ needs.create-release.outputs.version }}" | ||
echo "ARCHIVE=zim2waj-$version-${{ matrix.build }}" >> $GITHUB_ENV | ||
- name: Creating directory for archive | ||
shell: bash | ||
run: | | ||
mkdir -p "$ARCHIVE"/{complete,doc} | ||
cp "$BIN" "$ARCHIVE"/ | ||
cp "${LIBZIM_LIB}/${LIBZIM_NAME}" "$ARCHIVE/" | ||
cp {README.md,LICENSE-MIT} "$ARCHIVE"/ | ||
cp Changelog.md "$ARCHIVE"/doc/ | ||
- name: Build archive (Unix) | ||
shell: bash | ||
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 }} |