10 static int obj_allocs
;
12 static int find_object(const unsigned char *sha1
)
14 int first
= 0, last
= nr_objs
;
16 while (first
< last
) {
17 int next
= (first
+ last
) / 2;
18 struct object
*obj
= objs
[next
];
21 cmp
= memcmp(sha1
, obj
->sha1
, 20);
33 struct object
*lookup_object(const unsigned char *sha1
)
35 int pos
= find_object(sha1
);
41 void created_object(const unsigned char *sha1
, struct object
*obj
)
43 int pos
= find_object(sha1
);
46 memcpy(obj
->sha1
, sha1
, 20);
52 die("Inserting %s twice\n", sha1_to_hex(sha1
));
55 if (obj_allocs
== nr_objs
) {
56 obj_allocs
= alloc_nr(obj_allocs
);
57 objs
= xrealloc(objs
, obj_allocs
* sizeof(struct object
*));
60 /* Insert it into the right place */
61 memmove(objs
+ pos
+ 1, objs
+ pos
, (nr_objs
- pos
) *
62 sizeof(struct object
*));
68 void add_ref(struct object
*refer
, struct object
*target
)
70 struct object_list
**pp
= &refer
->refs
;
71 struct object_list
*p
;
73 while ((p
= *pp
) != NULL
) {
74 if (p
->item
== target
)
80 p
= xmalloc(sizeof(*p
));
86 void mark_reachable(struct object
*obj
, unsigned int mask
)
88 struct object_list
*p
= obj
->refs
;
90 /* If we've been here already, don't bother */
91 if (obj
->flags
& mask
)
95 mark_reachable(p
->item
, mask
);
100 struct object
*lookup_object_type(const unsigned char *sha1
, const char *type
)
102 if (!strcmp(type
, blob_type
)) {
103 return &lookup_blob(sha1
)->object
;
104 } else if (!strcmp(type
, tree_type
)) {
105 return &lookup_tree(sha1
)->object
;
106 } else if (!strcmp(type
, commit_type
)) {
107 return &lookup_commit(sha1
)->object
;
108 } else if (!strcmp(type
, tag_type
)) {
109 return &lookup_tag(sha1
)->object
;
111 error("Unknown type %s", type
);
116 struct object
*parse_object(const unsigned char *sha1
)
120 void *buffer
= read_sha1_file(sha1
, type
, &size
);
123 if (check_sha1_signature(sha1
, buffer
, size
, type
) < 0)
124 printf("sha1 mismatch %s\n", sha1_to_hex(sha1
));
125 if (!strcmp(type
, "blob")) {
126 struct blob
*blob
= lookup_blob(sha1
);
127 parse_blob_buffer(blob
, buffer
, size
);
129 } else if (!strcmp(type
, "tree")) {
130 struct tree
*tree
= lookup_tree(sha1
);
131 parse_tree_buffer(tree
, buffer
, size
);
133 } else if (!strcmp(type
, "commit")) {
134 struct commit
*commit
= lookup_commit(sha1
);
135 parse_commit_buffer(commit
, buffer
, size
);
136 if (!commit
->buffer
) {
137 commit
->buffer
= buffer
;
140 obj
= &commit
->object
;
141 } else if (!strcmp(type
, "tag")) {
142 struct tag
*tag
= lookup_tag(sha1
);
143 parse_tag_buffer(tag
, buffer
, size
);