diff options
Diffstat (limited to 'misc/merge-grangerhub-into-trem.sh')
-rw-r--r-- | misc/merge-grangerhub-into-trem.sh | 109 |
1 files changed, 109 insertions, 0 deletions
diff --git a/misc/merge-grangerhub-into-trem.sh b/misc/merge-grangerhub-into-trem.sh new file mode 100644 index 0000000..05e4592 --- /dev/null +++ b/misc/merge-grangerhub-into-trem.sh @@ -0,0 +1,109 @@ +#! /bin/bash +# TODO Consider rewrite in perl/python to make this a bit less crappy + +DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" +PATCHES_DIR=${DIR}/patches +LAST_REVISION_FILE=${DIR}/last-merged-grangerhub-revision +LAST_REVISION_TEMP_FILE=${LAST_REVISION_FILE}.temp + +if [ -f ${LAST_REVISION_TEMP_FILE} ] +then + LAST_REVISION=`cat ${LAST_REVISION_TEMP_FILE}` +else + LAST_REVISION=`cat ${LAST_REVISION_FILE}` +fi + +set -f +# Things that exist in ioq3 which we don't want +EXCLUSIONS="BUGS ChangeLog README ./*.txt NOTTODO TODO misc/* Makefile GNUmakefile src/sys/*" + +EXCLUDE_PARAMETERS="" +for EXCLUSION in ${EXCLUSIONS} +do + EXCLUDE_PARAMETERS+="--exclude=${EXCLUSION} " +done + +set +f + +PATCHES=`ls ${PATCHES_DIR}/*.patch 2> /dev/null` +if [ -z "${PATCHES}" ] +then + echo "Fetching and generating patches..." + git fetch git@grangerlab.grangerhub.com:top-secret/tremulous-scribble-3.git rsakey + + mkdir -p ${PATCHES_DIR} + git format-patch -o ${PATCHES_DIR} ${LAST_REVISION}..FETCH_HEAD +fi + +if [ -d ".git/rebase-apply" ] +then + echo "Failed patch detected." + + git diff --quiet --exit-code + if [ "$?" -ne 0 ] + then + echo "Unstaged changes present; git add any that are pending:" + git status + exit 1 + fi + + PATCH=`ls ${PATCHES_DIR}/*.patch | head -n 1` + SHA=`cat ${PATCH} | head -n 1 | awk '{print $2;}'` + echo "Processing ${SHA} ${PATCH}..." + + DIFF=`git diff --cached` + if [ -z "${DIFF}" ] + then + echo "Patch does nothing; skipping." + read -p "Confirm skip? " + git am --skip + else + read -p "Confirm resolve? " + git am --resolved + fi + + if [ "$?" -ne 0 ] + then + echo "Patch failed to apply." + exit $? + fi + + echo ${SHA} > ${LAST_REVISION_TEMP_FILE} + rm ${PATCH} +fi + +PATCHES=`ls ${PATCHES_DIR}/*.patch 2> /dev/null` +if [ -n "${PATCHES}" ] +then + for PATCH in ${PATCHES} + do + SHA=`cat ${PATCH} | head -n 1 | awk '{print $2;}'` + echo "Processing ${SHA} ${PATCH}..." + cat ${PATCH} | git am ${EXCLUDE_PARAMETERS} --quiet --3way + + if [ "$?" -ne 0 ] + then + echo "Patch failed to apply." + git status + exit $? + fi + + echo ${SHA} > ${LAST_REVISION_TEMP_FILE} + rm ${PATCH} + done +else + echo "Nothing to merge." +fi + +# Finished merging so update the last revision marker +if [ -f ${LAST_REVISION_TEMP_FILE} ] +then + diff ${LAST_REVISION_FILE} ${LAST_REVISION_TEMP_FILE} &> /dev/null + if [ "$?" -ne 0 ] + then + mv ${LAST_REVISION_TEMP_FILE} ${LAST_REVISION_FILE} + LAST_REVISION=`cat ${LAST_REVISION_FILE}` + git add ${LAST_REVISION_FILE} + git commit -m "Merged grangerhub ${LAST_REVISION}" + fi +fi |