Skip to content

Commit

Permalink
builtin/log.c: separate default and setup of cmd_log_init()
Browse files Browse the repository at this point in the history
cmd_log_init() sets up some default rev options and then calls
setup_revisions(), so that a caller cannot set up own defaults: Either
they get overriden by cmd_log_init() (if set before) or they override
the command line (if set after). We even complain about this in a
comment to cmd_log_reflog().

Therefore, separate the two steps so that one can still call
cmd_log_init() or, alternatively, cmd_log_init_defaults() followed by
cmd_log_init_finish() (and set defaults in between).

No functional change so far.

Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Michael J Gruber authored and Junio C Hamano committed Apr 1, 2011
1 parent 2352570 commit ef803fd
Showing 1 changed file with 15 additions and 6 deletions.
21 changes: 15 additions & 6 deletions builtin/log.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,13 +49,8 @@ static int parse_decoration_style(const char *var, const char *value)
return -1;
}

static void cmd_log_init(int argc, const char **argv, const char *prefix,
struct rev_info *rev, struct setup_revision_opt *opt)
static void cmd_log_init_defaults(struct rev_info *rev)
{
int i;
int decoration_given = 0;
struct userformat_want w;

rev->abbrev = DEFAULT_ABBREV;
rev->commit_format = CMIT_FMT_DEFAULT;
if (fmt_pretty)
Expand All @@ -68,7 +63,14 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix,

if (default_date_mode)
rev->date_mode = parse_date_format(default_date_mode);
}

static void cmd_log_init_finish(int argc, const char **argv, const char *prefix,
struct rev_info *rev, struct setup_revision_opt *opt)
{
int i;
int decoration_given = 0;
struct userformat_want w;
/*
* Check for -h before setup_revisions(), or "git log -h" will
* fail when run without a git directory.
Expand Down Expand Up @@ -128,6 +130,13 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix,
setup_pager();
}

static void cmd_log_init(int argc, const char **argv, const char *prefix,
struct rev_info *rev, struct setup_revision_opt *opt)
{
cmd_log_init_defaults(rev);
cmd_log_init_finish(argc, argv, prefix, rev, opt);
}

/*
* This gives a rough estimate for how many commits we
* will print out in the list.
Expand Down

0 comments on commit ef803fd

Please sign in to comment.