mirror of
https://github.com/YatopiaMC/Yatopia.git
synced 2024-11-29 06:05:14 +01:00
80 lines
2.4 KiB
Bash
80 lines
2.4 KiB
Bash
|
#!/bin/bash
|
||
|
# get base dir regardless of execution location
|
||
|
SOURCE="${BASH_SOURCE[0]}"
|
||
|
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
||
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
||
|
SOURCE="$(readlink "$SOURCE")"
|
||
|
[[ $SOURCE != /* ]] && SOURCE="$DIR/$SOURCE" # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
|
||
|
done
|
||
|
. $(dirname $SOURCE)/init.sh
|
||
|
PS1="$"
|
||
|
|
||
|
paperVer=$(cat current-paper)
|
||
|
gpgsign="$(git config commit.gpgsign || echo "false")"
|
||
|
|
||
|
echo "Rebuilding Forked projects.... "
|
||
|
function applyPatch {
|
||
|
what=$1
|
||
|
what_name=$(basename $what)
|
||
|
target=$2
|
||
|
branch=$3
|
||
|
patch_folder=$4
|
||
|
|
||
|
cd "$basedir/$what"
|
||
|
git fetch --all
|
||
|
git branch -f upstream "$branch" >/dev/null
|
||
|
|
||
|
cd "$basedir"
|
||
|
if [ ! -d "$basedir/$target" ]; then
|
||
|
mkdir "$basedir/$target"
|
||
|
cd "$basedir/$target"
|
||
|
git init
|
||
|
git remote add origin $5
|
||
|
cd "$basedir"
|
||
|
fi
|
||
|
cd "$basedir/$target"
|
||
|
|
||
|
# Disable GPG signing before AM, slows things down and doesn't play nicely.
|
||
|
# There is also zero rational or logical reason to do so for these sub-repo AMs.
|
||
|
# Calm down kids, it's re-enabled (if needed) immediately after, pass or fail.
|
||
|
git config commit.gpgsign false
|
||
|
|
||
|
echo "Resetting $target to $what_name..."
|
||
|
git remote rm upstream > /dev/null 2>&1
|
||
|
git remote add upstream $basedir/$what >/dev/null 2>&1
|
||
|
(git am --abort ; git rebase --abort) 1>&2 2>/dev/null || true
|
||
|
git checkout master 2>/dev/null
|
||
|
git fetch upstream >/dev/null 2>&1
|
||
|
git reset --hard upstream/upstream
|
||
|
echo " Applying patches to $target..."
|
||
|
statusfile=".git/patch-apply-failed"
|
||
|
rm -f "$statusfile"
|
||
|
git am --abort >/dev/null 2>&1
|
||
|
git am --3way --ignore-whitespace "$basedir/patches/$patch_folder/"*.patch
|
||
|
if [ "$?" != "0" ]; then
|
||
|
echo 1 > "$statusfile"
|
||
|
echo " Something did not apply cleanly to $target."
|
||
|
echo " Please review above details and finish the apply then"
|
||
|
echo " save the changes with rebuildPatches.sh"
|
||
|
exit 1
|
||
|
else
|
||
|
rm -f "$statusfile"
|
||
|
echo " Patches applied cleanly to $target"
|
||
|
fi
|
||
|
}
|
||
|
function enableCommitSigningIfNeeded {
|
||
|
if [[ "$gpgsign" == "true" ]]; then
|
||
|
git config commit.gpgsign true
|
||
|
fi
|
||
|
}
|
||
|
|
||
|
(
|
||
|
(applyPatch Paper/Paper-API ${FORK_NAME}-API HEAD api $API_REPO &&
|
||
|
applyPatch Paper/Paper-Server ${FORK_NAME}-Server HEAD server $SERVER_REPO) || exit 1
|
||
|
enableCommitSigningIfNeeded
|
||
|
) || (
|
||
|
echo "Failed to apply patches"
|
||
|
enableCommitSigningIfNeeded
|
||
|
exit 1
|
||
|
) || exit 1
|