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:
commit
42c4b58059
30
alloc.c
30
alloc.c
@ -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
8
blob.c
@ -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
13
cache.h
@ -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 */
|
||||||
|
8
commit.c
8
commit.c
@ -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);
|
||||||
|
23
object.c
23
object.c
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
object.h
2
object.h
@ -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);
|
||||||
|
10
tag.c
10
tag.c
@ -20,13 +20,9 @@ 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
8
tree.c
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user