From: Junio C Hamano Date: Tue, 13 Nov 2007 20:28:53 +0000 (-0800) Subject: revert/cherry-pick: allow starting from dirty work tree. X-Git-Tag: v1.5.3.6~15 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=245de36f035f9d549df2b1509787c25648fd611f;p=git.git revert/cherry-pick: allow starting from dirty work tree. There is no reason to forbid a dirty work tree when reverting or cherry-picking a change, as long as the index is clean. The scripted version used to allow it: case "$no_commit" in t) # We do not intend to commit immediately. We just want to # merge the differences in. head=$(git-write-tree) || die "Your index file is unmerged." ;; *) head=$(git-rev-parse --verify HEAD) || die "You do not have a valid HEAD" files=$(git-diff-index --cached --name-only $head) || exit if [ "$files" ]; then die "Dirty index: cannot $me (dirty: $files)" fi ;; esac but C rewrite tightened the check, probably by mistake. Signed-off-by: Junio C Hamano --- diff --git a/builtin-revert.c b/builtin-revert.c index eafafbc33..94e77771d 100644 --- a/builtin-revert.c +++ b/builtin-revert.c @@ -264,7 +264,7 @@ static int revert_or_cherry_pick(int argc, const char **argv) if (get_sha1("HEAD", head)) die ("You do not have a valid HEAD"); wt_status_prepare(&s); - if (s.commitable || s.workdir_dirty) + if (s.commitable) die ("Dirty index: cannot %s", me); discard_cache(); }