Improve renderer pairing logic in CI configuration

Refactor renderer repository and reference resolution logic in CI workflow.
This commit is contained in:
Life
2026-05-28 17:44:56 +02:00
committed by GitHub
parent 9089aacdf5
commit bbe130e1d4
+28 -48
View File
@@ -72,61 +72,41 @@ jobs:
VAR_REPO: ${{ vars.RENDERER_REPO }} VAR_REPO: ${{ vars.RENDERER_REPO }}
VAR_REF: ${{ vars.RENDERER_REF }} VAR_REF: ${{ vars.RENDERER_REF }}
run: | run: |
REPO="${{ github.event.inputs.renderer_repo }}" # Branch-aware auto pairing — the default when neither a
REF="${{ github.event.inputs.renderer_ref }}" # dispatch input nor a repo variable is supplied.
#
# Everything (including the custom features — rare values,
# fortune wheel, soundboard) now lives on duckietm's own
# `main` / `Dev` branches, so the renderer always pairs
# against UPSTREAM_RENDERER_REPO: `main` when the client build
# context is `main`, otherwise `Dev`. For PRs the context is
# the base ref.
case "${GITHUB_EVENT_NAME}" in
pull_request)
CTX="${GITHUB_BASE_REF}"
;;
*)
CTX="${GITHUB_REF_NAME}"
;;
esac
if [ -z "$REPO" ] || [ -z "$REF" ]; then AUTO_REPO="${UPSTREAM_RENDERER_REPO}"
# For PRs we usually pair against the base ref, but the HK case "$CTX" in
# PR specifically needs to pair against its OWN head ref — main) AUTO_REF="main" ;;
# the renderer companion PR is named identically *) AUTO_REF="Dev" ;;
# (`feat/housekeeping-packets`) and lives on the same fork. esac
case "${GITHUB_EVENT_NAME}" in
pull_request)
if [ "${GITHUB_HEAD_REF}" = "feat/housekeeping-panel" ]; then
CTX="${GITHUB_HEAD_REF}"
else
CTX="${GITHUB_BASE_REF}"
fi
;;
*)
CTX="${GITHUB_REF_NAME}"
;;
esac
case "$CTX" in # Precedence (most specific wins): dispatch input → repo
main) # variable → branch-aware auto default. The auto default is
AUTO_REPO="duckietm/Nitro_Render_V3" # the final fallback so a Dev/feat build never silently pairs
AUTO_REF="main" # against a renderer that's missing its companion exports.
;;
Dev)
# The client `Dev` branch carries the custom features
# (rare values, fortune wheel, soundboard); they live on
# the matching renderer fork branch, not upstream.
AUTO_REPO="medievalshell/Nitro_Render_V3"
AUTO_REF="dev"
;;
feat/housekeeping-panel)
AUTO_REPO="simoleo89/Nitro_Render_V3"
AUTO_REF="feat/housekeeping-packets"
;;
*)
AUTO_REPO="duckietm/Nitro_Render_V3"
AUTO_REF="Dev"
;;
esac
[ -z "$REPO" ] && REPO="$AUTO_REPO"
[ -z "$REF" ] && REF="$AUTO_REF"
fi
# Precedence: dispatch input → repo variable → upstream default.
REPO="$IN_REPO" REPO="$IN_REPO"
[ -z "$REPO" ] && REPO="$VAR_REPO" [ -z "$REPO" ] && REPO="$VAR_REPO"
[ -z "$REPO" ] && REPO="$UPSTREAM_RENDERER_REPO" [ -z "$REPO" ] && REPO="$AUTO_REPO"
REF="$IN_REF" REF="$IN_REF"
[ -z "$REF" ] && REF="$VAR_REF" [ -z "$REF" ] && REF="$VAR_REF"
[ -z "$REF" ] && REF="$DEFAULT_REF" [ -z "$REF" ] && REF="$AUTO_REF"
echo "repo=$REPO" >> "$GITHUB_OUTPUT" echo "repo=$REPO" >> "$GITHUB_OUTPUT"
echo "ref=$REF" >> "$GITHUB_OUTPUT" echo "ref=$REF" >> "$GITHUB_OUTPUT"