From: Phillip Wood <phillip.wood@xxxxxxxxxxxxx> Cleanup the handling of --strategy-option now that we no longer need to support "--preserve-merges" and properly quote the argument when saving it to disc. Thanks to Elijah for his comments on V1. Changes since V1: I've rebased these patches onto 'master' to avoid conflicts with 'sg/parse-options-h-initializers' in the new patch 2 (this series depends on 'ab/fix-strategy-opts-parsing' but that has now been merged to master). Patch 1 - Unchanged. Patch 2 - New patch to store the merge strategy options in an "struct strvec". This patch also introduces a new macro OPT_STRVEC() to collect options into an "struct strvec". Patch 3 - Small simplification due to the changes in patch 2. Patch 4 - Moved the code to quote a list so it can split by split_cmdline() into a new function quote_cmdline() as suggested by Elijah. Patch 5 - Reworded the commit message as suggested by Elijah. Base-Commit: 140b9478dad5d19543c1cb4fd293ccec228f1240 Published-As: https://github.com/phillipwood/git/releases/tag/sequencer-merge-strategy-options%2Fv2 View-Changes-At: https://github.com/phillipwood/git/compare/140b9478d...3515c31b4 Fetch-It-Via: git fetch https://github.com/phillipwood/git sequencer-merge-strategy-options/v2 Phillip Wood (5): rebase: stop reading and writing unnecessary strategy state sequencer: use struct strvec to store merge strategy options rebase -m: cleanup --strategy-option handling rebase -m: fix serialization of strategy options rebase: remove a couple of redundant strategy tests alias.c | 18 +++++++ alias.h | 3 ++ builtin/rebase.c | 54 ++++----------------- builtin/revert.c | 20 ++------ parse-options-cb.c | 16 +++++++ parse-options.h | 10 ++++ sequencer.c | 57 ++++++++++------------ sequencer.h | 12 +++-- t/t3402-rebase-merge.sh | 21 -------- t/t3418-rebase-continue.sh | 88 +++++++++++++--------------------- t/t3436-rebase-more-options.sh | 18 ------- 11 files changed, 126 insertions(+), 191 deletions(-) Range-diff against v1: 1: 029d0bf2b6 = 1: 2353c753f5 rebase: stop reading and writing unnecessary strategy state -: ---------- > 2: dd7b82cdd5 sequencer: use struct strvec to store merge strategy options 2: a01b182644 ! 3: ccef0e6f4b rebase -m: cleanup --strategy-option handling @@ builtin/rebase.c: struct rebase_options { .config_autosquash = -1, \ .update_refs = -1, \ .config_update_refs = -1, \ -+ .strategy_opts = STRING_LIST_INIT_NODUP \ ++ .strategy_opts = STRING_LIST_INIT_NODUP,\ } static struct replay_opts get_replay_opts(const struct rebase_options *opts) @@ builtin/rebase.c: static struct replay_opts get_replay_opts(const struct rebase_ - if (opts->strategy_opts) - parse_strategy_opts(&replay, opts->strategy_opts); -+ if (opts->strategy_opts.nr) { -+ ALLOC_ARRAY(replay.xopts, opts->strategy_opts.nr); -+ replay.xopts_nr = opts->strategy_opts.nr; -+ replay.xopts_alloc = opts->strategy_opts.nr; -+ for (size_t i = 0; i < opts->strategy_opts.nr; i++) -+ replay.xopts[i] = -+ xstrdup(opts->strategy_opts.items[i].string); -+ } ++ for (size_t i = 0; i < opts->strategy_opts.nr; i++) ++ strvec_push(&replay.xopts, opts->strategy_opts.items[i].string); if (opts->squash_onto) { oidcpy(&replay.squash_onto, opts->squash_onto); 3: 9af68cb065 ! 4: 9a90212ef2 rebase -m: fix serialization of strategy options @@ Commit message Signed-off-by: Phillip Wood <phillip.wood@xxxxxxxxxxxxx> + ## alias.c ## +@@ + #include "alloc.h" + #include "config.h" + #include "gettext.h" ++#include "strbuf.h" + #include "string-list.h" + + struct config_alias_data { +@@ alias.c: void list_aliases(struct string_list *list) + read_early_config(config_alias_cb, &data); + } + ++void quote_cmdline(struct strbuf *buf, const char **argv) ++{ ++ for (const char **argp = argv; *argp; argp++) { ++ if (argp != argv) ++ strbuf_addch(buf, ' '); ++ strbuf_addch(buf, '"'); ++ for (const char *p = *argp; *p; p++) { ++ const char c = *p; ++ ++ if (c == '"' || c =='\\') ++ strbuf_addch(buf, '\\'); ++ strbuf_addch(buf, c); ++ } ++ strbuf_addch(buf, '"'); ++ } ++} ++ + #define SPLIT_CMDLINE_BAD_ENDING 1 + #define SPLIT_CMDLINE_UNCLOSED_QUOTE 2 + #define SPLIT_CMDLINE_ARGC_OVERFLOW 3 + + ## alias.h ## +@@ + #ifndef ALIAS_H + #define ALIAS_H + ++struct strbuf; + struct string_list; + + char *alias_lookup(const char *alias); ++/* Quote argv so buf can be parsed by split_cmdline() */ ++void quote_cmdline(struct strbuf *buf, const char **argv); + int split_cmdline(char *cmdline, const char ***argv); + /* Takes a negative value returned by split_cmdline */ + const char *split_cmdline_strerror(int cmdline_errno); + ## sequencer.c ## @@ sequencer.c: static void parse_strategy_opts(struct replay_opts *opts, char *raw_opts) - count = split_cmdline(strategy_opts_string, - (const char ***)&opts->xopts); + + count = split_cmdline(strategy_opts_string, &argv); if (count < 0) - die(_("could not split '%s': %s"), strategy_opts_string, + BUG("could not split '%s': %s", strategy_opts_string, split_cmdline_strerror(count)); - opts->xopts_nr = count; - for (i = 0; i < opts->xopts_nr; i++) { + for (i = 0; i < count; i++) { + const char *arg = argv[i]; @@ sequencer.c: static int read_populate_opts(struct replay_opts *opts) static void write_strategy_opts(struct replay_opts *opts) { - int i; struct strbuf buf = STRBUF_INIT; -- for (i = 0; i < opts->xopts_nr; ++i) -- strbuf_addf(&buf, " --%s", opts->xopts[i]); +- for (i = 0; i < opts->xopts.nr; ++i) +- strbuf_addf(&buf, " --%s", opts->xopts.v[i]); - + /* + * Quote strategy options so that they can be read correctly + * by split_cmdline(). + */ -+ for (size_t i = 0; i < opts->xopts_nr; i++) { -+ char *arg = opts->xopts[i]; -+ -+ if (i) -+ strbuf_addch(&buf, ' '); -+ strbuf_addch(&buf, '"'); -+ for (size_t j = 0; arg[j]; j++) { -+ const char c = arg[j]; -+ -+ if (c == '"' || c =='\\') -+ strbuf_addch(&buf, '\\'); -+ strbuf_addch(&buf, c); -+ } -+ strbuf_addch(&buf, '"'); -+ } ++ quote_cmdline(&buf, opts->xopts.v); write_file(rebase_path_strategy_opts(), "%s\n", buf.buf); strbuf_release(&buf); } 4: 3e02eeff78 ! 5: 3515c31b40 rebase: remove a couple of redundant strategy tests @@ Metadata ## Commit message ## rebase: remove a couple of redundant strategy tests - The test removed in t3402 has been redundant ever since 80ff47957b - (rebase: remember strategy and strategy options, 2011-02-06) which added - a new test the first part of which (as noted in the commit message) - duplicated the existing test. The test removed in t3418 has been - redundant since the merge backend was removed in 68aa495b59 (rebase: - implement --merge via the interactive machinery, 2018-12-11) as it now - tests the same code paths as the preceding test. - + Remove a test in t3402 that has been redundant ever since 80ff47957b + (rebase: remember strategy and strategy options, 2011-02-06). That + commit added a new test, the first part of which (as noted in the old + commit message) duplicated an existing test. + + Also remove a test t3418 that has been redundant since the merge backend + was removed in 68aa495b59 (rebase: implement --merge via the interactive + machinery, 2018-12-11), since it now tests the same code paths as the + preceding test. + + Helped-by: Elijah Newren <newren@xxxxxxxxx> Signed-off-by: Phillip Wood <phillip.wood@xxxxxxxxxxxxx> ## t/t3402-rebase-merge.sh ## -- 2.40.0.670.g64ef305212.dirty