Koosha Khajehmoogahi <koosha@xxxxxxxxx> writes: > On 03/16/2015 09:50 PM, Junio C Hamano wrote: >> The command line overrides the config, no? If you set up what the >> command line defaults to from the config, let the command line >> parser do whatever it wants to do, and do nothing else after the >> command line parser returns, wouldn't that be sufficient? >> >> Puzzled... >> > > Yes, the command line overrides the config. But, the config and command > line parameters are parsed in two different files. The question is how > you would read the config in revision.c while parsing the command line > when there is no function in revision.c for that? What I had in mind was along the line of the attached diff. If I were doing this new feature, it would be in two-patch series, whose first patch [1/2] would be just the revision.[ch] to give these three "canned" selection options (we obviously need to update the documentation and also add tests to make sure the new option behaves sensibly when used alone, and in conjunction with existing "--merges" and "--no-merges" options). The second patch [2/2] would teach git_log_config() to read the new configuration value and keep it in a file-scope static variable in builtin/log.c, and then call parse_merges_opt() with that value in the codepath somewhere after init_revisions() is called on &rev and before setup_revisions() is called. Note that the addition I made to cmd_log() below is for illustration purposes only; I have no strong opinion on whether it is at the right place in the codepath (it is one place that is "between init_revisions() and setup_revisions()", but it may not be the best such place). The call may want to be made a lot later in the codepath, possibly inside cmd_log_init() instead of cmd_log(), for example. The choice depends on how widely you would want this new configuration be honored, which I didn't think too deeply. The questions you would need to answer before deciding where is the best place to make the call include: - Should "git whatchanged" also pay attention to it? - What about "git show"? etc. builtin/log.c | 5 +++++ revision.c | 20 ++++++++++++++++++++ revision.h | 2 ++ 3 files changed, 27 insertions(+) diff --git a/builtin/log.c b/builtin/log.c index dd8f3fc..11a191d 100644 --- a/builtin/log.c +++ b/builtin/log.c @@ -36,6 +36,7 @@ static int decoration_given; static int use_mailmap_config; static const char *fmt_patch_subject_prefix = "PATCH"; static const char *fmt_pretty; +static const char *log_merges; static const char * const builtin_log_usage[] = { N_("git log [<options>] [<revision range>] [[--] <path>...]"), @@ -397,6 +398,8 @@ static int git_log_config(const char *var, const char *value, void *cb) return 0; } + if (!strcmp(var, "log.merges")) + return git_config_string(&log_merges, var, value); if (grep_config(var, value, cb) < 0) return -1; if (git_gpg_config(var, value, cb) < 0) @@ -628,6 +631,8 @@ int cmd_log(int argc, const char **argv, const char *prefix) init_revisions(&rev, prefix); rev.always_show_header = 1; + if (log_merges && parse_merges_opt(&rev, log_merges)) + die("unknown config value for log.merges: %s", log_merges); memset(&opt, 0, sizeof(opt)); opt.def = "HEAD"; opt.revarg_opt = REVARG_COMMITTISH; diff --git a/revision.c b/revision.c index dbee26b..2fa37b0 100644 --- a/revision.c +++ b/revision.c @@ -1678,6 +1678,23 @@ static void add_message_grep(struct rev_info *revs, const char *pattern) add_grep(revs, pattern, GREP_PATTERN_BODY); } +int parse_merges_opt(struct rev_info *revs, const char *param) +{ + if (!strcmp(param, "both")) { + revs->min_parents = 0; + revs->max_parents = -1; + } else if (!strcmp(param, "only")) { + revs->min_parents = 2; + revs->max_parents = -1; + } else if (!strcmp(param, "skip")) { + revs->min_parents = 0; + revs->max_parents = 1; + } else { + return -1; + } + return 0; +} + static int handle_revision_opt(struct rev_info *revs, int argc, const char **argv, int *unkc, const char **unkv) { @@ -1812,6 +1829,9 @@ static int handle_revision_opt(struct rev_info *revs, int argc, const char **arg revs->max_parents = atoi(arg+14); } else if (starts_with(arg, "--no-max-parents")) { revs->max_parents = -1; + } else if (starts_with(arg, "--merges=")) { + if (parse_merges_opt(revs, arg + 9)) + die("unknown option: %s", arg); } else if (!strcmp(arg, "--boundary")) { revs->boundary = 1; } else if (!strcmp(arg, "--left-right")) { diff --git a/revision.h b/revision.h index 0ea8b4e..640589c 100644 --- a/revision.h +++ b/revision.h @@ -240,6 +240,8 @@ extern int setup_revisions(int argc, const char **argv, struct rev_info *revs, extern void parse_revision_opt(struct rev_info *revs, struct parse_opt_ctx_t *ctx, const struct option *options, const char * const usagestr[]); +extern int parse_merges_opt(struct rev_info *, const char *); + #define REVARG_CANNOT_BE_FILENAME 01 #define REVARG_COMMITTISH 02 extern int handle_revision_arg(const char *arg, struct rev_info *revs, -- 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