@ -6,30 +6,32 @@
#include "tag.h"
#include "tag.h"
struct object **objs;
struct object **objs;
int nr_objs;
static int nr_objs;
static int obj_allocs;
int obj_allocs;
int track_object_refs = 1;
int track_object_refs = 1;
static int hashtable_index(const unsigned char *sha1)
{
unsigned int i = *(unsigned int *)sha1;
return (int)(i % obj_allocs);
}
static int find_object(const unsigned char *sha1)
static int find_object(const unsigned char *sha1)
{
{
int first = 0, last = nr_objs;
int i = hashtable_index(sha1);
while (first < last) {
if (!objs)
int next = (first + last) / 2;
return -1;
struct object *obj = objs[next];
int cmp;
cmp = memcmp(sha1, obj->sha1, 20);
while (objs[i]) {
if (!cmp)
if (memcmp(sha1, objs[i]->sha1, 20) == 0)
return next;
return i;
if (cmp < 0) {
i++;
last = next;
if (i == obj_allocs)
continue;
i = 0;
}
}
first = next+1;
return -1 - i;
}
return -first-1;
}
}
struct object *lookup_object(const unsigned char *sha1)
struct object *lookup_object(const unsigned char *sha1)
@ -42,7 +44,7 @@ struct object *lookup_object(const unsigned char *sha1)
void created_object(const unsigned char *sha1, struct object *obj)
void created_object(const unsigned char *sha1, struct object *obj)
{
{
int pos = find_object(sha1);
int pos;
obj->parsed = 0;
obj->parsed = 0;
memcpy(obj->sha1, sha1, 20);
memcpy(obj->sha1, sha1, 20);
@ -50,18 +52,27 @@ void created_object(const unsigned char *sha1, struct object *obj)
obj->refs = NULL;
obj->refs = NULL;
obj->used = 0;
obj->used = 0;
if (pos >= 0)
if (obj_allocs - 1 <= nr_objs * 2) {
die("Inserting %s twice\n", sha1_to_hex(sha1));
int i, count = obj_allocs;
pos = -pos-1;
obj_allocs = (obj_allocs < 32 ? 32 : 2 * obj_allocs);
if (obj_allocs == nr_objs) {
obj_allocs = alloc_nr(obj_allocs);
objs = xrealloc(objs, obj_allocs * sizeof(struct object *));
objs = xrealloc(objs, obj_allocs * sizeof(struct object *));
memset(objs + count, 0, (obj_allocs - count)
* sizeof(struct object *));
for (i = 0; i < count; i++)
if (objs[i]) {
int j = find_object(objs[i]->sha1);
if (j != i) {
j = -1 - j;
objs[j] = objs[i];
objs[i] = NULL;
}
}
}
}
/* Insert it into the right place */
pos = find_object(sha1);
memmove(objs + pos + 1, objs + pos, (nr_objs - pos) *
if (pos >= 0)
sizeof(struct object *));
die("Inserting %s twice\n", sha1_to_hex(sha1));
pos = -pos-1;
objs[pos] = obj;
objs[pos] = obj;
nr_objs++;
nr_objs++;