blame: compute abbreviation width that ensures uniqueness
Julia Lawall noticed that in linux-next repository the commit object
60d5c9f5 (shown with the default abbreviation width baked into "git
blame") in output from
  $ git blame -L 3675,3675 60d5c9f5b -- \
      drivers/staging/brcm80211/brcmfmac/wl_iw.c
is no longer unique in the repository, which results in "short SHA1
60d5c9f5 is ambiguous".
Compute the minimum abbreviation width that ensures uniqueness when
the user did not specify the --abbrev option to avoid this.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
			
			
				maint
			
			
		
							parent
							
								
									f174a2583c
								
							
						
					
					
						commit
						b31272f704
					
				|  | @ -1828,6 +1828,16 @@ static int read_ancestry(const char *graft_file) | |||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static int update_auto_abbrev(int auto_abbrev, struct origin *suspect) | ||||
| { | ||||
| 	const char *uniq = find_unique_abbrev(suspect->commit->object.sha1, | ||||
| 					      auto_abbrev); | ||||
| 	int len = strlen(uniq); | ||||
| 	if (auto_abbrev < len) | ||||
| 		return len; | ||||
| 	return auto_abbrev; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * How many columns do we need to show line numbers in decimal? | ||||
|  */ | ||||
|  | @ -1850,12 +1860,16 @@ static void find_alignment(struct scoreboard *sb, int *option) | |||
| 	int longest_dst_lines = 0; | ||||
| 	unsigned largest_score = 0; | ||||
| 	struct blame_entry *e; | ||||
| 	int compute_auto_abbrev = (abbrev < 0); | ||||
| 	int auto_abbrev = default_abbrev; | ||||
|  | ||||
| 	for (e = sb->ent; e; e = e->next) { | ||||
| 		struct origin *suspect = e->suspect; | ||||
| 		struct commit_info ci; | ||||
| 		int num; | ||||
|  | ||||
| 		if (compute_auto_abbrev) | ||||
| 			auto_abbrev = update_auto_abbrev(auto_abbrev, suspect); | ||||
| 		if (strcmp(suspect->path, sb->path)) | ||||
| 			*option |= OUTPUT_SHOW_NAME; | ||||
| 		num = strlen(suspect->path); | ||||
|  | @ -1883,6 +1897,10 @@ static void find_alignment(struct scoreboard *sb, int *option) | |||
| 	max_orig_digits = lineno_width(longest_src_lines); | ||||
| 	max_digits = lineno_width(longest_dst_lines); | ||||
| 	max_score_digits = lineno_width(largest_score); | ||||
|  | ||||
| 	if (compute_auto_abbrev) | ||||
| 		/* one more abbrev length is needed for the boundary commit */ | ||||
| 		abbrev = auto_abbrev + 1; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | @ -2360,10 +2378,9 @@ int cmd_blame(int argc, const char **argv, const char *prefix) | |||
| parse_done: | ||||
| 	argc = parse_options_end(&ctx); | ||||
|  | ||||
| 	if (abbrev == -1) | ||||
| 		abbrev = default_abbrev; | ||||
| 	/* one more abbrev length is needed for the boundary commit */ | ||||
| 	abbrev++; | ||||
| 	if (0 < abbrev) | ||||
| 		/* one more abbrev length is needed for the boundary commit */ | ||||
| 		abbrev++; | ||||
|  | ||||
| 	if (revs_file && read_ancestry(revs_file)) | ||||
| 		die_errno("reading graft file '%s' failed", revs_file); | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Junio C Hamano
						Junio C Hamano