Merge with master.
[gitweb.git] / git-reset-script
index fe773388c9d55fdb87967bc04765fa94a83bf2c7..49994df7a2329a87a65588be94088198d208ba1a 100755 (executable)
@@ -1,5 +1,13 @@
 #!/bin/sh
-: ${GIT_DIR=.git}
-git-read-tree --reset HEAD
+. git-sh-setup-script || die "Not a git archive"
+rev=$(git-rev-parse --revs-only --verify --default HEAD "$@") || exit
+rev=$(git-rev-parse --revs-only --verify $rev^0) || exit
+git-read-tree --reset "$rev" && {
+       if orig=$(git-rev-parse --verify HEAD 2>/dev/null)
+       then
+               echo "$orig" >"$GIT_DIR/ORIG_HEAD"
+       fi
+       echo "$rev" > "$GIT_DIR/HEAD"
+}
 git-update-cache --refresh
 rm -f "$GIT_DIR/MERGE_HEAD"