2013-01-15 01:18:40 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2013-01-21 09:24:30 +00:00
|
|
|
basedir=`pwd`
|
2013-01-15 01:18:40 +00:00
|
|
|
echo "Rebuilding patch files from current fork state..."
|
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
|
2013-01-22 02:46:26 +00:00
|
|
|
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)")
|
|
|
|
|
|
|
|
testver=$(echo "$diffs" | tail -n 2 | grep -ve "^$" | tail -n 1 | grep "$gitver")
|
|
|
|
if [ "x$testver" != "x" ]; then
|
|
|
|
diffs=$(echo "$diffs" | head -n -2)
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if [ "x$diffs" == "x" ] ; then
|
2013-01-16 17:08:09 +00:00
|
|
|
git reset HEAD $patch >/dev/null
|
|
|
|
git checkout -- $patch >/dev/null
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
2013-01-15 01:18:40 +00:00
|
|
|
function savePatches {
|
|
|
|
what=$1
|
|
|
|
target=$2
|
2013-11-06 00:26:20 +00:00
|
|
|
cd "$basedir/$target"
|
|
|
|
git format-patch --no-stat -N -o "$basedir/${what}-Patches/" upstream/upstream
|
|
|
|
cd "$basedir"
|
|
|
|
git add "$basedir/${what}-Patches"
|
|
|
|
cleanupPatches "$basedir/${what}-Patches"
|
2013-01-15 01:18:40 +00:00
|
|
|
echo " Patches saved for $what to $what-Patches/"
|
|
|
|
}
|
|
|
|
|
|
|
|
savePatches Bukkit Spigot-API
|
2013-03-07 06:45:12 +00:00
|
|
|
savePatches CraftBukkit Spigot-Server
|