Merge branch 'lt/objalloc'

* 'lt/objalloc':
  Clean up object creation to use more common code
  Use proper object allocators for unknown object nodes too
This commit is contained in:
Junio C Hamano 2007-04-21 17:41:40 -07:00
commit 42c4b58059
8 changed files with 43 additions and 59 deletions

30
alloc.c
View File

@ -18,26 +18,38 @@
#define BLOCKING 1024 #define BLOCKING 1024
#define DEFINE_ALLOCATOR(name) \ #define DEFINE_ALLOCATOR(name, type) \
static unsigned int name##_allocs; \ static unsigned int name##_allocs; \
struct name *alloc_##name##_node(void) \ void *alloc_##name##_node(void) \
{ \ { \
static int nr; \ static int nr; \
static struct name *block; \ static type *block; \
void *ret; \
\ \
if (!nr) { \ if (!nr) { \
nr = BLOCKING; \ nr = BLOCKING; \
block = xcalloc(BLOCKING, sizeof(struct name)); \ block = xmalloc(BLOCKING * sizeof(type)); \
} \ } \
nr--; \ nr--; \
name##_allocs++; \ name##_allocs++; \
return block++; \ ret = block++; \
memset(ret, 0, sizeof(type)); \
return ret; \
} }
DEFINE_ALLOCATOR(blob) union any_object {
DEFINE_ALLOCATOR(tree) struct object object;
DEFINE_ALLOCATOR(commit) struct blob blob;
DEFINE_ALLOCATOR(tag) struct tree tree;
struct commit commit;
struct tag tag;
};
DEFINE_ALLOCATOR(blob, struct blob)
DEFINE_ALLOCATOR(tree, struct tree)
DEFINE_ALLOCATOR(commit, struct commit)
DEFINE_ALLOCATOR(tag, struct tag)
DEFINE_ALLOCATOR(object, union any_object)
#ifdef NO_C99_FORMAT #ifdef NO_C99_FORMAT
#define SZ_FMT "%u" #define SZ_FMT "%u"

8
blob.c
View File

@ -6,12 +6,8 @@ const char *blob_type = "blob";
struct blob *lookup_blob(const unsigned char *sha1) struct blob *lookup_blob(const unsigned char *sha1)
{ {
struct object *obj = lookup_object(sha1); struct object *obj = lookup_object(sha1);
if (!obj) { if (!obj)
struct blob *ret = alloc_blob_node(); return create_object(sha1, OBJ_BLOB, alloc_blob_node());
created_object(sha1, &ret->object);
ret->object.type = OBJ_BLOB;
return ret;
}
if (!obj->type) if (!obj->type)
obj->type = OBJ_BLOB; obj->type = OBJ_BLOB;
if (obj->type != OBJ_BLOB) { if (obj->type != OBJ_BLOB) {

13
cache.h
View File

@ -499,14 +499,11 @@ int decode_85(char *dst, const char *line, int linelen);
void encode_85(char *buf, const unsigned char *data, int bytes); void encode_85(char *buf, const unsigned char *data, int bytes);
/* alloc.c */ /* alloc.c */
struct blob; extern void *alloc_blob_node(void);
struct tree; extern void *alloc_tree_node(void);
struct commit; extern void *alloc_commit_node(void);
struct tag; extern void *alloc_tag_node(void);
extern struct blob *alloc_blob_node(void); extern void *alloc_object_node(void);
extern struct tree *alloc_tree_node(void);
extern struct commit *alloc_commit_node(void);
extern struct tag *alloc_tag_node(void);
extern void alloc_report(void); extern void alloc_report(void);
/* trace.c */ /* trace.c */

View File

@ -98,12 +98,8 @@ struct commit *lookup_commit_reference(const unsigned char *sha1)
struct commit *lookup_commit(const unsigned char *sha1) struct commit *lookup_commit(const unsigned char *sha1)
{ {
struct object *obj = lookup_object(sha1); struct object *obj = lookup_object(sha1);
if (!obj) { if (!obj)
struct commit *ret = alloc_commit_node(); return create_object(sha1, OBJ_COMMIT, alloc_commit_node());
created_object(sha1, &ret->object);
ret->object.type = OBJ_COMMIT;
return ret;
}
if (!obj->type) if (!obj->type)
obj->type = OBJ_COMMIT; obj->type = OBJ_COMMIT;
return check_commit(obj, sha1, 0); return check_commit(obj, sha1, 0);

View File

@ -105,11 +105,13 @@ static void grow_object_hash(void)
obj_hash_size = new_hash_size; obj_hash_size = new_hash_size;
} }
void created_object(const unsigned char *sha1, struct object *obj) void *create_object(const unsigned char *sha1, int type, void *o)
{ {
struct object *obj = o;
obj->parsed = 0; obj->parsed = 0;
obj->used = 0; obj->used = 0;
obj->type = OBJ_NONE; obj->type = type;
obj->flags = 0; obj->flags = 0;
hashcpy(obj->sha1, sha1); hashcpy(obj->sha1, sha1);
@ -118,25 +120,14 @@ void created_object(const unsigned char *sha1, struct object *obj)
insert_obj_hash(obj, obj_hash, obj_hash_size); insert_obj_hash(obj, obj_hash, obj_hash_size);
nr_objs++; nr_objs++;
return obj;
} }
union any_object {
struct object object;
struct commit commit;
struct tree tree;
struct blob blob;
struct tag tag;
};
struct object *lookup_unknown_object(const unsigned char *sha1) struct object *lookup_unknown_object(const unsigned char *sha1)
{ {
struct object *obj = lookup_object(sha1); struct object *obj = lookup_object(sha1);
if (!obj) { if (!obj)
union any_object *ret = xcalloc(1, sizeof(*ret)); obj = create_object(sha1, OBJ_NONE, alloc_object_node());
created_object(sha1, &ret->object);
ret->object.type = OBJ_NONE;
return &ret->object;
}
return obj; return obj;
} }

View File

@ -46,7 +46,7 @@ extern struct object_refs *lookup_object_refs(struct object *);
/** Internal only **/ /** Internal only **/
struct object *lookup_object(const unsigned char *sha1); struct object *lookup_object(const unsigned char *sha1);
void created_object(const unsigned char *sha1, struct object *obj); extern void *create_object(const unsigned char *sha1, int type, void *obj);
/** Returns the object, having parsed it to find out what it is. **/ /** Returns the object, having parsed it to find out what it is. **/
struct object *parse_object(const unsigned char *sha1); struct object *parse_object(const unsigned char *sha1);

8
tag.c
View File

@ -21,12 +21,8 @@ struct object *deref_tag(struct object *o, const char *warn, int warnlen)
struct tag *lookup_tag(const unsigned char *sha1) struct tag *lookup_tag(const unsigned char *sha1)
{ {
struct object *obj = lookup_object(sha1); struct object *obj = lookup_object(sha1);
if (!obj) { if (!obj)
struct tag *ret = alloc_tag_node(); return create_object(sha1, OBJ_TAG, alloc_tag_node());
created_object(sha1, &ret->object);
ret->object.type = OBJ_TAG;
return ret;
}
if (!obj->type) if (!obj->type)
obj->type = OBJ_TAG; obj->type = OBJ_TAG;
if (obj->type != OBJ_TAG) { if (obj->type != OBJ_TAG) {

8
tree.c
View File

@ -127,12 +127,8 @@ int read_tree(struct tree *tree, int stage, const char **match)
struct tree *lookup_tree(const unsigned char *sha1) struct tree *lookup_tree(const unsigned char *sha1)
{ {
struct object *obj = lookup_object(sha1); struct object *obj = lookup_object(sha1);
if (!obj) { if (!obj)
struct tree *ret = alloc_tree_node(); return create_object(sha1, OBJ_TREE, alloc_tree_node());
created_object(sha1, &ret->object);
ret->object.type = OBJ_TREE;
return ret;
}
if (!obj->type) if (!obj->type)
obj->type = OBJ_TREE; obj->type = OBJ_TREE;
if (obj->type != OBJ_TREE) { if (obj->type != OBJ_TREE) {