f3021c4ddb
release / release (push) Successful in 14s
- feat(ci): set each Gitea release body from the matching CHANGELOG section (was hardcoded "Automated release for…") - feat(updater): show "What's new" — release notes dialog before applying (GUI) and in `rigdoctor update` (CLI); fetch_latest/update_state now return notes - feat(gui): "Restart now" button relaunches the app after an update is applied - fix(packaging): build the self-extracting .run with a pure-Python extractor (packaging/make_run.py) instead of makeself, so it attaches to every release (it was silently skipped before) - chore: adopt Conventional Commits + git-cliff (cliff.toml, packaging/ changelog.sh) for changelog generation going forward (D20) - chore(gui): drop internal module refs (M4, M5, …) from Setup descriptions Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
93 lines
3.1 KiB
YAML
93 lines
3.1 KiB
YAML
name: release
|
|
run-name: Release on push to main
|
|
|
|
# Builds a wheel + sdist and publishes a Gitea release v<version> on every push to
|
|
# main. The version comes from pyproject.toml (kept in lockstep with __version__, D19);
|
|
# if a release for that tag already exists, the job is a no-op — so bump the version
|
|
# (and CHANGELOG) to cut a new release.
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
|
|
jobs:
|
|
release:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v5
|
|
with:
|
|
python-version: "3.12"
|
|
|
|
- name: Build wheel + sdist
|
|
run: |
|
|
python -m pip install --upgrade build
|
|
python -m build
|
|
|
|
- name: Build self-extracting installer (.run)
|
|
run: python packaging/make_run.py
|
|
|
|
- name: Read version
|
|
id: ver
|
|
run: |
|
|
V=$(python -c "import tomllib; print(tomllib.load(open('pyproject.toml','rb'))['project']['version'])")
|
|
echo "version=$V" >> "$GITHUB_OUTPUT"
|
|
|
|
- name: Build release notes
|
|
run: |
|
|
python - <<'PY'
|
|
import json
|
|
version = "${{ steps.ver.outputs.version }}"
|
|
tag = f"v{version}"
|
|
out, capturing = [], False
|
|
try:
|
|
for line in open("CHANGELOG.md", encoding="utf-8").read().splitlines():
|
|
if line.startswith("## "):
|
|
if capturing:
|
|
break
|
|
capturing = line.startswith(f"## [{version}]")
|
|
continue
|
|
if capturing:
|
|
out.append(line)
|
|
except OSError:
|
|
pass
|
|
body = "\n".join(out).strip() or f"Release {tag}."
|
|
payload = {"tag_name": tag, "target_commitish": "${{ github.sha }}", "name": tag, "body": body}
|
|
open("/tmp/release.json", "w", encoding="utf-8").write(json.dumps(payload))
|
|
print(f"release notes: {len(body)} chars")
|
|
PY
|
|
|
|
- name: Publish Gitea release
|
|
env:
|
|
TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
run: |
|
|
set -euo pipefail
|
|
API="${{ github.server_url }}/api/v1/repos/${{ github.repository }}"
|
|
TAG="v${{ steps.ver.outputs.version }}"
|
|
|
|
code=$(curl -sS -o /tmp/existing.json -w '%{http_code}' \
|
|
-H "Authorization: token ${TOKEN}" "${API}/releases/tags/${TAG}")
|
|
if [ "$code" = "200" ]; then
|
|
echo "Release ${TAG} already exists — nothing to do."
|
|
exit 0
|
|
fi
|
|
|
|
echo "Creating release ${TAG}…"
|
|
rid=$(curl -sS -X POST \
|
|
-H "Authorization: token ${TOKEN}" \
|
|
-H "Content-Type: application/json" \
|
|
-d @/tmp/release.json \
|
|
"${API}/releases" | python -c "import sys, json; print(json.load(sys.stdin)['id'])")
|
|
|
|
for f in dist/*; do
|
|
echo "Uploading $(basename "$f")…"
|
|
curl -sS -X POST \
|
|
-H "Authorization: token ${TOKEN}" \
|
|
-F "attachment=@${f}" \
|
|
"${API}/releases/${rid}/assets?name=$(basename "$f")" >/dev/null
|
|
done
|
|
echo "Published ${TAG}."
|