diff options
| -rw-r--r-- | object.c | 14 | 
1 files changed, 12 insertions, 2 deletions
| @@ -71,13 +71,13 @@ static unsigned int hashtable_index(const unsigned char *sha1)  struct object *lookup_object(const unsigned char *sha1)  { -	unsigned int i; +	unsigned int i, first;  	struct object *obj;  	if (!obj_hash)  		return NULL; -	i = hashtable_index(sha1); +	first = i = hashtable_index(sha1);  	while ((obj = obj_hash[i]) != NULL) {  		if (!hashcmp(sha1, obj->sha1))  			break; @@ -85,6 +85,16 @@ struct object *lookup_object(const unsigned char *sha1)  		if (i == obj_hash_size)  			i = 0;  	} +	if (obj && i != first) { +		/* +		 * Move object to where we started to look for it so +		 * that we do not need to walk the hash table the next +		 * time we look for it. +		 */ +		struct object *tmp = obj_hash[i]; +		obj_hash[i] = obj_hash[first]; +		obj_hash[first] = tmp; +	}  	return obj;  } | 
