1#!/bin/bash 2 3if [ $# -ne 1 ]; then 4 echo "Invalid arguments!" 5 echo "$0 <rNNNNNN | git-hash>" 6 exit 1 7fi 8 9if [ -n "$(git status -uno -s --porcelain)" ]; then 10 echo "You have unstashed changes. Please stash and then revert." 11 git status -uno 12 exit 1 13fi 14 15COMMIT=$1 16OTHER=$(git svn find-rev "$COMMIT") 17if [ $? -ne 0 ] || [ "$OTHER" = "" ]; then 18 echo "Error! Could not find an svn/git revision for commit $COMMIT!" 19 echo 20 echo "Possible problems are:" 21 echo " * Your revision number ($COMMIT) is wrong" 22 echo " * This tree is not up to date (before that commit)" 23 echo " * This commit in in another three (llvm, clang, compiler-rt, etc)" 24 exit 1 25fi 26 27if [ -n "$(echo $COMMIT | grep '^r[0-9]\+')" ]; then 28 SVN=`echo $COMMIT | sed -e 's/^r//'` 29 GIT=$OTHER 30else 31 SVN=$OTHER 32 GIT=$COMMIT 33fi 34 35# Grab the one line message for our revert commit message. 36ONE_LINE_MSG=$(git log --oneline $GIT -1 | cut -f2- -d " ") 37 38# Revert the commit. 39git revert --no-commit $GIT 2>/dev/null 40if [ $? -ne 0 ]; then 41 echo "Error! Failed to revert commit r$SVN. Resetting to head." 42 git reset --hard HEAD 43 exit 1 44fi 45 46# Create a template in our .git directory. 47TEMPLATE="`git rev-parse --git-dir`/git-svn-revert-template" 48cat > $TEMPLATE <<EOF 49Revert "$ONE_LINE_MSG" 50 51This reverts commit r$SVN. 52EOF 53 54# Begin the commit but give our user an opportunity to edit it. 55git commit --file="$TEMPLATE" --edit 56if [ $? -ne 0 ]; then 57 echo "Error! Failed to commit reverting commit for commit r$SVN. Reverting to head." 58 git reset --hard HEAD 59 rm -rf $TEMPLATE 60 exit 1 61fi 62 63rm -rf $TEMPLATE 64 65