Skip to content

Commit 30aaff4

Browse files
pks-tgitster
authored andcommitted
refs: pass repo when peeling objects
Both `peel_object()` and `peel_iterated_oid()` implicitly rely on `the_repository` to look up objects. Despite the fact that we want to get rid of `the_repository`, it also leads to some restrictions in our ref iterators when trying to retrieve the peeled value for a repository other than `the_repository`. Refactor these functions such that both take a repository as argument and remove the now-unnecessary restrictions. Signed-off-by: Patrick Steinhardt <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 19c76e8 commit 30aaff4

20 files changed

+37
-36
lines changed

builtin/describe.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -200,7 +200,7 @@ static int get_name(const char *path, const struct object_id *oid,
200200
}
201201

202202
/* Is it annotated? */
203-
if (!peel_iterated_oid(oid, &peeled)) {
203+
if (!peel_iterated_oid(the_repository, oid, &peeled)) {
204204
is_annotated = !oideq(oid, &peeled);
205205
} else {
206206
oidcpy(&peeled, oid);

builtin/gc.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -846,7 +846,7 @@ static int dfs_on_ref(const char *refname UNUSED,
846846
struct commit_list *stack = NULL;
847847
struct commit *commit;
848848

849-
if (!peel_iterated_oid(oid, &peeled))
849+
if (!peel_iterated_oid(the_repository, oid, &peeled))
850850
oid = &peeled;
851851
if (oid_object_info(the_repository, oid, NULL) != OBJ_COMMIT)
852852
return 0;

builtin/pack-objects.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -779,7 +779,7 @@ static int mark_tagged(const char *path UNUSED, const struct object_id *oid,
779779

780780
if (entry)
781781
entry->tagged = 1;
782-
if (!peel_iterated_oid(oid, &peeled)) {
782+
if (!peel_iterated_oid(the_repository, oid, &peeled)) {
783783
entry = packlist_find(&to_pack, &peeled);
784784
if (entry)
785785
entry->tagged = 1;
@@ -3125,7 +3125,7 @@ static int add_ref_tag(const char *tag UNUSED, const struct object_id *oid,
31253125
{
31263126
struct object_id peeled;
31273127

3128-
if (!peel_iterated_oid(oid, &peeled) && obj_is_packed(&peeled))
3128+
if (!peel_iterated_oid(the_repository, oid, &peeled) && obj_is_packed(&peeled))
31293129
add_tag_chain(oid);
31303130
return 0;
31313131
}
@@ -4074,7 +4074,7 @@ static int mark_bitmap_preferred_tip(const char *refname,
40744074
struct object_id peeled;
40754075
struct object *object;
40764076

4077-
if (!peel_iterated_oid(oid, &peeled))
4077+
if (!peel_iterated_oid(the_repository, oid, &peeled))
40784078
oid = &peeled;
40794079

40804080
object = parse_object_or_die(oid, refname);

builtin/repack.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -673,7 +673,7 @@ static int midx_snapshot_ref_one(const char *refname UNUSED,
673673
struct midx_snapshot_ref_data *data = _data;
674674
struct object_id peeled;
675675

676-
if (!peel_iterated_oid(oid, &peeled))
676+
if (!peel_iterated_oid(the_repository, oid, &peeled))
677677
oid = &peeled;
678678

679679
if (oidset_insert(&data->seen, oid))

builtin/show-ref.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -50,7 +50,7 @@ static void show_one(const struct show_one_options *opts,
5050
if (!opts->deref_tags)
5151
return;
5252

53-
if (!peel_iterated_oid(oid, &peeled)) {
53+
if (!peel_iterated_oid(the_repository, oid, &peeled)) {
5454
hex = repo_find_unique_abbrev(the_repository, &peeled, opts->abbrev);
5555
printf("%s %s^{}\n", hex, refname);
5656
}

commit-graph.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1821,7 +1821,7 @@ static int add_ref_to_set(const char *refname UNUSED,
18211821
struct object_id peeled;
18221822
struct refs_cb_data *data = (struct refs_cb_data *)cb_data;
18231823

1824-
if (!peel_iterated_oid(oid, &peeled))
1824+
if (!peel_iterated_oid(the_repository, oid, &peeled))
18251825
oid = &peeled;
18261826
if (oid_object_info(the_repository, oid, NULL) == OBJ_COMMIT)
18271827
oidset_insert(data->commits, oid);

ls-refs.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -110,7 +110,7 @@ static int send_ref(const char *refname, const struct object_id *oid,
110110

111111
if (data->peel && oid) {
112112
struct object_id peeled;
113-
if (!peel_iterated_oid(oid, &peeled))
113+
if (!peel_iterated_oid(the_repository, oid, &peeled))
114114
strbuf_addf(&data->buf, " peeled:%s", oid_to_hex(&peeled));
115115
}
116116

midx-write.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -664,7 +664,7 @@ static int add_ref_to_pending(const char *refname,
664664
return 0;
665665
}
666666

667-
if (!peel_iterated_oid(oid, &peeled))
667+
if (!peel_iterated_oid(the_repository, oid, &peeled))
668668
oid = &peeled;
669669

670670
object = parse_object_or_die(oid, refname);

object.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -207,20 +207,22 @@ struct object *lookup_object_by_type(struct repository *r,
207207
}
208208
}
209209

210-
enum peel_status peel_object(const struct object_id *name, struct object_id *oid)
210+
enum peel_status peel_object(struct repository *r,
211+
const struct object_id *name,
212+
struct object_id *oid)
211213
{
212-
struct object *o = lookup_unknown_object(the_repository, name);
214+
struct object *o = lookup_unknown_object(r, name);
213215

214216
if (o->type == OBJ_NONE) {
215-
int type = oid_object_info(the_repository, name, NULL);
217+
int type = oid_object_info(r, name, NULL);
216218
if (type < 0 || !object_as_type(o, type, 0))
217219
return PEEL_INVALID;
218220
}
219221

220222
if (o->type != OBJ_TAG)
221223
return PEEL_NON_TAG;
222224

223-
o = deref_tag_noverify(o);
225+
o = deref_tag_noverify(r, o);
224226
if (!o)
225227
return PEEL_INVALID;
226228

object.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -288,7 +288,8 @@ enum peel_status {
288288
* or is not valid, return PEEL_NON_TAG or PEEL_INVALID, respectively,
289289
* and leave oid unchanged.
290290
*/
291-
enum peel_status peel_object(const struct object_id *name, struct object_id *oid);
291+
enum peel_status peel_object(struct repository *r,
292+
const struct object_id *name, struct object_id *oid);
292293

293294
struct object_list *object_list_insert(struct object *item,
294295
struct object_list **list_p);

ref-filter.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2520,7 +2520,7 @@ static int populate_value(struct ref_array_item *ref, struct strbuf *err)
25202520
* If it is a tag object, see if we use the peeled value. If we do,
25212521
* grab the peeled OID.
25222522
*/
2523-
if (need_tagged && peel_iterated_oid(&obj->oid, &oi_deref.oid))
2523+
if (need_tagged && peel_iterated_oid(the_repository, &obj->oid, &oi_deref.oid))
25242524
die("bad tag");
25252525

25262526
return get_object(ref, 1, &obj, &oi_deref, err);

refs.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2064,14 +2064,14 @@ int refs_pack_refs(struct ref_store *refs, struct pack_refs_opts *opts)
20642064
return refs->be->pack_refs(refs, opts);
20652065
}
20662066

2067-
int peel_iterated_oid(const struct object_id *base, struct object_id *peeled)
2067+
int peel_iterated_oid(struct repository *r, const struct object_id *base, struct object_id *peeled)
20682068
{
20692069
if (current_ref_iter &&
20702070
(current_ref_iter->oid == base ||
20712071
oideq(current_ref_iter->oid, base)))
20722072
return ref_iterator_peel(current_ref_iter, peeled);
20732073

2074-
return peel_object(base, peeled) ? -1 : 0;
2074+
return peel_object(r, base, peeled) ? -1 : 0;
20752075
}
20762076

20772077
int refs_create_symref(struct ref_store *refs,

refs.h

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -127,13 +127,14 @@ void ref_store_release(struct ref_store *ref_store);
127127
* Return the peeled value of the oid currently being iterated via
128128
* for_each_ref(), etc. This is equivalent to calling:
129129
*
130-
* peel_object(oid, &peeled);
130+
* peel_object(r, oid, &peeled);
131131
*
132132
* with the "oid" value given to the each_ref_fn callback, except
133133
* that some ref storage may be able to answer the query without
134134
* actually loading the object in memory.
135135
*/
136-
int peel_iterated_oid(const struct object_id *base, struct object_id *peeled);
136+
int peel_iterated_oid(struct repository *r,
137+
const struct object_id *base, struct object_id *peeled);
137138

138139
/**
139140
* Resolve refname in the nested "gitlink" repository in the specified

refs/packed-backend.c

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -953,16 +953,13 @@ static int packed_ref_iterator_peel(struct ref_iterator *ref_iterator,
953953
struct packed_ref_iterator *iter =
954954
(struct packed_ref_iterator *)ref_iterator;
955955

956-
if (iter->repo != the_repository)
957-
BUG("peeling for non-the_repository is not supported");
958-
959956
if ((iter->base.flags & REF_KNOWS_PEELED)) {
960957
oidcpy(peeled, &iter->peeled);
961958
return is_null_oid(&iter->peeled) ? -1 : 0;
962959
} else if ((iter->base.flags & (REF_ISBROKEN | REF_ISSYMREF))) {
963960
return -1;
964961
} else {
965-
return peel_object(&iter->oid, peeled) ? -1 : 0;
962+
return peel_object(iter->repo, &iter->oid, peeled) ? -1 : 0;
966963
}
967964
}
968965

@@ -1421,7 +1418,8 @@ static int write_with_updates(struct packed_ref_store *refs,
14211418
i++;
14221419
} else {
14231420
struct object_id peeled;
1424-
int peel_error = peel_object(&update->new_oid,
1421+
int peel_error = peel_object(refs->base.repo,
1422+
&update->new_oid,
14251423
&peeled);
14261424

14271425
if (write_packed_entry(out, update->refname,

refs/ref-cache.c

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -441,10 +441,7 @@ static int cache_ref_iterator_peel(struct ref_iterator *ref_iterator,
441441
{
442442
struct cache_ref_iterator *iter =
443443
(struct cache_ref_iterator *)ref_iterator;
444-
445-
if (iter->repo != the_repository)
446-
BUG("peeling for non-the_repository is not supported");
447-
return peel_object(ref_iterator->oid, peeled) ? -1 : 0;
444+
return peel_object(iter->repo, ref_iterator->oid, peeled) ? -1 : 0;
448445
}
449446

450447
static int cache_ref_iterator_abort(struct ref_iterator *ref_iterator)

refs/reftable-backend.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1144,7 +1144,7 @@ static int write_transaction_table(struct reftable_writer *writer, void *cb_data
11441144
ref.refname = (char *)u->refname;
11451145
ref.update_index = ts;
11461146

1147-
peel_error = peel_object(&u->new_oid, &peeled);
1147+
peel_error = peel_object(arg->refs->base.repo, &u->new_oid, &peeled);
11481148
if (!peel_error) {
11491149
ref.value_type = REFTABLE_REF_VAL2;
11501150
memcpy(ref.value.val2.target_value, peeled.hash, GIT_MAX_RAWSZ);
@@ -2045,6 +2045,7 @@ static int reftable_be_delete_reflog(struct ref_store *ref_store,
20452045
}
20462046

20472047
struct reflog_expiry_arg {
2048+
struct reftable_ref_store *refs;
20482049
struct reftable_stack *stack;
20492050
struct reftable_log_record *records;
20502051
struct object_id update_oid;
@@ -2073,7 +2074,7 @@ static int write_reflog_expiry_table(struct reftable_writer *writer, void *cb_da
20732074
ref.refname = (char *)arg->refname;
20742075
ref.update_index = ts;
20752076

2076-
if (!peel_object(&arg->update_oid, &peeled)) {
2077+
if (!peel_object(arg->refs->base.repo, &arg->update_oid, &peeled)) {
20772078
ref.value_type = REFTABLE_REF_VAL2;
20782079
memcpy(ref.value.val2.target_value, peeled.hash, GIT_MAX_RAWSZ);
20792080
memcpy(ref.value.val2.value, arg->update_oid.hash, GIT_MAX_RAWSZ);
@@ -2235,6 +2236,7 @@ static int reftable_be_reflog_expire(struct ref_store *ref_store,
22352236
reftable_ref_record_val1(&ref_record))
22362237
oidread(&arg.update_oid, last_hash);
22372238

2239+
arg.refs = refs;
22382240
arg.records = rewritten;
22392241
arg.len = logs_nr;
22402242
arg.stack = stack,

t/helper/test-reach.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@ int cmd__reach(int ac, const char **av)
6262
die("failed to resolve %s", buf.buf + 2);
6363

6464
orig = parse_object(r, &oid);
65-
peeled = deref_tag_noverify(orig);
65+
peeled = deref_tag_noverify(the_repository, orig);
6666

6767
if (!peeled)
6868
die("failed to load commit for input %s resulting in oid %s\n",

tag.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -91,10 +91,10 @@ struct object *deref_tag(struct repository *r, struct object *o, const char *war
9191
return o;
9292
}
9393

94-
struct object *deref_tag_noverify(struct object *o)
94+
struct object *deref_tag_noverify(struct repository *r, struct object *o)
9595
{
9696
while (o && o->type == OBJ_TAG) {
97-
o = parse_object(the_repository, &o->oid);
97+
o = parse_object(r, &o->oid);
9898
if (o && o->type == OBJ_TAG && ((struct tag *)o)->tagged)
9999
o = ((struct tag *)o)->tagged;
100100
else

tag.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ int parse_tag_buffer(struct repository *r, struct tag *item, const void *data, u
1616
int parse_tag(struct tag *item);
1717
void release_tag_memory(struct tag *t);
1818
struct object *deref_tag(struct repository *r, struct object *, const char *, int);
19-
struct object *deref_tag_noverify(struct object *);
19+
struct object *deref_tag_noverify(struct repository *r, struct object *);
2020
int gpg_verify_tag(const struct object_id *oid,
2121
const char *name_to_report, unsigned flags);
2222
struct object_id *get_tagged_oid(struct tag *tag);

upload-pack.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1269,7 +1269,7 @@ static void write_v0_ref(struct upload_pack_data *data,
12691269
packet_fwrite_fmt(stdout, "%s %s\n", oid_to_hex(oid), refname_nons);
12701270
}
12711271
capabilities = NULL;
1272-
if (!peel_iterated_oid(oid, &peeled))
1272+
if (!peel_iterated_oid(the_repository, oid, &peeled))
12731273
packet_fwrite_fmt(stdout, "%s %s^{}\n", oid_to_hex(&peeled), refname_nons);
12741274
return;
12751275
}

0 commit comments

Comments
 (0)