Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
checkout: make reset_clean_to_new() not die by itself
author
Junio C Hamano
<gitster@pobox.com>
Wed, 28 May 2008 21:54:02 +0000
(14:54 -0700)
committer
Junio C Hamano
<gitster@pobox.com>
Thu, 29 May 2008 00:38:21 +0000
(17:38 -0700)
Instead, have its error percolate up through the callchain and let it be
the exit status of the main command. No semantic changes yet.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin-checkout.c
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
d2b3691
)
diff --git
a/builtin-checkout.c
b/builtin-checkout.c
index 00dc8cafd827aaffeb9f9e1b8cc7addb7fffaa8d..cc97724c87aeb975f8b6e87bc891e98f678f11ee 100644
(file)
--- a/
builtin-checkout.c
+++ b/
builtin-checkout.c
@@
-172,7
+172,7
@@
static int reset_to_new(struct tree *tree, int quiet)
return 0;
}
return 0;
}
-static
void
reset_clean_to_new(struct tree *tree, int quiet)
+static
int
reset_clean_to_new(struct tree *tree, int quiet)
{
struct unpack_trees_options opts;
struct tree_desc tree_desc;
{
struct unpack_trees_options opts;
struct tree_desc tree_desc;
@@
-189,7
+189,8
@@
static void reset_clean_to_new(struct tree *tree, int quiet)
parse_tree(tree);
init_tree_desc(&tree_desc, tree->buffer, tree->size);
if (unpack_trees(1, &tree_desc, &opts))
parse_tree(tree);
init_tree_desc(&tree_desc, tree->buffer, tree->size);
if (unpack_trees(1, &tree_desc, &opts))
- exit(128);
+ return 128;
+ return 0;
}
struct checkout_opts {
}
struct checkout_opts {
@@
-295,7
+296,9
@@
static int merge_working_tree(struct checkout_opts *opts,
return ret;
merge_trees(new->commit->tree, work, old->commit->tree,
new->name, "local", &result);
return ret;
merge_trees(new->commit->tree, work, old->commit->tree,
new->name, "local", &result);
- reset_clean_to_new(new->commit->tree, opts->quiet);
+ ret = reset_clean_to_new(new->commit->tree, opts->quiet);
+ if (ret)
+ return ret;
}
}
}
}