diff options
author | Junio C Hamano <junkio@cox.net> | 2005-10-03 21:44:48 +0200 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2005-10-05 02:04:44 +0200 |
commit | 4b12dae69a41471e7c8139de26c1135f7ecccbd8 (patch) | |
tree | 8843ecb5e7d40236047b1364ffbd65233f666769 /checkout-index.c | |
parent | Merge branch 'fixes' (diff) | |
download | git-4b12dae69a41471e7c8139de26c1135f7ecccbd8.tar.xz git-4b12dae69a41471e7c8139de26c1135f7ecccbd8.zip |
Return error when not checking out an entry due to dirtiness.
Without -f flag, 'git-checkout-index foo.c' issued an error message
when foo.c already existed in the working tree and did not match index.
However it did not return an error from the underlying checkout_entry()
function and resulted in a successful exit(0).
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'checkout-index.c')
-rw-r--r-- | checkout-index.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/checkout-index.c b/checkout-index.c index f32513c507..97845324be 100644 --- a/checkout-index.c +++ b/checkout-index.c @@ -63,15 +63,20 @@ static int checkout_file(const char *name) static int checkout_all(void) { - int i; + int i, errs = 0; for (i = 0; i < active_nr ; i++) { struct cache_entry *ce = active_cache[i]; if (ce_stage(ce)) continue; if (checkout_entry(ce, &state) < 0) - return -1; + errs++; } + if (errs) + /* we have already done our error reporting. + * exit with the same code as die(). + */ + exit(128); return 0; } |