Merge branch 'dl/pretty-reference'
"git log" family learned "--pretty=reference" that gives the name of a commit in the format that is often used to refer to it in log messages. * dl/pretty-reference: SubmittingPatches: use `--pretty=reference` pretty: implement 'reference' format pretty: add struct cmt_fmt_map::default_date_mode_type pretty: provide short date format t4205: cover `git log --reflog -z` blindspot pretty.c: inline initalize format_context revision: make get_revision_mark() return const pointer completion: complete `tformat:` pretty format SubmittingPatches: remove dq from commit reference pretty-formats.txt: use generic terms for hash SubmittingPatches: use generic terms for hash
This commit is contained in:
20
pretty.c
20
pretty.c
@ -20,6 +20,7 @@ static struct cmt_fmt_map {
|
||||
int is_tformat;
|
||||
int expand_tabs_in_log;
|
||||
int is_alias;
|
||||
enum date_mode_type default_date_mode_type;
|
||||
const char *user_format;
|
||||
} *commit_formats;
|
||||
static size_t builtin_formats_len;
|
||||
@ -97,7 +98,9 @@ static void setup_commit_formats(void)
|
||||
{ "mboxrd", CMIT_FMT_MBOXRD, 0, 0 },
|
||||
{ "fuller", CMIT_FMT_FULLER, 0, 8 },
|
||||
{ "full", CMIT_FMT_FULL, 0, 8 },
|
||||
{ "oneline", CMIT_FMT_ONELINE, 1, 0 }
|
||||
{ "oneline", CMIT_FMT_ONELINE, 1, 0 },
|
||||
{ "reference", CMIT_FMT_USERFORMAT, 1, 0,
|
||||
0, DATE_SHORT, "%C(auto)%h (%s, %ad)" },
|
||||
/*
|
||||
* Please update $__git_log_pretty_formats in
|
||||
* git-completion.bash when you add new formats.
|
||||
@ -181,6 +184,8 @@ void get_commit_format(const char *arg, struct rev_info *rev)
|
||||
rev->commit_format = commit_format->format;
|
||||
rev->use_terminator = commit_format->is_tformat;
|
||||
rev->expand_tabs_in_log_default = commit_format->expand_tabs_in_log;
|
||||
if (!rev->date_mode_explicit && commit_format->default_date_mode_type)
|
||||
rev->date_mode.type = commit_format->default_date_mode_type;
|
||||
if (commit_format->format == CMIT_FMT_USERFORMAT) {
|
||||
save_user_format(rev, commit_format->user_format,
|
||||
commit_format->is_tformat);
|
||||
@ -738,6 +743,9 @@ static size_t format_person_part(struct strbuf *sb, char part,
|
||||
case 'I': /* date, ISO 8601 strict */
|
||||
strbuf_addstr(sb, show_ident_date(&s, DATE_MODE(ISO8601_STRICT)));
|
||||
return placeholder_len;
|
||||
case 's':
|
||||
strbuf_addstr(sb, show_ident_date(&s, DATE_MODE(SHORT)));
|
||||
return placeholder_len;
|
||||
}
|
||||
|
||||
skip:
|
||||
@ -1617,14 +1625,14 @@ void repo_format_commit_message(struct repository *r,
|
||||
const char *format, struct strbuf *sb,
|
||||
const struct pretty_print_context *pretty_ctx)
|
||||
{
|
||||
struct format_commit_context context;
|
||||
struct format_commit_context context = {
|
||||
.commit = commit,
|
||||
.pretty_ctx = pretty_ctx,
|
||||
.wrap_start = sb->len
|
||||
};
|
||||
const char *output_enc = pretty_ctx->output_encoding;
|
||||
const char *utf8 = "UTF-8";
|
||||
|
||||
memset(&context, 0, sizeof(context));
|
||||
context.commit = commit;
|
||||
context.pretty_ctx = pretty_ctx;
|
||||
context.wrap_start = sb->len;
|
||||
/*
|
||||
* convert a commit message to UTF-8 first
|
||||
* as far as 'format_commit_item' assumes it in UTF-8
|
||||
|
||||
Reference in New Issue
Block a user