Add sexier applyPatches and rebuildPatches scripts

This commit is contained in:
Byteflux 2016-01-04 00:39:30 -06:00
parent 7f92ef8437
commit 8dfa4f8e54
2 changed files with 18 additions and 32 deletions

View file

@ -10,23 +10,21 @@ function applyPatch {
branch=$3 branch=$3
cd "$basedir/$what" cd "$basedir/$what"
git fetch git fetch
git reset --hard "$branch" git branch -f upstream "$branch" >/dev/null
git branch -f upstream >/dev/null
cd "$basedir" cd "$basedir"
if [ ! -d "$basedir/$target" ]; then if [ ! -d "$basedir/$target" ]; then
git clone $1 $target -b upstream git clone "$what" "$target"
fi fi
cd "$basedir/$target" cd "$basedir/$target"
echo "Resetting $target to $what..." echo "Resetting $target to $what..."
git remote rm upstream 2>/dev/null 2>&1 git remote add -f upstream ../$what >/dev/null 2>&1
git remote add upstream ../$what >/dev/null 2>&1
git checkout master >/dev/null 2>&1 git checkout master >/dev/null 2>&1
git fetch upstream >/dev/null 2>&1 git fetch upstream >/dev/null 2>&1
git reset --hard upstream/upstream git reset --hard upstream/upstream
echo " Applying patches to $target..." echo " Applying patches to $target..."
git am --abort git am --abort >/dev/null 2>&1
git am --3way "$basedir/${what}-Patches/"*.patch git am --3way --ignore-whitespace "$basedir/${what}-Patches/"*.patch
if [ "$?" != "0" ]; then if [ "$?" != "0" ]; then
echo " Something did not apply cleanly to $target." echo " Something did not apply cleanly to $target."
echo " Please review above details and finish the apply then" echo " Please review above details and finish the apply then"
@ -37,14 +35,5 @@ function applyPatch {
fi fi
} }
echo applyPatch Bukkit Spigot-API HEAD && applyPatch CraftBukkit Spigot-Server patched
echo "Applying SpigotMC patches to CraftBukkit and Bukkit" applyPatch Spigot-API PaperSpigot-API HEAD && applyPatch Spigot-Server PaperSpigot-Server HEAD
echo
cd ../Bukkit
hash=$(git rev-parse HEAD)
git branch -f spigot "$hash"
applyPatch Bukkit Spigot-API origin/spigot && applyPatch CraftBukkit Spigot-Server origin/patched
echo
echo "Applying PaperSpigot patches to Spigot-Server and Spigot-API"
echo
applyPatch Spigot-API PaperSpigot-API && applyPatch Spigot-Server PaperSpigot-Server

View file

@ -3,23 +3,19 @@
PS1="$" PS1="$"
basedir=`pwd` basedir=`pwd`
echo "Rebuilding patch files from current fork state..." echo "Rebuilding patch files from current fork state..."
git config core.safecrlf false
function cleanupPatches { function cleanupPatches {
cd "$1" cd "$1"
for patch in *.patch; do for patch in *.patch; do
echo "$patch"
gitver=$(tail -n 2 $patch | grep -ve "^$" | tail -n 1) gitver=$(tail -n 2 $patch | grep -ve "^$" | tail -n 1)
diffs=$(git diff --staged $patch | grep -E "^(\+|\-)" | grep -Ev "(From [a-z0-9]{32,}|\-\-\- a|\+\+\+ b|.index)") diffs=$(git diff --staged $patch | grep -E "^(\+|\-)" | grep -Ev "(From [a-z0-9]{32,}|\-\-\- a|\+\+\+ b|Date\: |.index)")
testver=$(echo "$diffs" | tail -n 2 | grep -ve "^$" | tail -n 1 | grep "$gitver") testver=$(echo "$diffs" | tail -n 2 | grep -ve "^$" | tail -n 1 | grep "$gitver")
if [ "x$testver" != "x" ]; then if [ "x$testver" != "x" ]; then
mingw=$(uname -s | grep "MINGW") diffs=$(echo "$diffs" | sed 'N;$!P;$!D;$d')
if [ "x$mingw" != "x" ]; then
diffs=$(echo "$diffs" | head -n $(($(echo "$diffs" | wc -l | sed -r 's/^ +//' | cut -d ' ' -f 1) - 2)))
else
diffs=$(echo "$diffs" | head -n -2)
fi fi
fi
if [ "x$diffs" == "x" ] ; then if [ "x$diffs" == "x" ] ; then
git reset HEAD $patch >/dev/null git reset HEAD $patch >/dev/null
@ -31,15 +27,16 @@ function cleanupPatches {
function savePatches { function savePatches {
what=$1 what=$1
target=$2 target=$2
echo "Formatting patches for $what..."
cd "$basedir/$target" cd "$basedir/$target"
git format-patch --no-stat -N -o "$basedir/${what}-Patches/" upstream/upstream git format-patch --no-stat -N -o "$basedir/${what}-Patches/" upstream/upstream >/dev/null
cd "$basedir" cd "$basedir"
git add "$basedir/${what}-Patches" git add -A "$basedir/${what}-Patches"
cleanupPatches "$basedir/${what}-Patches" cleanupPatches "$basedir/${what}-Patches"
echo " Patches saved for $what to $what-Patches/" echo " Patches saved for $what to $what-Patches/"
} }
if [ "$1" == "clean" ]; then
#savePatches Bukkit Spigot-API rm -rf Spigot-*-Patches
#savePatches CraftBukkit Spigot-Server fi
savePatches Spigot-API PaperSpigot-API savePatches Spigot-API PaperSpigot-API
savePatches Spigot-Server PaperSpigot-Server savePatches Spigot-Server PaperSpigot-Server