diff options
| -rw-r--r-- | archive.c | 4 | ||||
| -rw-r--r-- | builtin-branch.c | 3 | ||||
| -rw-r--r-- | builtin-checkout.c | 3 | ||||
| -rw-r--r-- | builtin-commit.c | 8 | ||||
| -rw-r--r-- | builtin-log.c | 3 | ||||
| -rw-r--r-- | builtin-merge.c | 7 | ||||
| -rw-r--r-- | builtin-rev-list.c | 7 | ||||
| -rw-r--r-- | builtin-shortlog.c | 9 | ||||
| -rw-r--r-- | builtin-show-branch.c | 4 | ||||
| -rw-r--r-- | commit.h | 19 | ||||
| -rw-r--r-- | log-tree.c | 24 | ||||
| -rw-r--r-- | pretty.c | 27 | 
12 files changed, 72 insertions, 46 deletions
| @@ -31,6 +31,8 @@ static void format_subst(const struct commit *commit,  {  	char *to_free = NULL;  	struct strbuf fmt = STRBUF_INIT; +	struct pretty_print_context ctx = {0}; +	ctx.date_mode = DATE_NORMAL;  	if (src == buf->buf)  		to_free = strbuf_detach(buf, NULL); @@ -48,7 +50,7 @@ static void format_subst(const struct commit *commit,  		strbuf_add(&fmt, b + 8, c - b - 8);  		strbuf_add(buf, src, b - src); -		format_commit_message(commit, fmt.buf, buf, DATE_NORMAL); +		format_commit_message(commit, fmt.buf, buf, &ctx);  		len -= c + 1 - src;  		src  = c + 1;  	} diff --git a/builtin-branch.c b/builtin-branch.c index 9f57992062..05e876e285 100644 --- a/builtin-branch.c +++ b/builtin-branch.c @@ -387,8 +387,9 @@ static void print_ref_item(struct ref_item *item, int maxwidth, int verbose,  		commit = item->commit;  		if (commit && !parse_commit(commit)) { +			struct pretty_print_context ctx = {0};  			pretty_print_commit(CMIT_FMT_ONELINE, commit, -					    &subject, 0, NULL, NULL, 0, 0); +					    &subject, &ctx);  			sub = subject.buf;  		} diff --git a/builtin-checkout.c b/builtin-checkout.c index d050c3789f..075a49f1a0 100644 --- a/builtin-checkout.c +++ b/builtin-checkout.c @@ -302,8 +302,9 @@ static void show_local_changes(struct object *head)  static void describe_detached_head(char *msg, struct commit *commit)  {  	struct strbuf sb = STRBUF_INIT; +	struct pretty_print_context ctx = {0};  	parse_commit(commit); -	pretty_print_commit(CMIT_FMT_ONELINE, commit, &sb, 0, NULL, NULL, 0, 0); +	pretty_print_commit(CMIT_FMT_ONELINE, commit, &sb, &ctx);  	fprintf(stderr, "%s %s... %s\n", msg,  		find_unique_abbrev(commit->object.sha1, DEFAULT_ABBREV), sb.buf);  	strbuf_release(&sb); diff --git a/builtin-commit.c b/builtin-commit.c index 200ffdaad4..13edeee575 100644 --- a/builtin-commit.c +++ b/builtin-commit.c @@ -684,8 +684,10 @@ static const char *find_author_by_nickname(const char *name)  	prepare_revision_walk(&revs);  	commit = get_revision(&revs);  	if (commit) { +		struct pretty_print_context ctx = {0}; +		ctx.date_mode = DATE_NORMAL;  		strbuf_release(&buf); -		format_commit_message(commit, "%an <%ae>", &buf, DATE_NORMAL); +		format_commit_message(commit, "%an <%ae>", &buf, &ctx);  		return strbuf_detach(&buf, NULL);  	}  	die("No existing author found with '%s'", name); @@ -942,8 +944,10 @@ static void print_summary(const char *prefix, const unsigned char *sha1)  		initial_commit ? " (root-commit)" : "");  	if (!log_tree_commit(&rev, commit)) { +		struct pretty_print_context ctx = {0};  		struct strbuf buf = STRBUF_INIT; -		format_commit_message(commit, format + 7, &buf, DATE_NORMAL); +		ctx.date_mode = DATE_NORMAL; +		format_commit_message(commit, format + 7, &buf, &ctx);  		printf("%s\n", buf.buf);  		strbuf_release(&buf);  	} diff --git a/builtin-log.c b/builtin-log.c index 25e21ed415..207a36178b 100644 --- a/builtin-log.c +++ b/builtin-log.c @@ -1304,8 +1304,9 @@ int cmd_cherry(int argc, const char **argv, const char *prefix)  		if (verbose) {  			struct strbuf buf = STRBUF_INIT; +			struct pretty_print_context ctx = {0};  			pretty_print_commit(CMIT_FMT_ONELINE, commit, -			                    &buf, 0, NULL, NULL, 0, 0); +					    &buf, &ctx);  			printf("%c %s %s\n", sign,  			       sha1_to_hex(commit->object.sha1), buf.buf);  			strbuf_release(&buf); diff --git a/builtin-merge.c b/builtin-merge.c index b6b84286b2..c69a3051f3 100644 --- a/builtin-merge.c +++ b/builtin-merge.c @@ -264,6 +264,7 @@ static void squash_message(void)  	struct strbuf out = STRBUF_INIT;  	struct commit_list *j;  	int fd; +	struct pretty_print_context ctx = {0};  	printf("Squash commit -- not updating HEAD\n");  	fd = open(git_path("SQUASH_MSG"), O_WRONLY | O_CREAT, 0666); @@ -285,13 +286,15 @@ static void squash_message(void)  	if (prepare_revision_walk(&rev))  		die("revision walk setup failed"); +	ctx.abbrev = rev.abbrev; +	ctx.date_mode = rev.date_mode; +  	strbuf_addstr(&out, "Squashed commit of the following:\n");  	while ((commit = get_revision(&rev)) != NULL) {  		strbuf_addch(&out, '\n');  		strbuf_addf(&out, "commit %s\n",  			sha1_to_hex(commit->object.sha1)); -		pretty_print_commit(rev.commit_format, commit, &out, rev.abbrev, -			NULL, NULL, rev.date_mode, 0); +		pretty_print_commit(rev.commit_format, commit, &out, &ctx);  	}  	if (write(fd, out.buf, out.len) < 0)  		die_errno("Writing SQUASH_MSG"); diff --git a/builtin-rev-list.c b/builtin-rev-list.c index 4ba1c12e0b..42cc8d8872 100644 --- a/builtin-rev-list.c +++ b/builtin-rev-list.c @@ -96,9 +96,10 @@ static void show_commit(struct commit *commit, void *data)  	if (revs->verbose_header && commit->buffer) {  		struct strbuf buf = STRBUF_INIT; -		pretty_print_commit(revs->commit_format, commit, -				    &buf, revs->abbrev, NULL, NULL, -				    revs->date_mode, 0); +		struct pretty_print_context ctx = {0}; +		ctx.abbrev = revs->abbrev; +		ctx.date_mode = revs->date_mode; +		pretty_print_commit(revs->commit_format, commit, &buf, &ctx);  		if (revs->graph) {  			if (buf.len) {  				if (revs->commit_format != CMIT_FMT_ONELINE) diff --git a/builtin-shortlog.c b/builtin-shortlog.c index 4d4a3c82d6..8aa63c7857 100644 --- a/builtin-shortlog.c +++ b/builtin-shortlog.c @@ -158,9 +158,12 @@ void shortlog_add_commit(struct shortlog *log, struct commit *commit)  		    sha1_to_hex(commit->object.sha1));  	if (log->user_format) {  		struct strbuf buf = STRBUF_INIT; - -		pretty_print_commit(CMIT_FMT_USERFORMAT, commit, &buf, -			DEFAULT_ABBREV, "", "", DATE_NORMAL, 0); +		struct pretty_print_context ctx = {0}; +		ctx.abbrev = DEFAULT_ABBREV; +		ctx.subject = ""; +		ctx.after_subject = ""; +		ctx.date_mode = DATE_NORMAL; +		pretty_print_commit(CMIT_FMT_USERFORMAT, commit, &buf, &ctx);  		insert_one_record(log, author, buf.buf);  		strbuf_release(&buf);  		return; diff --git a/builtin-show-branch.c b/builtin-show-branch.c index be95930b78..9f13caa76d 100644 --- a/builtin-show-branch.c +++ b/builtin-show-branch.c @@ -293,8 +293,8 @@ static void show_one_commit(struct commit *commit, int no_name)  	struct commit_name *name = commit->util;  	if (commit->object.parsed) { -		pretty_print_commit(CMIT_FMT_ONELINE, commit, -				    &pretty, 0, NULL, NULL, 0, 0); +		struct pretty_print_context ctx = {0}; +		pretty_print_commit(CMIT_FMT_ONELINE, commit, &pretty, &ctx);  		pretty_str = pretty.buf;  	}  	if (!prefixcmp(pretty_str, "[PATCH] ")) @@ -63,6 +63,15 @@ enum cmit_fmt {  	CMIT_FMT_UNSPECIFIED,  }; +struct pretty_print_context +{ +	int abbrev; +	const char *subject; +	const char *after_subject; +	enum date_mode date_mode; +	int need_8bit_cte; +}; +  extern int non_ascii(int);  extern int has_non_ascii(const char *text);  struct rev_info; /* in revision.h, it circularly uses enum cmit_fmt */ @@ -71,12 +80,10 @@ extern char *reencode_commit_message(const struct commit *commit,  extern void get_commit_format(const char *arg, struct rev_info *);  extern void format_commit_message(const struct commit *commit,  				  const void *format, struct strbuf *sb, -				  enum date_mode dmode); -extern void pretty_print_commit(enum cmit_fmt fmt, const struct commit*, -                                struct strbuf *, -                                int abbrev, const char *subject, -                                const char *after_subject, enum date_mode, -				int need_8bit_cte); +				  const struct pretty_print_context *context); +extern void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit, +				struct strbuf *sb, +				const struct pretty_print_context *context);  void pp_user_info(const char *what, enum cmit_fmt fmt, struct strbuf *sb,  		   const char *line, enum date_mode dmode,  		   const char *encoding); diff --git a/log-tree.c b/log-tree.c index f7d54f2f1b..1675035d84 100644 --- a/log-tree.c +++ b/log-tree.c @@ -179,8 +179,10 @@ void get_patch_filename(struct commit *commit, int nr, const char *suffix,  	strbuf_addf(buf, commit ? "%04d-" : "%d", nr);  	if (commit) {  		int max_len = start_len + FORMAT_PATCH_NAME_MAX - suffix_len; +		struct pretty_print_context ctx = {0}; +		ctx.date_mode = DATE_NORMAL; -		format_commit_message(commit, "%f", buf, DATE_NORMAL); +		format_commit_message(commit, "%f", buf, &ctx);  		if (max_len < buf->len)  			strbuf_setlen(buf, max_len);  		strbuf_addstr(buf, suffix); @@ -277,10 +279,9 @@ void show_log(struct rev_info *opt)  	struct strbuf msgbuf = STRBUF_INIT;  	struct log_info *log = opt->loginfo;  	struct commit *commit = log->commit, *parent = log->parent; -	int abbrev = opt->diffopt.abbrev;  	int abbrev_commit = opt->abbrev_commit ? opt->abbrev : 40; -	const char *subject = NULL, *extra_headers = opt->extra_headers; -	int need_8bit_cte = 0; +	const char *extra_headers = opt->extra_headers; +	struct pretty_print_context ctx = {0};  	opt->loginfo = NULL;  	if (!opt->verbose_header) { @@ -347,8 +348,8 @@ void show_log(struct rev_info *opt)  	 */  	if (opt->commit_format == CMIT_FMT_EMAIL) { -		log_write_email_headers(opt, commit, &subject, &extra_headers, -					&need_8bit_cte); +		log_write_email_headers(opt, commit, &ctx.subject, &extra_headers, +					&ctx.need_8bit_cte);  	} else if (opt->commit_format != CMIT_FMT_USERFORMAT) {  		fputs(diff_get_color_opt(&opt->diffopt, DIFF_COMMIT), stdout);  		if (opt->commit_format != CMIT_FMT_ONELINE) @@ -405,11 +406,12 @@ void show_log(struct rev_info *opt)  	/*  	 * And then the pretty-printed message itself  	 */ -	if (need_8bit_cte >= 0) -		need_8bit_cte = has_non_ascii(opt->add_signoff); -	pretty_print_commit(opt->commit_format, commit, &msgbuf, -			    abbrev, subject, extra_headers, opt->date_mode, -			    need_8bit_cte); +	if (ctx.need_8bit_cte >= 0) +		ctx.need_8bit_cte = has_non_ascii(opt->add_signoff); +	ctx.date_mode = opt->date_mode; +	ctx.abbrev = opt->diffopt.abbrev; +	ctx.after_subject = extra_headers; +	pretty_print_commit(opt->commit_format, commit, &msgbuf, &ctx);  	if (opt->add_signoff)  		append_signoff(&msgbuf, opt->add_signoff); @@ -442,7 +442,7 @@ struct chunk {  struct format_commit_context {  	const struct commit *commit; -	enum date_mode dmode; +	const struct pretty_print_context *pretty_ctx;  	unsigned commit_header_parsed:1;  	unsigned commit_message_parsed:1; @@ -711,11 +711,11 @@ static size_t format_commit_item(struct strbuf *sb, const char *placeholder,  	case 'a':	/* author ... */  		return format_person_part(sb, placeholder[1],  				   msg + c->author.off, c->author.len, -				   c->dmode); +				   c->pretty_ctx->date_mode);  	case 'c':	/* committer ... */  		return format_person_part(sb, placeholder[1],  				   msg + c->committer.off, c->committer.len, -				   c->dmode); +				   c->pretty_ctx->date_mode);  	case 'e':	/* encoding */  		strbuf_add(sb, msg + c->encoding.off, c->encoding.len);  		return 1; @@ -741,13 +741,13 @@ static size_t format_commit_item(struct strbuf *sb, const char *placeholder,  void format_commit_message(const struct commit *commit,  			   const void *format, struct strbuf *sb, -			   enum date_mode dmode) +			   const struct pretty_print_context *pretty_ctx)  {  	struct format_commit_context context;  	memset(&context, 0, sizeof(context));  	context.commit = commit; -	context.dmode = dmode; +	context.pretty_ctx = pretty_ctx;  	strbuf_expand(sb, format, format_commit_item, &context);  } @@ -900,18 +900,18 @@ char *reencode_commit_message(const struct commit *commit, const char **encoding  }  void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit, -			 struct strbuf *sb, int abbrev, -			 const char *subject, const char *after_subject, -			 enum date_mode dmode, int need_8bit_cte) +			 struct strbuf *sb, +			 const struct pretty_print_context *context)  {  	unsigned long beginning_of_body;  	int indent = 4;  	const char *msg = commit->buffer;  	char *reencoded;  	const char *encoding; +	int need_8bit_cte = context->need_8bit_cte;  	if (fmt == CMIT_FMT_USERFORMAT) { -		format_commit_message(commit, user_format, sb, dmode); +		format_commit_message(commit, user_format, sb, context);  		return;  	} @@ -946,8 +946,9 @@ void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit,  		}  	} -	pp_header(fmt, abbrev, dmode, encoding, commit, &msg, sb); -	if (fmt != CMIT_FMT_ONELINE && !subject) { +	pp_header(fmt, context->abbrev, context->date_mode, encoding, +		  commit, &msg, sb); +	if (fmt != CMIT_FMT_ONELINE && !context->subject) {  		strbuf_addch(sb, '\n');  	} @@ -956,8 +957,8 @@ void pretty_print_commit(enum cmit_fmt fmt, const struct commit *commit,  	/* These formats treat the title line specially. */  	if (fmt == CMIT_FMT_ONELINE || fmt == CMIT_FMT_EMAIL) -		pp_title_line(fmt, &msg, sb, subject, -			      after_subject, encoding, need_8bit_cte); +		pp_title_line(fmt, &msg, sb, context->subject, +			      context->after_subject, encoding, need_8bit_cte);  	beginning_of_body = sb->len;  	if (fmt != CMIT_FMT_ONELINE) | 
