2016-04-02 03:55:54 +00:00
|
|
|
#!/usr/bin/env bash
|
2013-01-15 01:18:40 +00:00
|
|
|
|
2016-04-03 07:23:19 +00:00
|
|
|
(
|
2014-04-14 11:01:27 +00:00
|
|
|
PS1="$"
|
2016-04-03 08:35:51 +00:00
|
|
|
basedir="$(cd "$1" && pwd -P)"
|
2016-04-02 03:55:54 +00:00
|
|
|
workdir="$basedir/work"
|
2018-08-12 15:54:35 +00:00
|
|
|
source "$basedir/scripts/functions.sh"
|
2018-05-24 18:41:50 +00:00
|
|
|
gitcmd="git -c commit.gpgsign=false -c core.safecrlf=false"
|
|
|
|
|
2013-01-15 01:18:40 +00:00
|
|
|
echo "Rebuilding patch files from current fork state..."
|
2019-04-03 03:20:10 +00:00
|
|
|
nofilter="0"
|
2020-06-25 01:10:30 +00:00
|
|
|
if [ "$2" == "nofilter" ] || [ "$2" == "noclean" ]; then
|
2019-04-03 03:20:10 +00:00
|
|
|
nofilter="1"
|
|
|
|
fi
|
2013-01-16 17:08:09 +00:00
|
|
|
function cleanupPatches {
|
2013-11-06 00:26:20 +00:00
|
|
|
cd "$1"
|
2013-01-16 17:08:09 +00:00
|
|
|
for patch in *.patch; do
|
2018-10-27 03:58:58 +00:00
|
|
|
echo "$patch"
|
2020-05-06 09:31:08 +00:00
|
|
|
diffs=$($gitcmd diff --staged "$patch" | grep --color=none -E "^(\+|\-)" | grep --color=none -Ev "(\-\-\- a|\+\+\+ b|^.index)")
|
2013-01-22 02:46:26 +00:00
|
|
|
|
|
|
|
if [ "x$diffs" == "x" ] ; then
|
2018-05-24 18:41:50 +00:00
|
|
|
$gitcmd reset HEAD "$patch" >/dev/null
|
|
|
|
$gitcmd checkout -- "$patch" >/dev/null
|
2013-01-16 17:08:09 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
2014-04-14 11:01:27 +00:00
|
|
|
|
2013-01-15 01:18:40 +00:00
|
|
|
function savePatches {
|
|
|
|
what=$1
|
2016-04-02 03:55:54 +00:00
|
|
|
what_name=$(basename "$what")
|
2013-01-15 01:18:40 +00:00
|
|
|
target=$2
|
2016-02-29 23:09:49 +00:00
|
|
|
echo "Formatting patches for $what..."
|
2016-03-22 01:40:18 +00:00
|
|
|
|
|
|
|
cd "$basedir/${what_name}-Patches/"
|
2016-05-12 02:07:46 +00:00
|
|
|
if [ -d "$basedir/$target/.git/rebase-apply" ]; then
|
|
|
|
# in middle of a rebase, be smarter
|
|
|
|
echo "REBASE DETECTED - PARTIAL SAVE"
|
|
|
|
last=$(cat "$basedir/$target/.git/rebase-apply/last")
|
|
|
|
next=$(cat "$basedir/$target/.git/rebase-apply/next")
|
2018-07-15 01:53:17 +00:00
|
|
|
orderedfiles=$(find . -name "*.patch" | sort)
|
2016-05-13 01:37:14 +00:00
|
|
|
for i in $(seq -f "%04g" 1 1 $last)
|
2016-05-12 02:07:46 +00:00
|
|
|
do
|
|
|
|
if [ $i -lt $next ]; then
|
2018-07-15 01:53:17 +00:00
|
|
|
rm $(echo "$orderedfiles{@}" | sed -n "${i}p")
|
2016-05-12 02:07:46 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
else
|
|
|
|
rm -rf *.patch
|
|
|
|
fi
|
2016-03-22 01:40:18 +00:00
|
|
|
|
2013-11-06 00:26:20 +00:00
|
|
|
cd "$basedir/$target"
|
2016-03-22 00:46:54 +00:00
|
|
|
|
2020-05-06 09:31:08 +00:00
|
|
|
$gitcmd format-patch --zero-commit --full-index --no-signature --no-stat -N -o "$basedir/${what_name}-Patches/" upstream/upstream >/dev/null
|
2013-11-06 00:26:20 +00:00
|
|
|
cd "$basedir"
|
2018-05-24 18:41:50 +00:00
|
|
|
$gitcmd add -A "$basedir/${what_name}-Patches"
|
2019-04-03 03:20:10 +00:00
|
|
|
if [ "$nofilter" == "0" ]; then
|
|
|
|
cleanupPatches "$basedir/${what_name}-Patches"
|
|
|
|
fi
|
2016-03-21 17:22:47 +00:00
|
|
|
echo " Patches saved for $what to $what_name-Patches/"
|
2013-01-15 01:18:40 +00:00
|
|
|
}
|
2016-03-19 04:11:14 +00:00
|
|
|
|
2016-04-02 03:55:54 +00:00
|
|
|
savePatches "$workdir/Spigot/Spigot-API" "Paper-API"
|
2018-08-12 15:54:35 +00:00
|
|
|
if [ -f "$basedir/Paper-API/.git/patch-apply-failed" ]; then
|
|
|
|
echo "$(color 1 31)[[[ WARNING ]]] $(color 1 33)- Not saving Paper-Server as it appears Paper-API did not apply clean.$(colorend)"
|
|
|
|
echo "$(color 1 33)If this is a mistake, delete $(color 1 34)Paper-API/.git/patch-apply-failed$(color 1 33) and run rebuild again.$(colorend)"
|
|
|
|
echo "$(color 1 33)Otherwise, rerun ./paper patch to have a clean Paper-API apply so the latest Paper-Server can build.$(colorend)"
|
|
|
|
else
|
|
|
|
savePatches "$workdir/Spigot/Spigot-Server" "Paper-Server"
|
|
|
|
fi
|
2018-07-30 21:37:24 +00:00
|
|
|
) || exit 1
|