[ci-skip] Ability to generate Pufferfish upstream changelogs

This commit is contained in:
Encode42
2022-01-25 10:50:14 -05:00
parent 3d176e2a92
commit 6817c5e1af

View File

@@ -2,24 +2,73 @@
# requires curl & jq # requires curl & jq
# upstreamCommit <baseHash> # upstreamCommit --paper HASH --pufferfish HASH
# param: bashHash - the commit hash to use for comparing commits (baseHash...HEAD) # flag: --paper HASH - the commit hash to use for comparing commits between paper (PaperMC/Paper/compare/HASH...HEAD)
# flag: --pufferfish HASH - the commit hash to use for comparing commits between pufferfish (pufferfish-gg/Pufferfish/compare/HASH...HEAD)
function getCommits() {
echo "$(curl -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/"$1"/compare/"$2"...HEAD | jq -r '.commits[] | "'"$1"'r@\(.sha[:7]) \(.commit.message | split("\r\n")[0] | split("\n")[0])"')"
}
( (
set -e set -e
PS1="$" PS1="$"
paper=$(curl -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/PaperMC/Paper/compare/$1...HEAD | jq -r '.commits[] | "PaperMC/Paper@\(.sha[:7]) \(.commit.message | split("\r\n")[0] | split("\n")[0])"') paperHash=""
pufferfishHash=""
TEMP=$(getopt --long paper:,pufferfish: -o "" -- "$@")
eval set -- "$TEMP"
while true; do
case "$1" in
--paper)
paperHash="$2"
shift 2
;;
--pufferfish)
pufferfishHash="$2"
shift 2
;;
*)
break
;;
esac
done
paper=""
pufferfish=""
updated="" updated=""
logsuffix="" logsuffix=""
if [ ! -z "paper" ]; then
logsuffix="$logsuffix\n\nPaper Changes:\n$paper"
updated="Paper"
fi
disclaimer="Upstream has released updates that appear to apply and compile correctly"
log="${UP_LOG_PREFIX}Updated Upstream ($updated)\n\n${disclaimer}${logsuffix}" # Paper updates
if [ -n "$paperHash" ]; then
paper=$(getCommits "PaperMC/Paper" "$paperHash")
# Updates found
if [ -n "$paper" ]; then
updated="Paper"
logsuffix="$logsuffix\n\nPaper Changes:\n$paper"
fi
fi
# Pufferfish updates
if [ -n "$pufferfishHash" ]; then
pufferfish=$(getCommits "pufferfish-gg/Pufferfish" "$pufferfishHash")
# Updates found
if [ -n "$pufferfish" ]; then
updated="Pufferfish"
logsuffix="$logsuffix\n\nPufferfish Changes:\n$pufferfish"
fi
fi
# Both have updates
if [ -n "$paper" ] && [ -n "$pufferfish" ]; then
updated="Paper & Pufferfish"
fi
disclaimer="Upstream has released updates that appear to apply and compile correctly"
log="Updated Upstream ($updated)\n\n${disclaimer}${logsuffix}"
echo -e "$log" | git commit -F - echo -e "$log" | git commit -F -