diff options
Diffstat (limited to 'combine-diff.c')
| -rw-r--r-- | combine-diff.c | 88 | 
1 files changed, 42 insertions, 46 deletions
| diff --git a/combine-diff.c b/combine-diff.c index 5cae5fbd62..0e1d4b0893 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; @@ -189,11 +189,11 @@ static struct lline *coalesce_lines(struct lline *base, int *lenbase,  	 *   - Else if we have NEW, insert newend lline into base and  	 *   consume newend  	 */ -	lcs = xcalloc(origbaselen + 1, sizeof(int*)); -	directions = xcalloc(origbaselen + 1, sizeof(enum coalesce_direction*)); +	lcs = xcalloc(st_add(origbaselen, 1), sizeof(int*)); +	directions = xcalloc(st_add(origbaselen, 1), sizeof(enum coalesce_direction*));  	for (i = 0; i < origbaselen + 1; i++) { -		lcs[i] = xcalloc(lennew + 1, sizeof(int)); -		directions[i] = xcalloc(lennew + 1, sizeof(enum coalesce_direction)); +		lcs[i] = xcalloc(st_add(lennew, 1), sizeof(int)); +		directions[i] = xcalloc(st_add(lennew, 1), sizeof(enum coalesce_direction));  		directions[i][0] = BASE;  	}  	for (j = 1; j < lennew + 1; j++) @@ -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;  } @@ -319,7 +319,7 @@ static void append_lost(struct sline *sline, int n, const char *line, int len)  	if (line[len-1] == '\n')  		len--; -	lline = xmalloc(sizeof(*lline) + len + 1); +	FLEX_ALLOC_MEM(lline, line, line, len);  	lline->len = len;  	lline->next = NULL;  	lline->prev = sline->plost.lost_tail; @@ -330,8 +330,6 @@ static void append_lost(struct sline *sline, int n, const char *line, int len)  	sline->plost.lost_tail = lline;  	sline->plost.len++;  	lline->parent_map = this_mask; -	memcpy(lline->line, line, len); -	lline->line[len] = 0;  }  struct combine_diff_state { @@ -389,7 +387,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 +420,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 +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); @@ -916,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) { @@ -993,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 */ @@ -1015,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); @@ -1043,7 +1041,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  				elem->mode = canon_mode(S_IFLNK);  			result_size = len; -			result = xmalloc(len + 1); +			result = xmallocz(len);  			done = read_in_full(fd, result, len);  			if (done < 0) @@ -1051,8 +1049,6 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  			else if (done < len)  				die("early EOF '%s'", elem->path); -			result[len] = 0; -  			/* If not a fake symlink, apply filters, e.g. autocrlf */  			if (is_file) {  				struct strbuf buf = STRBUF_INIT; @@ -1092,7 +1088,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)) @@ -1115,7 +1111,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  	if (result_size && result[result_size-1] != '\n')  		cnt++; /* incomplete line */ -	sline = xcalloc(cnt+2, sizeof(*sline)); +	sline = xcalloc(st_add(cnt, 2), sizeof(*sline));  	sline[0].bol = result;  	for (lno = 0, cp = result; cp < result + result_size; cp++) {  		if (*cp == '\n') { @@ -1134,21 +1130,21 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,  	/* Even p_lno[cnt+1] is valid -- that is for the end line number  	 * for deletion hunk at the end.  	 */ -	sline[0].p_lno = xcalloc((cnt+2) * num_parent, sizeof(unsigned long)); +	sline[0].p_lno = xcalloc(st_mult(st_add(cnt, 2), num_parent), sizeof(unsigned long));  	for (lno = 0; lno <= cnt; lno++)  		sline[lno+1].p_lno = sline[lno].p_lno + 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 +1204,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)) { @@ -1266,23 +1262,23 @@ static struct diff_filepair *combined_pair(struct combine_diff_path *p,  	struct diff_filespec *pool;  	pair = xmalloc(sizeof(*pair)); -	pool = xcalloc(num_parent + 1, sizeof(struct diff_filespec)); +	pool = xcalloc(st_add(num_parent, 1), sizeof(struct diff_filespec));  	pair->one = pool + 1;  	pair->two = pool;  	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;  } @@ -1372,7 +1368,7 @@ static struct combine_diff_path *find_paths_multitree(  	struct combine_diff_path paths_head;  	struct strbuf base; -	parents_sha1 = xmalloc(nparent * sizeof(parents_sha1[0])); +	ALLOC_ARRAY(parents_sha1, nparent);  	for (i = 0; i < nparent; i++)  		parents_sha1[i] = parents->sha1[i]; @@ -1483,7 +1479,7 @@ void diff_tree_combined(const unsigned char *sha1,  	if (opt->orderfile && num_paths) {  		struct obj_order *o; -		o = xmalloc(sizeof(*o) * num_paths); +		ALLOC_ARRAY(o, num_paths);  		for (i = 0, p = paths; p; p = p->next, i++)  			o[i].obj = p;  		order_objects(opt->orderfile, path_path, o, num_paths); @@ -1540,9 +1536,9 @@ void diff_tree_combined_merge(const struct commit *commit, int dense,  	struct sha1_array parents = SHA1_ARRAY_INIT;  	while (parent) { -		sha1_array_append(&parents, parent->item->object.sha1); +		sha1_array_append(&parents, parent->item->object.oid.hash);  		parent = parent->next;  	} -	diff_tree_combined(commit->object.sha1, &parents, dense, rev); +	diff_tree_combined(commit->object.oid.hash, &parents, dense, rev);  	sha1_array_clear(&parents);  } | 
