Merge git://ozlabs.org/~paulus/gitk
[git.git] / fetch-object.c
blob42665488008bc0fffafa5d4e0455bc22b510b92a
1 #include "cache.h"
2 #include "packfile.h"
3 #include "pkt-line.h"
4 #include "strbuf.h"
5 #include "transport.h"
6 #include "fetch-object.h"
8 static void fetch_refs(const char *remote_name, struct ref *ref)
10 struct remote *remote;
11 struct transport *transport;
12 int original_fetch_if_missing = fetch_if_missing;
14 fetch_if_missing = 0;
15 remote = remote_get(remote_name);
16 if (!remote->url[0])
17 die(_("Remote with no URL"));
18 transport = transport_get(remote, remote->url[0]);
20 transport_set_option(transport, TRANS_OPT_FROM_PROMISOR, "1");
21 transport_set_option(transport, TRANS_OPT_NO_DEPENDENTS, "1");
22 transport_fetch_refs(transport, ref);
23 fetch_if_missing = original_fetch_if_missing;
26 void fetch_objects(const char *remote_name, const struct object_id *oids,
27 int oid_nr)
29 struct ref *ref = NULL;
30 int i;
32 for (i = 0; i < oid_nr; i++) {
33 struct ref *new_ref = alloc_ref(oid_to_hex(&oids[i]));
34 oidcpy(&new_ref->old_oid, &oids[i]);
35 new_ref->exact_oid = 1;
36 new_ref->next = ref;
37 ref = new_ref;
39 fetch_refs(remote_name, ref);