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