diff options
Diffstat (limited to 'reflog-walk.c')
| -rw-r--r-- | reflog-walk.c | 88 | 
1 files changed, 64 insertions, 24 deletions
| diff --git a/reflog-walk.c b/reflog-walk.c index f751fdc8d8..5d81d39a52 100644 --- a/reflog-walk.c +++ b/reflog-walk.c @@ -8,6 +8,7 @@  struct complete_reflogs {  	char *ref; +	const char *short_ref;  	struct reflog_info {  		unsigned char osha1[20], nsha1[20];  		char *email; @@ -161,7 +162,7 @@ int add_reflog_for_walk(struct reflog_walk_info *info,  	} else  		recno = 0; -	item = string_list_lookup(branch, &info->complete_reflogs); +	item = string_list_lookup(&info->complete_reflogs, branch);  	if (item)  		reflogs = item->util;  	else { @@ -189,7 +190,7 @@ int add_reflog_for_walk(struct reflog_walk_info *info,  		}  		if (!reflogs || reflogs->nr == 0)  			return -1; -		string_list_insert(branch, &info->complete_reflogs)->util +		string_list_insert(&info->complete_reflogs, branch)->util  			= reflogs;  	} @@ -238,37 +239,76 @@ void fake_reflog_parent(struct reflog_walk_info *info, struct commit *commit)  	commit->parents = xcalloc(sizeof(struct commit_list), 1);  	commit->parents->item = commit_info->commit; -	commit->object.flags &= ~(ADDED | SEEN | SHOWN);  } -void show_reflog_message(struct reflog_walk_info* info, int oneline, -	int relative_date) +void get_reflog_selector(struct strbuf *sb, +			 struct reflog_walk_info *reflog_info, +			 enum date_mode dmode, +			 int shorten)  { -	if (info && info->last_commit_reflog) { -		struct commit_reflog *commit_reflog = info->last_commit_reflog; +	struct commit_reflog *commit_reflog = reflog_info->last_commit_reflog; +	struct reflog_info *info; +	const char *printed_ref; + +	if (!commit_reflog) +		return; + +	if (shorten) { +		if (!commit_reflog->reflogs->short_ref) +			commit_reflog->reflogs->short_ref +				= shorten_unambiguous_ref(commit_reflog->reflogs->ref, 0); +		printed_ref = commit_reflog->reflogs->short_ref; +	} else { +		printed_ref = commit_reflog->reflogs->ref; +	} + +	strbuf_addf(sb, "%s@{", printed_ref); +	if (commit_reflog->flag || dmode) { +		info = &commit_reflog->reflogs->items[commit_reflog->recno+1]; +		strbuf_addstr(sb, show_date(info->timestamp, info->tz, dmode)); +	} else { +		strbuf_addf(sb, "%d", commit_reflog->reflogs->nr +			    - 2 - commit_reflog->recno); +	} + +	strbuf_addch(sb, '}'); +} + +void get_reflog_message(struct strbuf *sb, +			struct reflog_walk_info *reflog_info) +{ +	struct commit_reflog *commit_reflog = reflog_info->last_commit_reflog; +	struct reflog_info *info; +	size_t len; + +	if (!commit_reflog) +		return; + +	info = &commit_reflog->reflogs->items[commit_reflog->recno+1]; +	len = strlen(info->message); +	if (len > 0) +		len--; /* strip away trailing newline */ +	strbuf_add(sb, info->message, len); +} + +void show_reflog_message(struct reflog_walk_info *reflog_info, int oneline, +	enum date_mode dmode) +{ +	if (reflog_info && reflog_info->last_commit_reflog) { +		struct commit_reflog *commit_reflog = reflog_info->last_commit_reflog;  		struct reflog_info *info; +		struct strbuf selector = STRBUF_INIT;  		info = &commit_reflog->reflogs->items[commit_reflog->recno+1]; +		get_reflog_selector(&selector, reflog_info, dmode, 0);  		if (oneline) { -			printf("%s@{", commit_reflog->reflogs->ref); -			if (commit_reflog->flag || relative_date) -				printf("%s", show_date(info->timestamp, 0, 1)); -			else -				printf("%d", commit_reflog->reflogs->nr -				       - 2 - commit_reflog->recno); -			printf("}: %s", info->message); +			printf("%s: %s", selector.buf, info->message);  		}  		else { -			printf("Reflog: %s@{", commit_reflog->reflogs->ref); -			if (commit_reflog->flag || relative_date) -				printf("%s", show_date(info->timestamp, -							info->tz, -							relative_date)); -			else -				printf("%d", commit_reflog->reflogs->nr -				       - 2 - commit_reflog->recno); -			printf("} (%s)\nReflog message: %s", -			       info->email, info->message); +			printf("Reflog: %s (%s)\nReflog message: %s", +			       selector.buf, info->email, info->message);  		} + +		strbuf_release(&selector);  	}  } | 
