2016-04-02 11:55:54 +08:00
|
|
|
#!/usr/bin/env bash
|
2016-01-26 14:04:43 +08:00
|
|
|
|
2016-04-03 15:23:19 +08:00
|
|
|
(
|
|
|
|
set -e
|
2016-01-26 14:04:43 +08:00
|
|
|
PS1="$"
|
2016-04-03 16:35:51 +08:00
|
|
|
basedir="$(cd "$1" && pwd -P)"
|
2016-04-02 11:55:54 +08:00
|
|
|
workdir="$basedir/work"
|
2018-05-25 02:41:50 +08:00
|
|
|
gitcmd="git -c commit.gpgsign=false"
|
2016-01-26 14:04:43 +08:00
|
|
|
|
2019-04-03 11:20:10 +08:00
|
|
|
updated="0"
|
|
|
|
function getRef {
|
|
|
|
git ls-tree $1 $2 | cut -d' ' -f3 | cut -f1
|
|
|
|
}
|
2016-01-26 14:04:43 +08:00
|
|
|
function update {
|
2016-04-02 11:55:54 +08:00
|
|
|
cd "$workdir/$1"
|
2019-04-03 09:46:32 +08:00
|
|
|
$gitcmd fetch && $gitcmd clean -fd && $gitcmd reset --hard origin/master
|
2019-04-03 11:20:10 +08:00
|
|
|
refRemote=$(git rev-parse HEAD)
|
2016-01-26 14:04:43 +08:00
|
|
|
cd ../
|
2021-04-05 19:14:54 +08:00
|
|
|
$gitcmd add --force $1
|
2019-04-03 11:20:10 +08:00
|
|
|
refHEAD=$(getRef HEAD "$workdir/$1")
|
|
|
|
echo "$1 $refHEAD - $refRemote"
|
|
|
|
if [ "$refHEAD" != "$refRemote" ]; then
|
|
|
|
export updated="1"
|
|
|
|
fi
|
2016-01-26 14:04:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
update Bukkit
|
|
|
|
update CraftBukkit
|
2016-03-22 01:32:05 +08:00
|
|
|
update Spigot
|
2016-08-20 05:00:59 +08:00
|
|
|
|
2017-05-21 12:41:39 +08:00
|
|
|
if [[ "$2" = "all" || "$2" = "a" ]] ; then
|
2016-08-20 05:00:59 +08:00
|
|
|
update BuildData
|
|
|
|
fi
|
2019-04-03 11:20:10 +08:00
|
|
|
if [ "$updated" == "1" ]; then
|
|
|
|
echo "Rebuilding patches without filtering to improve apply ability"
|
|
|
|
cd "$basedir"
|
2021-06-15 16:38:41 +08:00
|
|
|
./gradlew cleanCache || exit 1 # todo: Figure out why this is necessary
|
2021-06-15 14:42:57 +08:00
|
|
|
./gradlew applyPatches -Dpaperweight.debug=true || exit 1
|
|
|
|
./gradlew rebuildPatches || exit 1
|
2019-04-03 11:20:10 +08:00
|
|
|
fi
|
2016-04-03 15:23:19 +08:00
|
|
|
)
|