diff options
| author | brian m. carlson <sandals@crustytoothpaste.net> | 2015-03-13 23:39:33 +0000 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2015-03-13 22:43:13 -0700 | 
| commit | 1ff57c13c54bc9d548178e012f77717f87f2655d (patch) | |
| tree | 60fc80edc5fe63b258d0da5c74a17eb1bdb8826a /combine-diff.c | |
| parent | fa33c3aae238c683b2b15989b9d7f88df19fa93d (diff) | |
| download | git-1ff57c13c54bc9d548178e012f77717f87f2655d.tar.gz | |
diff: convert struct combine_diff_path to object_id
Also, convert a constant to GIT_SHA1_HEXSZ.
Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'combine-diff.c')
| -rw-r--r-- | combine-diff.c | 56 | 
1 files changed, 28 insertions, 28 deletions
diff --git a/combine-diff.c b/combine-diff.c index 91edce58e1..8eb7278978 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, @@ -897,7 +897,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); @@ -914,11 +914,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) { @@ -991,7 +991,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 */ @@ -1013,12 +1013,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); @@ -1090,7 +1090,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)) @@ -1139,14 +1139,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, @@ -1206,9 +1206,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)) { @@ -1271,16 +1271,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;  }  | 
