diff options
Diffstat (limited to 'combine-diff.c')
| -rw-r--r-- | combine-diff.c | 58 | 
1 files changed, 29 insertions, 29 deletions
diff --git a/combine-diff.c b/combine-diff.c index 5cae5fbd62..0f62f54b5e 100644 --- a/combine-diff.c +++ b/combine-diff.c @@ -44,9 +44,9 @@ static struct combine_diff_path *intersect_paths(struct combine_diff_path *curr,  			memset(p->parent, 0,  			       sizeof(p->parent[0]) * num_parent); -			hashcpy(p->sha1, q->queue[i]->two->sha1); +			hashcpy(p->oid.hash, q->queue[i]->two->sha1);  			p->mode = q->queue[i]->two->mode; -			hashcpy(p->parent[n].sha1, q->queue[i]->one->sha1); +			hashcpy(p->parent[n].oid.hash, q->queue[i]->one->sha1);  			p->parent[n].mode = q->queue[i]->one->mode;  			p->parent[n].status = q->queue[i]->status;  			*tail = p; @@ -77,7 +77,7 @@ static struct combine_diff_path *intersect_paths(struct combine_diff_path *curr,  			continue;  		} -		hashcpy(p->parent[n].sha1, q->queue[i]->one->sha1); +		hashcpy(p->parent[n].oid.hash, q->queue[i]->one->sha1);  		p->parent[n].mode = q->queue[i]->one->mode;  		p->parent[n].status = q->queue[i]->status; @@ -284,7 +284,7 @@ static struct lline *coalesce_lines(struct lline *base, int *lenbase,  	return base;  } -static char *grab_blob(const unsigned char *sha1, unsigned int mode, +static char *grab_blob(const struct object_id *oid, unsigned int mode,  		       unsigned long *size, struct userdiff_driver *textconv,  		       const char *path)  { @@ -294,20 +294,20 @@ static char *grab_blob(const unsigned char *sha1, unsigned int mode,  	if (S_ISGITLINK(mode)) {  		blob = xmalloc(100);  		*size = snprintf(blob, 100, -				 "Subproject commit %s\n", sha1_to_hex(sha1)); -	} else if (is_null_sha1(sha1)) { +				 "Subproject commit %s\n", oid_to_hex(oid)); +	} else if (is_null_oid(oid)) {  		/* deleted blob */  		*size = 0;  		return xcalloc(1, 1);  	} else if (textconv) {  		struct diff_filespec *df = alloc_filespec(path); -		fill_filespec(df, sha1, 1, mode); +		fill_filespec(df, oid->hash, 1, mode);  		*size = fill_textconv(textconv, df, &blob);  		free_filespec(df);  	} else { -		blob = read_sha1_file(sha1, &type, size); +		blob = read_sha1_file(oid->hash, &type, size);  		if (type != OBJ_BLOB) -			die("object '%s' is not a blob!", sha1_to_hex(sha1)); +			die("object '%s' is not a blob!", oid_to_hex(oid));  	}  	return blob;  } @@ -389,7 +389,7 @@ static void consume_line(void *state_, char *line, unsigned long len)  	}  } -static void combine_diff(const unsigned char *parent, unsigned int mode, +static void combine_diff(const struct object_id *parent, unsigned int mode,  			 mmfile_t *result_file,  			 struct sline *sline, unsigned int cnt, int n,  			 int num_parent, int result_deleted, @@ -422,7 +422,7 @@ static void combine_diff(const unsigned char *parent, unsigned int mode,  	if (xdi_diff_outf(&parent_file, result_file, consume_line, &state,  			  &xpp, &xecfg))  		die("unable to generate combined diff for %s", -		    sha1_to_hex(parent)); +		    oid_to_hex(parent));  	free(parent_file.ptr);  	/* Assign line numbers for this parent. @@ -899,7 +899,7 @@ static void show_combined_header(struct combine_diff_path *elem,  				 int show_file_header)  {  	struct diff_options *opt = &rev->diffopt; -	int abbrev = DIFF_OPT_TST(opt, FULL_INDEX) ? 40 : DEFAULT_ABBREV; +	int abbrev = DIFF_OPT_TST(opt, FULL_INDEX) ? GIT_SHA1_HEXSZ : DEFAULT_ABBREV;  	const char *a_prefix = opt->a_prefix ? opt->a_prefix : "a/";  	const char *b_prefix = opt->b_prefix ? opt->b_prefix : "b/";  	const char *c_meta = diff_get_color_opt(opt, DIFF_METAINFO); @@ -916,11 +916,11 @@ static void show_combined_header(struct combine_diff_path *elem,  			 "", elem->path, line_prefix, c_meta, c_reset);  	printf("%s%sindex ", line_prefix, c_meta);  	for (i = 0; i < num_parent; i++) { -		abb = find_unique_abbrev(elem->parent[i].sha1, +		abb = find_unique_abbrev(elem->parent[i].oid.hash,  					 abbrev);  		printf("%s%s", i ? "," : "", abb);  	} -	abb = find_unique_abbrev(elem->sha1, abbrev); +	abb = find_unique_abbrev(elem->oid.hash, abbrev);  	printf("..%s%s\n", abb, c_reset);  	if (mode_differs) { @@ -993,7 +993,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  	/* Read the result of merge first */  	if (!working_tree_file) -		result = grab_blob(elem->sha1, elem->mode, &result_size, +		result = grab_blob(&elem->oid, elem->mode, &result_size,  				   textconv, elem->path);  	else {  		/* Used by diff-tree to read from the working tree */ @@ -1015,12 +1015,12 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  			result = strbuf_detach(&buf, NULL);  			elem->mode = canon_mode(st.st_mode);  		} else if (S_ISDIR(st.st_mode)) { -			unsigned char sha1[20]; -			if (resolve_gitlink_ref(elem->path, "HEAD", sha1) < 0) -				result = grab_blob(elem->sha1, elem->mode, +			struct object_id oid; +			if (resolve_gitlink_ref(elem->path, "HEAD", oid.hash) < 0) +				result = grab_blob(&elem->oid, elem->mode,  						   &result_size, NULL, NULL);  			else -				result = grab_blob(sha1, elem->mode, +				result = grab_blob(&oid, elem->mode,  						   &result_size, NULL, NULL);  		} else if (textconv) {  			struct diff_filespec *df = alloc_filespec(elem->path); @@ -1092,7 +1092,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  		for (i = 0; !is_binary && i < num_parent; i++) {  			char *buf;  			unsigned long size; -			buf = grab_blob(elem->parent[i].sha1, +			buf = grab_blob(&elem->parent[i].oid,  					elem->parent[i].mode,  					&size, NULL, NULL);  			if (buffer_is_binary(buf, size)) @@ -1141,14 +1141,14 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  	for (i = 0; i < num_parent; i++) {  		int j;  		for (j = 0; j < i; j++) { -			if (!hashcmp(elem->parent[i].sha1, -				     elem->parent[j].sha1)) { +			if (!oidcmp(&elem->parent[i].oid, +				     &elem->parent[j].oid)) {  				reuse_combine_diff(sline, cnt, i, j);  				break;  			}  		}  		if (i <= j) -			combine_diff(elem->parent[i].sha1, +			combine_diff(&elem->parent[i].oid,  				     elem->parent[i].mode,  				     &result_file, sline,  				     cnt, i, num_parent, result_deleted, @@ -1208,9 +1208,9 @@ static void show_raw_diff(struct combine_diff_path *p, int num_parent, struct re  		/* Show sha1's */  		for (i = 0; i < num_parent; i++) -			printf(" %s", diff_unique_abbrev(p->parent[i].sha1, +			printf(" %s", diff_unique_abbrev(p->parent[i].oid.hash,  							 opt->abbrev)); -		printf(" %s ", diff_unique_abbrev(p->sha1, opt->abbrev)); +		printf(" %s ", diff_unique_abbrev(p->oid.hash, opt->abbrev));  	}  	if (opt->output_format & (DIFF_FORMAT_RAW | DIFF_FORMAT_NAME_STATUS)) { @@ -1273,16 +1273,16 @@ static struct diff_filepair *combined_pair(struct combine_diff_path *p,  	for (i = 0; i < num_parent; i++) {  		pair->one[i].path = p->path;  		pair->one[i].mode = p->parent[i].mode; -		hashcpy(pair->one[i].sha1, p->parent[i].sha1); -		pair->one[i].sha1_valid = !is_null_sha1(p->parent[i].sha1); +		hashcpy(pair->one[i].sha1, p->parent[i].oid.hash); +		pair->one[i].sha1_valid = !is_null_oid(&p->parent[i].oid);  		pair->one[i].has_more_entries = 1;  	}  	pair->one[num_parent - 1].has_more_entries = 0;  	pair->two->path = p->path;  	pair->two->mode = p->mode; -	hashcpy(pair->two->sha1, p->sha1); -	pair->two->sha1_valid = !is_null_sha1(p->sha1); +	hashcpy(pair->two->sha1, p->oid.hash); +	pair->two->sha1_valid = !is_null_oid(&p->oid);  	return pair;  }  | 
