The function demanded an internal structure "struct checkout_opts" as its argument, but we'd want to split this (and one of its callers) out into a separate library. This makes what the function wants a bit more explicit and much less dependent on the rest of builtin-checkout.c Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> --- builtin-checkout.c | 15 +++++++++------ 1 files changed, 9 insertions(+), 6 deletions(-) diff --git a/builtin-checkout.c b/builtin-checkout.c index c2c0561..d88fce2 100644 --- a/builtin-checkout.c +++ b/builtin-checkout.c @@ -319,7 +319,7 @@ static void describe_detached_head(char *msg, struct commit *commit) strbuf_release(&sb); } -static int reset_tree(struct tree *tree, struct checkout_opts *o, int worktree) +static int reset_tree(struct tree *tree, int quiet, int worktree, int *wt_error) { struct unpack_trees_options opts; struct tree_desc tree_desc; @@ -331,14 +331,14 @@ static int reset_tree(struct tree *tree, struct checkout_opts *o, int worktree) opts.reset = 1; opts.merge = 1; opts.fn = oneway_merge; - opts.verbose_update = !o->quiet; + opts.verbose_update = !quiet; opts.src_index = &the_index; opts.dst_index = &the_index; parse_tree(tree); init_tree_desc(&tree_desc, tree->buffer, tree->size); switch (unpack_trees(1, &tree_desc, &opts)) { case -2: - o->writeout_error = 1; + *wt_error = 1; /* * We return 0 nevertheless, as the index is all right * and more importantly we have made best efforts to @@ -377,7 +377,8 @@ static int merge_working_tree(struct checkout_opts *opts, return error("corrupt index file"); if (opts->force) { - ret = reset_tree(new->commit->tree, opts, 1); + ret = reset_tree(new->commit->tree, opts->quiet, 1, + &opts->writeout_error); if (ret) return ret; } else { @@ -446,14 +447,16 @@ static int merge_working_tree(struct checkout_opts *opts, o.verbosity = 0; work = write_tree_from_memory(&o); - ret = reset_tree(new->commit->tree, opts, 1); + ret = reset_tree(new->commit->tree, opts->quiet, 1, + &opts->writeout_error); if (ret) return ret; o.branch1 = new->name; o.branch2 = "local"; merge_trees(&o, new->commit->tree, work, old->commit->tree, &result); - ret = reset_tree(new->commit->tree, opts, 0); + ret = reset_tree(new->commit->tree, opts->quiet, 0, + &opts->writeout_error); if (ret) return ret; } -- 1.6.1.rc1.72.ga5ce6 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html