On Mon, Dec 12, 2016 at 09:34:13PM +1300, Chris Packham wrote: > Teach 'git merge' the --continue option which allows 'continuing' a > merge by completing it. The traditional way of completing a merge after > resolving conflicts is to use 'git commit'. Now with commands like 'git > rebase' and 'git cherry-pick' having a '--continue' option adding such > an option to 'git merge' presents a consistent UI. > > Signed-off-by: Chris Packham <judge.packham@xxxxxxxxx> > --- > So here is a quick patch that adds the --continue option. I need to add > some tests (suggestions for where to start are welcome). I'm not sure if there's much to test besides concluding a successful merge, and possibly some error cases where --continue should complain. Probably that could go at the end of t7600. > @@ -1166,6 +1169,18 @@ int cmd_merge(int argc, const char **argv, const char *prefix) > goto done; > } > > + if (continue_current_merge) { > + int nargc = 1; > + const char *nargv[] = {"commit", NULL}; > + > + if (!file_exists(git_path_merge_head())) > + die(_("There is no merge in progress (MERGE_HEAD missing).")); > + > + /* Invoke 'git commit' */ > + ret = cmd_commit(nargc, nargv, prefix); > + goto done; > + } > + I know this block is just adapted from the "--abort" one above, but should both of these complain when other arguments are given? I can't imagine what the user might mean with "git merge --no-commit --continue", but probably it should be an error. :) -Peff