sha1-array: convert internal storage for struct sha1_array to object_id

Make the internal storage for struct sha1_array use an array of struct
object_id internally.  Update the users of this struct which inspect its
internals.

Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
brian m. carlson 2017-03-26 16:01:37 +00:00 committed by Junio C Hamano
parent f9b11147e0
commit ee3051bd23
11 changed files with 58 additions and 58 deletions

View File

@ -457,7 +457,7 @@ static char *join_sha1_array_hex(struct sha1_array *array, char delim)
int i; int i;
for (i = 0; i < array->nr; i++) { for (i = 0; i < array->nr; i++) {
strbuf_addstr(&joined_hexs, sha1_to_hex(array->sha1[i])); strbuf_addstr(&joined_hexs, oid_to_hex(array->oid + i));
if (i + 1 < array->nr) if (i + 1 < array->nr)
strbuf_addch(&joined_hexs, delim); strbuf_addch(&joined_hexs, delim);
} }
@ -621,7 +621,7 @@ static void bisect_rev_setup(struct rev_info *revs, const char *prefix,
argv_array_pushf(&rev_argv, bad_format, oid_to_hex(current_bad_oid)); argv_array_pushf(&rev_argv, bad_format, oid_to_hex(current_bad_oid));
for (i = 0; i < good_revs.nr; i++) for (i = 0; i < good_revs.nr; i++)
argv_array_pushf(&rev_argv, good_format, argv_array_pushf(&rev_argv, good_format,
sha1_to_hex(good_revs.sha1[i])); oid_to_hex(good_revs.oid + i));
argv_array_push(&rev_argv, "--"); argv_array_push(&rev_argv, "--");
if (read_paths) if (read_paths)
read_bisect_paths(&rev_argv); read_bisect_paths(&rev_argv);
@ -701,11 +701,11 @@ static int bisect_checkout(const unsigned char *bisect_rev, int no_checkout)
return run_command_v_opt(argv_show_branch, RUN_GIT_CMD); return run_command_v_opt(argv_show_branch, RUN_GIT_CMD);
} }
static struct commit *get_commit_reference(const unsigned char *sha1) static struct commit *get_commit_reference(const struct object_id *oid)
{ {
struct commit *r = lookup_commit_reference(sha1); struct commit *r = lookup_commit_reference(oid->hash);
if (!r) if (!r)
die(_("Not a valid commit name %s"), sha1_to_hex(sha1)); die(_("Not a valid commit name %s"), oid_to_hex(oid));
return r; return r;
} }
@ -715,9 +715,9 @@ static struct commit **get_bad_and_good_commits(int *rev_nr)
int i, n = 0; int i, n = 0;
ALLOC_ARRAY(rev, 1 + good_revs.nr); ALLOC_ARRAY(rev, 1 + good_revs.nr);
rev[n++] = get_commit_reference(current_bad_oid->hash); rev[n++] = get_commit_reference(current_bad_oid);
for (i = 0; i < good_revs.nr; i++) for (i = 0; i < good_revs.nr; i++)
rev[n++] = get_commit_reference(good_revs.sha1[i]); rev[n++] = get_commit_reference(good_revs.oid + i);
*rev_nr = n; *rev_nr = n;
return rev; return rev;

View File

@ -514,7 +514,7 @@ static int run_fetch(const char *repo, const char **refspecs)
/** /**
* "Pulls into void" by branching off merge_head. * "Pulls into void" by branching off merge_head.
*/ */
static int pull_into_void(const unsigned char *merge_head, static int pull_into_void(const struct object_id *merge_head,
const struct object_id *curr_head) const struct object_id *curr_head)
{ {
/* /*
@ -523,10 +523,10 @@ static int pull_into_void(const unsigned char *merge_head,
* index/worktree changes that the user already made on the unborn * index/worktree changes that the user already made on the unborn
* branch. * branch.
*/ */
if (checkout_fast_forward(EMPTY_TREE_SHA1_BIN, merge_head, 0)) if (checkout_fast_forward(EMPTY_TREE_SHA1_BIN, merge_head->hash, 0))
return 1; return 1;
if (update_ref("initial pull", "HEAD", merge_head, curr_head->hash, 0, UPDATE_REFS_DIE_ON_ERR)) if (update_ref("initial pull", "HEAD", merge_head->hash, curr_head->hash, 0, UPDATE_REFS_DIE_ON_ERR))
return 1; return 1;
return 0; return 0;
@ -693,13 +693,13 @@ cleanup:
*/ */
static int get_octopus_merge_base(struct object_id *merge_base, static int get_octopus_merge_base(struct object_id *merge_base,
const struct object_id *curr_head, const struct object_id *curr_head,
const unsigned char *merge_head, const struct object_id *merge_head,
const struct object_id *fork_point) const struct object_id *fork_point)
{ {
struct commit_list *revs = NULL, *result; struct commit_list *revs = NULL, *result;
commit_list_insert(lookup_commit_reference(curr_head->hash), &revs); commit_list_insert(lookup_commit_reference(curr_head->hash), &revs);
commit_list_insert(lookup_commit_reference(merge_head), &revs); commit_list_insert(lookup_commit_reference(merge_head->hash), &revs);
if (!is_null_oid(fork_point)) if (!is_null_oid(fork_point))
commit_list_insert(lookup_commit_reference(fork_point->hash), &revs); commit_list_insert(lookup_commit_reference(fork_point->hash), &revs);
@ -718,7 +718,7 @@ static int get_octopus_merge_base(struct object_id *merge_base,
* appropriate arguments and returns its exit status. * appropriate arguments and returns its exit status.
*/ */
static int run_rebase(const struct object_id *curr_head, static int run_rebase(const struct object_id *curr_head,
const unsigned char *merge_head, const struct object_id *merge_head,
const struct object_id *fork_point) const struct object_id *fork_point)
{ {
int ret; int ret;
@ -754,12 +754,12 @@ static int run_rebase(const struct object_id *curr_head,
warning(_("ignoring --verify-signatures for rebase")); warning(_("ignoring --verify-signatures for rebase"));
argv_array_push(&args, "--onto"); argv_array_push(&args, "--onto");
argv_array_push(&args, sha1_to_hex(merge_head)); argv_array_push(&args, oid_to_hex(merge_head));
if (fork_point && !is_null_oid(fork_point)) if (fork_point && !is_null_oid(fork_point))
argv_array_push(&args, oid_to_hex(fork_point)); argv_array_push(&args, oid_to_hex(fork_point));
else else
argv_array_push(&args, sha1_to_hex(merge_head)); argv_array_push(&args, oid_to_hex(merge_head));
ret = run_command_v_opt(args.argv, RUN_GIT_CMD); ret = run_command_v_opt(args.argv, RUN_GIT_CMD);
argv_array_clear(&args); argv_array_clear(&args);
@ -856,7 +856,7 @@ int cmd_pull(int argc, const char **argv, const char *prefix)
if (is_null_oid(&orig_head)) { if (is_null_oid(&orig_head)) {
if (merge_heads.nr > 1) if (merge_heads.nr > 1)
die(_("Cannot merge multiple branches into empty head.")); die(_("Cannot merge multiple branches into empty head."));
return pull_into_void(*merge_heads.sha1, &curr_head); return pull_into_void(merge_heads.oid, &curr_head);
} }
if (opt_rebase && merge_heads.nr > 1) if (opt_rebase && merge_heads.nr > 1)
die(_("Cannot rebase onto multiple branches.")); die(_("Cannot rebase onto multiple branches."));
@ -867,13 +867,13 @@ int cmd_pull(int argc, const char **argv, const char *prefix)
head = lookup_commit_reference(orig_head.hash); head = lookup_commit_reference(orig_head.hash);
commit_list_insert(head, &list); commit_list_insert(head, &list);
merge_head = lookup_commit_reference(merge_heads.sha1[0]); merge_head = lookup_commit_reference(merge_heads.oid[0].hash);
if (is_descendant_of(merge_head, list)) { if (is_descendant_of(merge_head, list)) {
/* we can fast-forward this without invoking rebase */ /* we can fast-forward this without invoking rebase */
opt_ff = "--ff-only"; opt_ff = "--ff-only";
return run_merge(); return run_merge();
} }
return run_rebase(&curr_head, *merge_heads.sha1, &rebase_fork_point); return run_rebase(&curr_head, merge_heads.oid, &rebase_fork_point);
} else { } else {
return run_merge(); return run_merge();
} }

View File

@ -842,7 +842,7 @@ static int update_shallow_ref(struct command *cmd, struct shallow_info *si)
if (si->used_shallow[i] && if (si->used_shallow[i] &&
(si->used_shallow[i][cmd->index / 32] & mask) && (si->used_shallow[i][cmd->index / 32] & mask) &&
!delayed_reachability_test(si, i)) !delayed_reachability_test(si, i))
sha1_array_append(&extra, si->shallow->sha1[i]); sha1_array_append(&extra, si->shallow->oid[i].hash);
opt.env = tmp_objdir_env(tmp_objdir); opt.env = tmp_objdir_env(tmp_objdir);
setup_alternate_shallow(&shallow_lock, &opt.shallow_file, &extra); setup_alternate_shallow(&shallow_lock, &opt.shallow_file, &extra);
@ -859,7 +859,7 @@ static int update_shallow_ref(struct command *cmd, struct shallow_info *si)
* not lose these new roots.. * not lose these new roots..
*/ */
for (i = 0; i < extra.nr; i++) for (i = 0; i < extra.nr; i++)
register_shallow(extra.sha1[i]); register_shallow(extra.oid[i].hash);
si->shallow_ref[cmd->index] = 0; si->shallow_ref[cmd->index] = 0;
sha1_array_clear(&extra); sha1_array_clear(&extra);

View File

@ -1335,7 +1335,7 @@ static struct combine_diff_path *find_paths_generic(const unsigned char *sha1,
opt->output_format = stat_opt; opt->output_format = stat_opt;
else else
opt->output_format = DIFF_FORMAT_NO_OUTPUT; opt->output_format = DIFF_FORMAT_NO_OUTPUT;
diff_tree_sha1(parents->sha1[i], sha1, "", opt); diff_tree_sha1(parents->oid[i].hash, sha1, "", opt);
diffcore_std(opt); diffcore_std(opt);
paths = intersect_paths(paths, i, num_parent); paths = intersect_paths(paths, i, num_parent);
@ -1369,7 +1369,7 @@ static struct combine_diff_path *find_paths_multitree(
ALLOC_ARRAY(parents_sha1, nparent); ALLOC_ARRAY(parents_sha1, nparent);
for (i = 0; i < nparent; i++) for (i = 0; i < nparent; i++)
parents_sha1[i] = parents->sha1[i]; parents_sha1[i] = parents->oid[i].hash;
/* fake list head, so worker can assume it is non-NULL */ /* fake list head, so worker can assume it is non-NULL */
paths_head.next = NULL; paths_head.next = NULL;
@ -1462,7 +1462,7 @@ void diff_tree_combined(const unsigned char *sha1,
if (stat_opt) { if (stat_opt) {
diffopts.output_format = stat_opt; diffopts.output_format = stat_opt;
diff_tree_sha1(parents->sha1[0], sha1, "", &diffopts); diff_tree_sha1(parents->oid[0].hash, sha1, "", &diffopts);
diffcore_std(&diffopts); diffcore_std(&diffopts);
if (opt->orderfile) if (opt->orderfile)
diffcore_order(opt->orderfile); diffcore_order(opt->orderfile);

View File

@ -1039,10 +1039,10 @@ static void update_shallow(struct fetch_pack_args *args,
* after get_pack() and reprepare_packed_git()) * after get_pack() and reprepare_packed_git())
*/ */
struct sha1_array extra = SHA1_ARRAY_INIT; struct sha1_array extra = SHA1_ARRAY_INIT;
unsigned char (*sha1)[20] = si->shallow->sha1; struct object_id *oid = si->shallow->oid;
for (i = 0; i < si->shallow->nr; i++) for (i = 0; i < si->shallow->nr; i++)
if (has_sha1_file(sha1[i])) if (has_object_file(&oid[i]))
sha1_array_append(&extra, sha1[i]); sha1_array_append(&extra, oid[i].hash);
if (extra.nr) { if (extra.nr) {
setup_alternate_shallow(&shallow_lock, setup_alternate_shallow(&shallow_lock,
&alternate_shallow_file, &alternate_shallow_file,
@ -1071,16 +1071,16 @@ static void update_shallow(struct fetch_pack_args *args,
* refs. * refs.
*/ */
struct sha1_array extra = SHA1_ARRAY_INIT; struct sha1_array extra = SHA1_ARRAY_INIT;
unsigned char (*sha1)[20] = si->shallow->sha1; struct object_id *oid = si->shallow->oid;
assign_shallow_commits_to_refs(si, NULL, NULL); assign_shallow_commits_to_refs(si, NULL, NULL);
if (!si->nr_ours && !si->nr_theirs) { if (!si->nr_ours && !si->nr_theirs) {
sha1_array_clear(&ref); sha1_array_clear(&ref);
return; return;
} }
for (i = 0; i < si->nr_ours; i++) for (i = 0; i < si->nr_ours; i++)
sha1_array_append(&extra, sha1[si->ours[i]]); sha1_array_append(&extra, oid[si->ours[i]].hash);
for (i = 0; i < si->nr_theirs; i++) for (i = 0; i < si->nr_theirs; i++)
sha1_array_append(&extra, sha1[si->theirs[i]]); sha1_array_append(&extra, oid[si->theirs[i]].hash);
setup_alternate_shallow(&shallow_lock, setup_alternate_shallow(&shallow_lock,
&alternate_shallow_file, &alternate_shallow_file,
&extra); &extra);

4
fsck.c
View File

@ -158,8 +158,8 @@ static void init_skiplist(struct fsck_options *options, const char *path)
die("Invalid SHA-1: %s", buffer); die("Invalid SHA-1: %s", buffer);
sha1_array_append(&skiplist, oid.hash); sha1_array_append(&skiplist, oid.hash);
if (sorted && skiplist.nr > 1 && if (sorted && skiplist.nr > 1 &&
hashcmp(skiplist.sha1[skiplist.nr - 2], oidcmp(&skiplist.oid[skiplist.nr - 2],
oid.hash) > 0) &oid) > 0)
sorted = 0; sorted = 0;
} }
close(fd); close(fd);

View File

@ -230,7 +230,7 @@ static void free_discovery(struct discovery *d)
if (d) { if (d) {
if (d == last_discovery) if (d == last_discovery)
last_discovery = NULL; last_discovery = NULL;
free(d->shallow.sha1); free(d->shallow.oid);
free(d->buf_alloc); free(d->buf_alloc);
free_refs(d->refs); free_refs(d->refs);
free(d); free(d);

View File

@ -98,7 +98,7 @@ static int pack_objects(int fd, struct ref *refs, struct sha1_array *extra, stru
*/ */
po_in = xfdopen(po.in, "w"); po_in = xfdopen(po.in, "w");
for (i = 0; i < extra->nr; i++) for (i = 0; i < extra->nr; i++)
feed_object(extra->sha1[i], po_in, 1); feed_object(extra->oid[i].hash, po_in, 1);
while (refs) { while (refs) {
if (!is_null_oid(&refs->old_oid)) if (!is_null_oid(&refs->old_oid))

View File

@ -4,39 +4,39 @@
void sha1_array_append(struct sha1_array *array, const unsigned char *sha1) void sha1_array_append(struct sha1_array *array, const unsigned char *sha1)
{ {
ALLOC_GROW(array->sha1, array->nr + 1, array->alloc); ALLOC_GROW(array->oid, array->nr + 1, array->alloc);
hashcpy(array->sha1[array->nr++], sha1); hashcpy(array->oid[array->nr++].hash, sha1);
array->sorted = 0; array->sorted = 0;
} }
static int void_hashcmp(const void *a, const void *b) static int void_hashcmp(const void *a, const void *b)
{ {
return hashcmp(a, b); return oidcmp(a, b);
} }
static void sha1_array_sort(struct sha1_array *array) static void sha1_array_sort(struct sha1_array *array)
{ {
QSORT(array->sha1, array->nr, void_hashcmp); QSORT(array->oid, array->nr, void_hashcmp);
array->sorted = 1; array->sorted = 1;
} }
static const unsigned char *sha1_access(size_t index, void *table) static const unsigned char *sha1_access(size_t index, void *table)
{ {
unsigned char (*array)[20] = table; struct object_id *array = table;
return array[index]; return array[index].hash;
} }
int sha1_array_lookup(struct sha1_array *array, const unsigned char *sha1) int sha1_array_lookup(struct sha1_array *array, const unsigned char *sha1)
{ {
if (!array->sorted) if (!array->sorted)
sha1_array_sort(array); sha1_array_sort(array);
return sha1_pos(sha1, array->sha1, array->nr, sha1_access); return sha1_pos(sha1, array->oid, array->nr, sha1_access);
} }
void sha1_array_clear(struct sha1_array *array) void sha1_array_clear(struct sha1_array *array)
{ {
free(array->sha1); free(array->oid);
array->sha1 = NULL; array->oid = NULL;
array->nr = 0; array->nr = 0;
array->alloc = 0; array->alloc = 0;
array->sorted = 0; array->sorted = 0;
@ -53,9 +53,9 @@ int sha1_array_for_each_unique(struct sha1_array *array,
for (i = 0; i < array->nr; i++) { for (i = 0; i < array->nr; i++) {
int ret; int ret;
if (i > 0 && !hashcmp(array->sha1[i], array->sha1[i-1])) if (i > 0 && !oidcmp(array->oid + i, array->oid + i - 1))
continue; continue;
ret = fn(array->sha1[i], data); ret = fn(array->oid[i].hash, data);
if (ret) if (ret)
return ret; return ret;
} }

View File

@ -2,7 +2,7 @@
#define SHA1_ARRAY_H #define SHA1_ARRAY_H
struct sha1_array { struct sha1_array {
unsigned char (*sha1)[20]; struct object_id *oid;
int nr; int nr;
int alloc; int alloc;
int sorted; int sorted;

View File

@ -273,7 +273,7 @@ static int write_shallow_commits_1(struct strbuf *out, int use_pack_protocol,
if (!extra) if (!extra)
return data.count; return data.count;
for (i = 0; i < extra->nr; i++) { for (i = 0; i < extra->nr; i++) {
strbuf_addstr(out, sha1_to_hex(extra->sha1[i])); strbuf_addstr(out, oid_to_hex(extra->oid + i));
strbuf_addch(out, '\n'); strbuf_addch(out, '\n');
data.count++; data.count++;
} }
@ -396,9 +396,9 @@ void prepare_shallow_info(struct shallow_info *info, struct sha1_array *sa)
ALLOC_ARRAY(info->ours, sa->nr); ALLOC_ARRAY(info->ours, sa->nr);
ALLOC_ARRAY(info->theirs, sa->nr); ALLOC_ARRAY(info->theirs, sa->nr);
for (i = 0; i < sa->nr; i++) { for (i = 0; i < sa->nr; i++) {
if (has_sha1_file(sa->sha1[i])) { if (has_object_file(sa->oid + i)) {
struct commit_graft *graft; struct commit_graft *graft;
graft = lookup_commit_graft(sa->sha1[i]); graft = lookup_commit_graft(sa->oid[i].hash);
if (graft && graft->nr_parent < 0) if (graft && graft->nr_parent < 0)
continue; continue;
info->ours[info->nr_ours++] = i; info->ours[info->nr_ours++] = i;
@ -417,13 +417,13 @@ void clear_shallow_info(struct shallow_info *info)
void remove_nonexistent_theirs_shallow(struct shallow_info *info) void remove_nonexistent_theirs_shallow(struct shallow_info *info)
{ {
unsigned char (*sha1)[20] = info->shallow->sha1; struct object_id *oid = info->shallow->oid;
int i, dst; int i, dst;
trace_printf_key(&trace_shallow, "shallow: remove_nonexistent_theirs_shallow\n"); trace_printf_key(&trace_shallow, "shallow: remove_nonexistent_theirs_shallow\n");
for (i = dst = 0; i < info->nr_theirs; i++) { for (i = dst = 0; i < info->nr_theirs; i++) {
if (i != dst) if (i != dst)
info->theirs[dst] = info->theirs[i]; info->theirs[dst] = info->theirs[i];
if (has_sha1_file(sha1[info->theirs[i]])) if (has_object_file(oid + info->theirs[i]))
dst++; dst++;
} }
info->nr_theirs = dst; info->nr_theirs = dst;
@ -559,7 +559,7 @@ static void post_assign_shallow(struct shallow_info *info,
void assign_shallow_commits_to_refs(struct shallow_info *info, void assign_shallow_commits_to_refs(struct shallow_info *info,
uint32_t **used, int *ref_status) uint32_t **used, int *ref_status)
{ {
unsigned char (*sha1)[20] = info->shallow->sha1; struct object_id *oid = info->shallow->oid;
struct sha1_array *ref = info->ref; struct sha1_array *ref = info->ref;
unsigned int i, nr; unsigned int i, nr;
int *shallow, nr_shallow = 0; int *shallow, nr_shallow = 0;
@ -599,18 +599,18 @@ void assign_shallow_commits_to_refs(struct shallow_info *info,
/* Mark potential bottoms so we won't go out of bound */ /* Mark potential bottoms so we won't go out of bound */
for (i = 0; i < nr_shallow; i++) { for (i = 0; i < nr_shallow; i++) {
struct commit *c = lookup_commit(sha1[shallow[i]]); struct commit *c = lookup_commit(oid[shallow[i]].hash);
c->object.flags |= BOTTOM; c->object.flags |= BOTTOM;
} }
for (i = 0; i < ref->nr; i++) for (i = 0; i < ref->nr; i++)
paint_down(&pi, ref->sha1[i], i); paint_down(&pi, ref->oid[i].hash, i);
if (used) { if (used) {
int bitmap_size = ((pi.nr_bits + 31) / 32) * sizeof(uint32_t); int bitmap_size = ((pi.nr_bits + 31) / 32) * sizeof(uint32_t);
memset(used, 0, sizeof(*used) * info->shallow->nr); memset(used, 0, sizeof(*used) * info->shallow->nr);
for (i = 0; i < nr_shallow; i++) { for (i = 0; i < nr_shallow; i++) {
const struct commit *c = lookup_commit(sha1[shallow[i]]); const struct commit *c = lookup_commit(oid[shallow[i]].hash);
uint32_t **map = ref_bitmap_at(&pi.ref_bitmap, c); uint32_t **map = ref_bitmap_at(&pi.ref_bitmap, c);
if (*map) if (*map)
used[shallow[i]] = xmemdupz(*map, bitmap_size); used[shallow[i]] = xmemdupz(*map, bitmap_size);
@ -664,7 +664,7 @@ static void post_assign_shallow(struct shallow_info *info,
struct ref_bitmap *ref_bitmap, struct ref_bitmap *ref_bitmap,
int *ref_status) int *ref_status)
{ {
unsigned char (*sha1)[20] = info->shallow->sha1; struct object_id *oid = info->shallow->oid;
struct commit *c; struct commit *c;
uint32_t **bitmap; uint32_t **bitmap;
int dst, i, j; int dst, i, j;
@ -679,7 +679,7 @@ static void post_assign_shallow(struct shallow_info *info,
for (i = dst = 0; i < info->nr_theirs; i++) { for (i = dst = 0; i < info->nr_theirs; i++) {
if (i != dst) if (i != dst)
info->theirs[dst] = info->theirs[i]; info->theirs[dst] = info->theirs[i];
c = lookup_commit(sha1[info->theirs[i]]); c = lookup_commit(oid[info->theirs[i]].hash);
bitmap = ref_bitmap_at(ref_bitmap, c); bitmap = ref_bitmap_at(ref_bitmap, c);
if (!*bitmap) if (!*bitmap)
continue; continue;
@ -700,7 +700,7 @@ static void post_assign_shallow(struct shallow_info *info,
for (i = dst = 0; i < info->nr_ours; i++) { for (i = dst = 0; i < info->nr_ours; i++) {
if (i != dst) if (i != dst)
info->ours[dst] = info->ours[i]; info->ours[dst] = info->ours[i];
c = lookup_commit(sha1[info->ours[i]]); c = lookup_commit(oid[info->ours[i]].hash);
bitmap = ref_bitmap_at(ref_bitmap, c); bitmap = ref_bitmap_at(ref_bitmap, c);
if (!*bitmap) if (!*bitmap)
continue; continue;
@ -722,7 +722,7 @@ static void post_assign_shallow(struct shallow_info *info,
int delayed_reachability_test(struct shallow_info *si, int c) int delayed_reachability_test(struct shallow_info *si, int c)
{ {
if (si->need_reachability_test[c]) { if (si->need_reachability_test[c]) {
struct commit *commit = lookup_commit(si->shallow->sha1[c]); struct commit *commit = lookup_commit(si->shallow->oid[c].hash);
if (!si->commits) { if (!si->commits) {
struct commit_array ca; struct commit_array ca;