On Thu, Jun 18, 2015 at 10:13:37AM -0700, Junio C Hamano wrote: > > -static const char *set_outdir(const char *prefix, const char *output_directory) > > +static const char *set_outdir(const char *prefix, const char *output_directory, > > + const char *config_output_directory) > > This change looks ugly and unnecessary. All the machinery after and > including the point set_outdir() is called, including reopen_stdout(), > work on output_directory variable and only that variable. > > Wouldn't it work equally well to have > > if (!output_directory) > output_directory = config_output_directory; > > before a call to set_outdir() is made but after the configuration is > read (namely, soon after parse_options() returns), without making > any change to this function? Don't we load the config before parsing options here? In that case, we can use our usual strategy to just set output_directory (which is already a static global) from the config callback, and everything Just Works. We do have to bump the definition of output_directory up above the config callback, like so (while we are here, we might also want to drop the unnecessary static initializers, which violate our style guide): diff --git a/builtin/log.c b/builtin/log.c index e67671e..77c06f7 100644 --- a/builtin/log.c +++ b/builtin/log.c @@ -37,6 +37,10 @@ static int use_mailmap_config; static const char *fmt_patch_subject_prefix = "PATCH"; static const char *fmt_pretty; +static FILE *realstdout = NULL; +static const char *output_directory = NULL; +static int outdir_offset; + static const char * const builtin_log_usage[] = { N_("git log [<options>] [<revision-range>] [[--] <path>...]"), N_("git show [<options>] <object>..."), @@ -752,14 +756,12 @@ static int git_format_config(const char *var, const char *value, void *cb) config_cover_letter = git_config_bool(var, value) ? COVER_ON : COVER_OFF; return 0; } + if (!strcmp(var, "format.outputdirectory")) + return git_config_string(&output_directory, var, value); return git_log_config(var, value, cb); } -static FILE *realstdout = NULL; -static const char *output_directory = NULL; -static int outdir_offset; - static int reopen_stdout(struct commit *commit, const char *subject, struct rev_info *rev, int quiet) { -- 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