]> git.ipfire.org Git - thirdparty/git.git/commitdiff
Merge branch 'js/stash'
authorJunio C Hamano <gitster@pobox.com>
Sat, 7 Jul 2007 20:38:06 +0000 (13:38 -0700)
committerJunio C Hamano <gitster@pobox.com>
Sat, 7 Jul 2007 20:38:06 +0000 (13:38 -0700)
* js/stash:
  Teach git-stash to "apply --index"

1  2 
git-stash.sh

diff --combined git-stash.sh
index 7b1638c68c796aee4a108263dc45b650f7bc987c,5c63ca5bce1180a6a6182a73ec5a75b7580580ab..eac5551380539e629c07e3f6afece9b5e2d16c0a
@@@ -3,7 -3,6 +3,7 @@@
  
  USAGE='[ | list | show | apply | clear]'
  
 +SUBDIRECTORY_OK=Yes
  . git-sh-setup
  require_work_tree
  
@@@ -112,6 -111,13 +112,13 @@@ apply_stash () 
        git diff-files --quiet ||
                die 'Cannot restore on top of a dirty state'
  
+       unstash_index=
+       case "$1" in
+       --index)
+               unstash_index=t
+               shift
+       esac
        # current index state
        c_tree=$(git write-tree) ||
                die 'Cannot apply a stash in the middle of a merge'
        b_tree=$(git rev-parse --verify "$s^:") ||
                die "$*: no valid stashed state found"
  
+       test -z "$unstash_index" || {
+               git diff --binary $s^2^..$s^2 | git apply --cached
+               test $? -ne 0 &&
+                       die 'Conflicts in index. Try without --index.'
+               unstashed_index_tree=$(git-write-tree) ||
+                       die 'Could not save index tree'
+               git reset
+       }
        eval "
                GITHEAD_$w_tree='Stashed changes' &&
                GITHEAD_$c_tree='Updated upstream' &&
                        die "Cannot unstage modified files"
                git-status
                rm -f "$a"
+               test -z "$unstash_index" || git read-tree $unstashed_index_tree
        else
                # Merge conflict; keep the exit status from merge-recursive
-               exit
+               status=$?
+               test -z "$unstash_index" || echo 'Index was not unstashed.' >&2
+               exit $status
        fi
  }