mirror of
https://github.com/git/git.git
synced 2024-12-11 10:54:21 +08:00
3e4339e6f9
This shrinks "struct object" to the absolutely minimal size possible. It now contains /only/ the object flags and the SHA1 hash name of the object. The "refs" field, which is really needed only for fsck, is maintained in a separate hashed lookup-table, allowing all normal users to totally ignore it. This helps memory usage, although not as much as I hoped: it looks like the allocation overhead of malloc (and the alignment constraints in particular) means that while the structure size shrinks, the actual allocation overhead mostly does not. [ That said: memory usage is actually down, but not as much as it should be: I suspect just one of the object types actually ended up shrinking its effective allocation size. To get to the next level, we probably need specialized allocators that don't pad the allocation more than necessary. ] The separation makes for some code cleanup, though, and makes the ref tracking that fsck wants a clearly separate thing. Signed-off-by: Linus Torvalds <torvalds@osdl.org> Signed-off-by: Junio C Hamano <junkio@cox.net>
76 lines
1.9 KiB
C
76 lines
1.9 KiB
C
#ifndef OBJECT_H
|
|
#define OBJECT_H
|
|
|
|
struct object_list {
|
|
struct object *item;
|
|
struct object_list *next;
|
|
const char *name;
|
|
};
|
|
|
|
struct object_refs {
|
|
unsigned count;
|
|
struct object *base;
|
|
struct object *ref[FLEX_ARRAY]; /* more */
|
|
};
|
|
|
|
#define TYPE_BITS 3
|
|
#define FLAG_BITS 27
|
|
|
|
#define TYPE_NONE 0
|
|
#define TYPE_BLOB 1
|
|
#define TYPE_TREE 2
|
|
#define TYPE_COMMIT 3
|
|
#define TYPE_TAG 4
|
|
#define TYPE_BAD 5
|
|
|
|
struct object {
|
|
unsigned parsed : 1;
|
|
unsigned used : 1;
|
|
unsigned type : TYPE_BITS;
|
|
unsigned flags : FLAG_BITS;
|
|
unsigned char sha1[20];
|
|
};
|
|
|
|
extern int track_object_refs;
|
|
extern int obj_allocs;
|
|
extern struct object **objs;
|
|
extern const char *type_names[];
|
|
|
|
static inline const char *typename(unsigned int type)
|
|
{
|
|
return type_names[type > TYPE_TAG ? TYPE_BAD : type];
|
|
}
|
|
|
|
extern struct object_refs *lookup_object_refs(struct object *);
|
|
|
|
/** Internal only **/
|
|
struct object *lookup_object(const unsigned char *sha1);
|
|
|
|
/** Returns the object, having looked it up as being the given type. **/
|
|
struct object *lookup_object_type(const unsigned char *sha1, const char *type);
|
|
|
|
void created_object(const unsigned char *sha1, struct object *obj);
|
|
|
|
/** Returns the object, having parsed it to find out what it is. **/
|
|
struct object *parse_object(const unsigned char *sha1);
|
|
|
|
/** Returns the object, with potentially excess memory allocated. **/
|
|
struct object *lookup_unknown_object(const unsigned char *sha1);
|
|
|
|
struct object_refs *alloc_object_refs(unsigned count);
|
|
void set_object_refs(struct object *obj, struct object_refs *refs);
|
|
|
|
void mark_reachable(struct object *obj, unsigned int mask);
|
|
|
|
struct object_list *object_list_insert(struct object *item,
|
|
struct object_list **list_p);
|
|
|
|
void object_list_append(struct object *item,
|
|
struct object_list **list_p);
|
|
|
|
unsigned object_list_length(struct object_list *list);
|
|
|
|
int object_list_contains(struct object_list *list, struct object *obj);
|
|
|
|
#endif /* OBJECT_H */
|