Merge branch 'jk/trailers-use-config' into maint
[gitweb.git] / fetch-object.c
index 258fcfac7566ad92ac63c1f8406a06e11b08c63b..42665488008bc0fffafa5d4e0455bc22b510b92a 100644 (file)
@@ -5,11 +5,10 @@
 #include "transport.h"
 #include "fetch-object.h"
 
-void fetch_object(const char *remote_name, const unsigned char *sha1)
+static void fetch_refs(const char *remote_name, struct ref *ref)
 {
        struct remote *remote;
        struct transport *transport;
-       struct ref *ref;
        int original_fetch_if_missing = fetch_if_missing;
 
        fetch_if_missing = 0;
@@ -18,10 +17,24 @@ void fetch_object(const char *remote_name, const unsigned char *sha1)
                die(_("Remote with no URL"));
        transport = transport_get(remote, remote->url[0]);
 
-       ref = alloc_ref(sha1_to_hex(sha1));
-       hashcpy(ref->old_oid.hash, sha1);
        transport_set_option(transport, TRANS_OPT_FROM_PROMISOR, "1");
        transport_set_option(transport, TRANS_OPT_NO_DEPENDENTS, "1");
        transport_fetch_refs(transport, ref);
        fetch_if_missing = original_fetch_if_missing;
 }
+
+void fetch_objects(const char *remote_name, const struct object_id *oids,
+                  int oid_nr)
+{
+       struct ref *ref = NULL;
+       int i;
+
+       for (i = 0; i < oid_nr; i++) {
+               struct ref *new_ref = alloc_ref(oid_to_hex(&oids[i]));
+               oidcpy(&new_ref->old_oid, &oids[i]);
+               new_ref->exact_oid = 1;
+               new_ref->next = ref;
+               ref = new_ref;
+       }
+       fetch_refs(remote_name, ref);
+}