diff options
| author | David Rientjes <rientjes@google.com> | 2006-08-17 11:54:57 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-08-17 14:23:53 -0700 | 
| commit | a89fccd28197fa179828c8596791ff16e2268d20 (patch) | |
| tree | 4a6c2b256a986fc221c0e1d5fa7d910f3b31eee8 /pack-redundant.c | |
| parent | d4baf9eaf47ea1ba204f1ab5ecd22326913dd081 (diff) | |
| download | git-a89fccd28197fa179828c8596791ff16e2268d20.tar.gz | |
Do not use memcmp(sha1_1, sha1_2, 20) with hardcoded length.
Introduces global inline:
	hashcmp(const unsigned char *sha1, const unsigned char *sha2)
Uses memcmp for comparison and returns the result based on the length of
the hash name (a future runtime decision).
Acked-by: Alex Riesen <raa.lkml@gmail.com>
Signed-off-by: David Rientjes <rientjes@google.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'pack-redundant.c')
| -rw-r--r-- | pack-redundant.c | 14 | 
1 files changed, 7 insertions, 7 deletions
| diff --git a/pack-redundant.c b/pack-redundant.c index 92a09ed362..edb5524fc4 100644 --- a/pack-redundant.c +++ b/pack-redundant.c @@ -139,7 +139,7 @@ static inline struct llist_item *llist_insert_sorted_unique(struct llist *list,  	l = (hint == NULL) ? list->front : hint;  	while (l) { -		int cmp = memcmp(l->sha1, sha1, 20); +		int cmp = hashcmp(l->sha1, sha1);  		if (cmp > 0) { /* we insert before this entry */  			return llist_insert(list, prev, sha1);  		} @@ -162,7 +162,7 @@ redo_from_start:  	l = (hint == NULL) ? list->front : hint;  	prev = NULL;  	while (l) { -		int cmp = memcmp(l->sha1, sha1, 20); +		int cmp = hashcmp(l->sha1, sha1);  		if (cmp > 0) /* not in list, since sorted */  			return prev;  		if(!cmp) { /* found */ @@ -256,7 +256,7 @@ static void cmp_two_packs(struct pack_list *p1, struct pack_list *p2)  	while (p1_off <= p1->pack->index_size - 3 * 20 &&  	       p2_off <= p2->pack->index_size - 3 * 20)  	{ -		int cmp = memcmp(p1_base + p1_off, p2_base + p2_off, 20); +		int cmp = hashcmp(p1_base + p1_off, p2_base + p2_off);  		/* cmp ~ p1 - p2 */  		if (cmp == 0) {  			p1_hint = llist_sorted_remove(p1->unique_objects, @@ -351,16 +351,16 @@ static size_t sizeof_union(struct packed_git *p1, struct packed_git *p2)  {  	size_t ret = 0;  	int p1_off, p2_off; -	char *p1_base, *p2_base; +	unsigned char *p1_base, *p2_base;  	p1_off = p2_off = 256 * 4 + 4; -	p1_base = (char *)p1->index_base; -	p2_base = (char *)p2->index_base; +	p1_base = (unsigned char *)p1->index_base; +	p2_base = (unsigned char *)p2->index_base;  	while (p1_off <= p1->index_size - 3 * 20 &&  	       p2_off <= p2->index_size - 3 * 20)  	{ -		int cmp = memcmp(p1_base + p1_off, p2_base + p2_off, 20); +		int cmp = hashcmp(p1_base + p1_off, p2_base + p2_off);  		/* cmp ~ p1 - p2 */  		if (cmp == 0) {  			ret++; | 
