reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
    1
    2
    3
    4
    5
    6
    7
    8
    9
   10
   11
   12
   13
   14
   15
   16
   17
   18
   19
   20
   21
   22
   23
   24
   25
   26
   27
   28
   29
   30
   31
   32
   33
   34
   35
   36
   37
   38
   39
   40
   41
   42
   43
   44
   45
   46
   47
   48
   49
   50
   51
   52
   53
   54
   55
   56
   57
   58
   59
   60
   61
   62
   63
   64
#!/bin/bash

if [ $# -ne 1 ]; then
    echo "Invalid arguments!"
    echo "$0 <rNNNNNN | git-hash>"
    exit 1
fi

if [ -n "$(git status -uno -s --porcelain)" ]; then
    echo "You have unstashed changes. Please stash and then revert."
    git status -uno
    exit 1
fi

COMMIT=$1
OTHER=$(git svn find-rev "$COMMIT")
if [ $? -ne 0 ] || [ "$OTHER" = "" ]; then
    echo "Error! Could not find an svn/git revision for commit $COMMIT!"
    echo
    echo "Possible problems are:"
    echo "  * Your revision number ($COMMIT) is wrong"
    echo "  * This tree is not up to date (before that commit)"
    echo "  * This commit in in another three (llvm, clang, compiler-rt, etc)"
    exit 1
fi

if [ -n "$(echo $COMMIT | grep '^r[0-9]\+')" ]; then
  SVN=`echo $COMMIT | sed -e 's/^r//'`
  GIT=$OTHER
else
  SVN=$OTHER
  GIT=$COMMIT
fi

# Grab the one line message for our revert commit message.
ONE_LINE_MSG=$(git log --oneline $GIT -1 | cut -f2- -d " ")

# Revert the commit.
git revert --no-commit $GIT 2>/dev/null
if [ $? -ne 0 ]; then
    echo "Error! Failed to revert commit r$SVN. Resetting to head."
    git reset --hard HEAD
    exit 1
fi

# Create a template in our .git directory.
TEMPLATE="`git rev-parse --git-dir`/git-svn-revert-template"
cat > $TEMPLATE <<EOF
Revert "$ONE_LINE_MSG"

This reverts commit r$SVN.
EOF

# Begin the commit but give our user an opportunity to edit it.
git commit --file="$TEMPLATE" --edit
if [ $? -ne 0 ]; then
    echo "Error! Failed to commit reverting commit for commit r$SVN. Reverting to head."
    git reset --hard HEAD
    rm -rf $TEMPLATE
    exit 1
fi

rm -rf $TEMPLATE