Merge branch 'jc/cache-tree' into next
* jc/cache-tree: fsck-objects: mark objects reachable from cache-tree cache-tree: replace a sscanf() by two strtol() calls
This commit is contained in:
commit
f5196dbb25
11
cache-tree.c
11
cache-tree.c
@ -440,6 +440,8 @@ static struct cache_tree *read_one(const char **buffer, unsigned long *size_p)
|
|||||||
{
|
{
|
||||||
const char *buf = *buffer;
|
const char *buf = *buffer;
|
||||||
unsigned long size = *size_p;
|
unsigned long size = *size_p;
|
||||||
|
const char *cp;
|
||||||
|
char *ep;
|
||||||
struct cache_tree *it;
|
struct cache_tree *it;
|
||||||
int i, subtree_nr;
|
int i, subtree_nr;
|
||||||
|
|
||||||
@ -453,7 +455,14 @@ static struct cache_tree *read_one(const char **buffer, unsigned long *size_p)
|
|||||||
goto free_return;
|
goto free_return;
|
||||||
buf++; size--;
|
buf++; size--;
|
||||||
it = cache_tree();
|
it = cache_tree();
|
||||||
if (sscanf(buf, "%d %d\n", &it->entry_count, &subtree_nr) != 2)
|
|
||||||
|
cp = buf;
|
||||||
|
it->entry_count = strtol(cp, &ep, 10);
|
||||||
|
if (cp == ep)
|
||||||
|
goto free_return;
|
||||||
|
cp = ep;
|
||||||
|
subtree_nr = strtol(cp, &ep, 10);
|
||||||
|
if (cp == ep)
|
||||||
goto free_return;
|
goto free_return;
|
||||||
while (size && *buf && *buf != '\n') {
|
while (size && *buf && *buf != '\n') {
|
||||||
size--;
|
size--;
|
||||||
|
@ -446,6 +446,8 @@ static int fsck_cache_tree(struct cache_tree *it)
|
|||||||
|
|
||||||
if (0 <= it->entry_count) {
|
if (0 <= it->entry_count) {
|
||||||
struct object *obj = parse_object(it->sha1);
|
struct object *obj = parse_object(it->sha1);
|
||||||
|
mark_reachable(obj, REACHABLE);
|
||||||
|
obj->used = 1;
|
||||||
if (obj->type != tree_type)
|
if (obj->type != tree_type)
|
||||||
err |= objerror(obj, "non-tree in cache-tree");
|
err |= objerror(obj, "non-tree in cache-tree");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user