diff options
| author | Junio C Hamano <gitster@pobox.com> | 2008-07-08 00:19:17 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-07-08 00:19:17 -0700 | 
| commit | c636d0e2bcffdbd55c096944561d9ac470da600e (patch) | |
| tree | 92fccc512d3bf7a04cca3ad3067fd7c96fc2f783 /read-cache.c | |
| parent | 39f319f4d51966419c0725d1145677457d6f162a (diff) | |
| parent | f49c2c22fef520fd69ff26869c26dc58a834de2c (diff) | |
Merge branch 'lt/racy-empty' into maint
* lt/racy-empty:
  racy-git: an empty blob has a fixed object name
Diffstat (limited to 'read-cache.c')
| -rw-r--r-- | read-cache.c | 16 | 
1 files changed, 16 insertions, 0 deletions
| diff --git a/read-cache.c b/read-cache.c index 8e5fbb6192..f83de8c415 100644 --- a/read-cache.c +++ b/read-cache.c @@ -138,6 +138,16 @@ static int ce_modified_check_fs(struct cache_entry *ce, struct stat *st)  	return 0;  } +static int is_empty_blob_sha1(const unsigned char *sha1) +{ +	static const unsigned char empty_blob_sha1[20] = { +		0xe6,0x9d,0xe2,0x9b,0xb2,0xd1,0xd6,0x43,0x4b,0x8b, +		0x29,0xae,0x77,0x5a,0xd8,0xc2,0xe4,0x8c,0x53,0x91 +	}; + +	return !hashcmp(sha1, empty_blob_sha1); +} +  static int ce_match_stat_basic(struct cache_entry *ce, struct stat *st)  {  	unsigned int changed = 0; @@ -193,6 +203,12 @@ static int ce_match_stat_basic(struct cache_entry *ce, struct stat *st)  	if (ce->ce_size != (unsigned int) st->st_size)  		changed |= DATA_CHANGED; +	/* Racily smudged entry? */ +	if (!ce->ce_size) { +		if (!is_empty_blob_sha1(ce->sha1)) +			changed |= DATA_CHANGED; +	} +  	return changed;  } | 
