upload-pack: fix off-by-one depth calculation in shallow clone
[gitweb.git] / fetch-pack.h
index fbe85ac05fd2d945d645365dc086460003fa7f27..cb148719bfd3bace27a0ca9611f1c38066fb6ed4 100644 (file)
@@ -1,8 +1,9 @@
 #ifndef FETCH_PACK_H
 #define FETCH_PACK_H
 
-struct fetch_pack_args
-{
+#include "string-list.h"
+
+struct fetch_pack_args {
        const char *uploadpack;
        int unpacklimit;
        int depth;
@@ -11,18 +12,25 @@ struct fetch_pack_args
                lock_pack:1,
                use_thin_pack:1,
                fetch_all:1,
+               stdin_refs:1,
                verbose:1,
                no_progress:1,
                include_tag:1,
                stateless_rpc:1;
 };
 
+/*
+ * sought contains the full names of remote references that should be
+ * updated from.  On return, the names that were found on the remote
+ * will have been removed from the list.  The util members of the
+ * string_list_items are used internally; they must be NULL on entry
+ * (and will be NULL on exit).
+ */
 struct ref *fetch_pack(struct fetch_pack_args *args,
-               int fd[], struct child_process *conn,
-               const struct ref *ref,
-               const char *dest,
-               int nr_heads,
-               char **heads,
-               char **pack_lockfile);
+                      int fd[], struct child_process *conn,
+                      const struct ref *ref,
+                      const char *dest,
+                      struct string_list *sought,
+                      char **pack_lockfile);
 
 #endif