Merge branch 'mz/reset-misc'
commit772f8113988a8ad3a38323c70ecbad1034e9e699
authorJunio C Hamano <gitster@pobox.com>
Tue, 22 Jan 2013 17:36:13 +0000 (22 09:36 -0800)
committerJunio C Hamano <gitster@pobox.com>
Tue, 22 Jan 2013 17:36:41 +0000 (22 09:36 -0800)
tree30fe4769c84dc916ca97b4433e2b443320cd4f4e
parent9a9f243f6426056058c7c29999c27a086f94e035
parentbf44142f5464e913d99f9544787e59fc630f6cc9
Merge branch 'mz/reset-misc'

Various 'reset' optimizations and clean-ups, followed by a change
to allow "git reset" to work even on an unborn branch.

* mz/reset-misc:
  reset: update documentation to require only tree-ish with paths
  reset [--mixed]: use diff-based reset whether or not pathspec was given
  reset: allow reset on unborn branch
  reset $sha1 $pathspec: require $sha1 only to be treeish
  reset.c: inline update_index_refresh()
  reset.c: finish entire cmd_reset() whether or not pathspec is given
  reset [--mixed]: only write index file once
  reset.c: move lock, write and commit out of update_index_refresh()
  reset.c: move update_index_refresh() call out of read_from_tree()
  reset.c: replace switch by if-else
  reset: avoid redundant error message
  reset --keep: only write index file once
  reset.c: share call to die_if_unmerged_cache()
  reset.c: extract function for updating {ORIG_,}HEAD
  reset.c: remove unnecessary variable 'i'
  reset.c: extract function for parsing arguments
  reset: don't allow "git reset -- $pathspec" in bare repo
  reset.c: pass pathspec around instead of (prefix, argv) pair
  reset $pathspec: exit with code 0 if successful
  reset $pathspec: no need to discard index