diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-05-21 04:02:23 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-05-21 04:02:23 -0700 | 
| commit | 82c531b3b6d24040443ba739e150bc06ecc762ea (patch) | |
| tree | de6a17434e48ee7866941e2e5491d9cf4d9b96e1 /diff.c | |
| parent | 82e7ee7351d6e328294016d3b99825d8001abd24 (diff) | |
| parent | 9feeaa2bf39aed4a0148296f504f88b09b8901d4 (diff) | |
| download | git-82c531b3b6d24040443ba739e150bc06ecc762ea.tar.gz | |
Merge branch 'by/log-follow'
* by/log-follow:
  tests: rename duplicate t4205
  Make git log --follow find copies among unmodified files.
  Make diffcore_std only can run once before a diff_flush
  Add a macro DIFF_QUEUE_CLEAR.
Diffstat (limited to 'diff.c')
| -rw-r--r-- | diff.c | 21 | 
1 files changed, 13 insertions, 8 deletions
| @@ -2600,6 +2600,7 @@ static void run_checkdiff(struct diff_filepair *p, struct diff_options *o)  void diff_setup(struct diff_options *options)  {  	memset(options, 0, sizeof(*options)); +	memset(&diff_queued_diff, 0, sizeof(diff_queued_diff));  	options->file = stdout; @@ -3541,8 +3542,7 @@ int diff_flush_patch_id(struct diff_options *options, unsigned char *sha1)  		diff_free_filepair(q->queue[i]);  	free(q->queue); -	q->queue = NULL; -	q->nr = q->alloc = 0; +	DIFF_QUEUE_CLEAR(q);  	return result;  } @@ -3670,8 +3670,7 @@ void diff_flush(struct diff_options *options)  		diff_free_filepair(q->queue[i]);  free_queue:  	free(q->queue); -	q->queue = NULL; -	q->nr = q->alloc = 0; +	DIFF_QUEUE_CLEAR(q);  	if (options->close_file)  		fclose(options->file); @@ -3693,8 +3692,7 @@ static void diffcore_apply_filter(const char *filter)  	int i;  	struct diff_queue_struct *q = &diff_queued_diff;  	struct diff_queue_struct outq; -	outq.queue = NULL; -	outq.nr = outq.alloc = 0; +	DIFF_QUEUE_CLEAR(&outq);  	if (!filter)  		return; @@ -3762,8 +3760,7 @@ static void diffcore_skip_stat_unmatch(struct diff_options *diffopt)  	int i;  	struct diff_queue_struct *q = &diff_queued_diff;  	struct diff_queue_struct outq; -	outq.queue = NULL; -	outq.nr = outq.alloc = 0; +	DIFF_QUEUE_CLEAR(&outq);  	for (i = 0; i < q->nr; i++) {  		struct diff_filepair *p = q->queue[i]; @@ -3824,6 +3821,12 @@ void diffcore_fix_diff_index(struct diff_options *options)  void diffcore_std(struct diff_options *options)  { +	/* We never run this function more than one time, because the +	 * rename/copy detection logic can only run once. +	 */ +	if (diff_queued_diff.run) +		return; +  	if (options->skip_stat_unmatch)  		diffcore_skip_stat_unmatch(options);  	if (options->break_opt != -1) @@ -3843,6 +3846,8 @@ void diffcore_std(struct diff_options *options)  		DIFF_OPT_SET(options, HAS_CHANGES);  	else  		DIFF_OPT_CLR(options, HAS_CHANGES); + +	diff_queued_diff.run = 1;  }  int diff_result_code(struct diff_options *opt, int status) | 
