chore(workflows): add container upx fallback
This commit is contained in:
@@ -251,25 +251,49 @@ jobs:
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
upx_cmd=""
|
upx_cmd=""
|
||||||
|
upx_runner=""
|
||||||
if command -v upx >/dev/null 2>&1; then
|
if command -v upx >/dev/null 2>&1; then
|
||||||
upx_cmd=upx
|
upx_cmd=upx
|
||||||
elif command -v upx-ucl >/dev/null 2>&1; then
|
elif command -v upx-ucl >/dev/null 2>&1; then
|
||||||
upx_cmd=upx-ucl
|
upx_cmd=upx-ucl
|
||||||
|
elif command -v docker >/dev/null 2>&1; then
|
||||||
|
upx_runner=docker
|
||||||
|
elif command -v podman >/dev/null 2>&1; then
|
||||||
|
upx_runner=podman
|
||||||
else
|
else
|
||||||
echo "UPX is not available on PATH; continuing without binary compression." >&2
|
echo "UPX is not available on PATH and no container runtime is available; continuing without binary compression." >&2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p dist
|
mkdir -p dist
|
||||||
|
|
||||||
|
compress_with_upx() {
|
||||||
|
local file="$1"
|
||||||
|
|
||||||
|
if [[ -n "${upx_cmd}" ]]; then
|
||||||
|
"${upx_cmd}" --best --lzma "${file}"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${upx_runner}" == "docker" ]]; then
|
||||||
|
docker run --rm -v "$PWD/dist:/work" ghcr.io/upx/upx:4.2.4 --best --lzma "/work/$(basename "${file}")"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${upx_runner}" == "podman" ]]; then
|
||||||
|
podman run --rm -v "$PWD/dist:/work:Z" ghcr.io/upx/upx:4.2.4 --best --lzma "/work/$(basename "${file}")"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
for target in linux/amd64 linux/arm64; do
|
for target in linux/amd64 linux/arm64; do
|
||||||
os="${target%/*}"
|
os="${target%/*}"
|
||||||
arch="${target#*/}"
|
arch="${target#*/}"
|
||||||
|
|
||||||
bin="vociferate_${RELEASE_VERSION}_${os}_${arch}"
|
bin="vociferate_${RELEASE_VERSION}_${os}_${arch}"
|
||||||
GOOS="$os" GOARCH="$arch" go build -trimpath -ldflags="-s -w" -o "dist/${bin}" ./cmd/vociferate
|
GOOS="$os" GOARCH="$arch" go build -trimpath -ldflags="-s -w" -o "dist/${bin}" ./cmd/vociferate
|
||||||
if [[ -n "${upx_cmd}" ]]; then
|
compress_with_upx "dist/${bin}"
|
||||||
"${upx_cmd}" --best --lzma "dist/${bin}"
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
|
|
||||||
(
|
(
|
||||||
@@ -349,7 +373,7 @@ jobs:
|
|||||||
echo "- Tag: ${TAG_NAME}"
|
echo "- Tag: ${TAG_NAME}"
|
||||||
echo "- Release notes sourced from changelog entry ${RELEASE_VERSION}."
|
echo "- Release notes sourced from changelog entry ${RELEASE_VERSION}."
|
||||||
echo "- Published assets: vociferate_${RELEASE_VERSION}_linux_amd64, vociferate_${RELEASE_VERSION}_linux_arm64, checksums.txt"
|
echo "- Published assets: vociferate_${RELEASE_VERSION}_linux_amd64, vociferate_${RELEASE_VERSION}_linux_arm64, checksums.txt"
|
||||||
echo "- Release binaries are compressed with UPX when available, otherwise uploaded uncompressed."
|
echo "- Release binaries use local UPX when available, otherwise containerized UPX (Docker/Podman), otherwise uncompressed upload."
|
||||||
} >> "$SUMMARY_FILE"
|
} >> "$SUMMARY_FILE"
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -173,25 +173,49 @@ jobs:
|
|||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
upx_cmd=""
|
upx_cmd=""
|
||||||
|
upx_runner=""
|
||||||
if command -v upx >/dev/null 2>&1; then
|
if command -v upx >/dev/null 2>&1; then
|
||||||
upx_cmd=upx
|
upx_cmd=upx
|
||||||
elif command -v upx-ucl >/dev/null 2>&1; then
|
elif command -v upx-ucl >/dev/null 2>&1; then
|
||||||
upx_cmd=upx-ucl
|
upx_cmd=upx-ucl
|
||||||
|
elif command -v docker >/dev/null 2>&1; then
|
||||||
|
upx_runner=docker
|
||||||
|
elif command -v podman >/dev/null 2>&1; then
|
||||||
|
upx_runner=podman
|
||||||
else
|
else
|
||||||
echo "UPX is not available on PATH; continuing without binary compression." >&2
|
echo "UPX is not available on PATH and no container runtime is available; continuing without binary compression." >&2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p dist
|
mkdir -p dist
|
||||||
|
|
||||||
|
compress_with_upx() {
|
||||||
|
local file="$1"
|
||||||
|
|
||||||
|
if [[ -n "${upx_cmd}" ]]; then
|
||||||
|
"${upx_cmd}" --best --lzma "${file}"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${upx_runner}" == "docker" ]]; then
|
||||||
|
docker run --rm -v "$PWD/dist:/work" ghcr.io/upx/upx:4.2.4 --best --lzma "/work/$(basename "${file}")"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${upx_runner}" == "podman" ]]; then
|
||||||
|
podman run --rm -v "$PWD/dist:/work:Z" ghcr.io/upx/upx:4.2.4 --best --lzma "/work/$(basename "${file}")"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
for target in linux/amd64 linux/arm64; do
|
for target in linux/amd64 linux/arm64; do
|
||||||
os="${target%/*}"
|
os="${target%/*}"
|
||||||
arch="${target#*/}"
|
arch="${target#*/}"
|
||||||
|
|
||||||
bin="vociferate_${RELEASE_VERSION}_${os}_${arch}"
|
bin="vociferate_${RELEASE_VERSION}_${os}_${arch}"
|
||||||
GOOS="$os" GOARCH="$arch" go build -trimpath -ldflags="-s -w" -o "dist/${bin}" ./cmd/vociferate
|
GOOS="$os" GOARCH="$arch" go build -trimpath -ldflags="-s -w" -o "dist/${bin}" ./cmd/vociferate
|
||||||
if [[ -n "${upx_cmd}" ]]; then
|
compress_with_upx "dist/${bin}"
|
||||||
"${upx_cmd}" --best --lzma "dist/${bin}"
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
|
|
||||||
(
|
(
|
||||||
@@ -271,7 +295,7 @@ jobs:
|
|||||||
echo "- Tag: ${TAG_NAME}"
|
echo "- Tag: ${TAG_NAME}"
|
||||||
echo "- Release notes sourced from changelog entry ${RELEASE_VERSION}."
|
echo "- Release notes sourced from changelog entry ${RELEASE_VERSION}."
|
||||||
echo "- Published assets: vociferate_${RELEASE_VERSION}_linux_amd64, vociferate_${RELEASE_VERSION}_linux_arm64, checksums.txt"
|
echo "- Published assets: vociferate_${RELEASE_VERSION}_linux_amd64, vociferate_${RELEASE_VERSION}_linux_arm64, checksums.txt"
|
||||||
echo "- Release binaries are compressed with UPX when available, otherwise uploaded uncompressed."
|
echo "- Release binaries use local UPX when available, otherwise containerized UPX (Docker/Podman), otherwise uncompressed upload."
|
||||||
} >> "$SUMMARY_FILE"
|
} >> "$SUMMARY_FILE"
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user