remote: convert get_stale_heads to take a struct refspec
[gitweb.git] / refspec.h
index fc9c1af77576f882a3272bf7ca1db8f97eff5290..7e1ff94ac99e58042d623624226a2aa93605a290 100644 (file)
--- a/refspec.h
+++ b/refspec.h
@@ -14,10 +14,31 @@ struct refspec_item {
        char *dst;
 };
 
-int valid_fetch_refspec(const char *refspec);
-struct refspec_item *parse_fetch_refspec(int nr_refspec, const char **refspec);
-struct refspec_item *parse_push_refspec(int nr_refspec, const char **refspec);
+#define REFSPEC_FETCH 1
+#define REFSPEC_PUSH 0
+
+#define REFSPEC_INIT_FETCH { .fetch = REFSPEC_FETCH }
+#define REFSPEC_INIT_PUSH { .fetch = REFSPEC_PUSH }
+
+struct refspec {
+       struct refspec_item *items;
+       int alloc;
+       int nr;
+
+       const char **raw;
+       int raw_alloc;
+       int raw_nr;
 
-void free_refspec(int nr_refspec, struct refspec_item *refspec);
+       int fetch;
+};
+
+void refspec_item_init(struct refspec_item *item, const char *refspec, int fetch);
+void refspec_item_clear(struct refspec_item *item);
+void refspec_init(struct refspec *rs, int fetch);
+void refspec_append(struct refspec *rs, const char *refspec);
+void refspec_appendn(struct refspec *rs, const char **refspecs, int nr);
+void refspec_clear(struct refspec *rs);
+
+int valid_fetch_refspec(const char *refspec);
 
 #endif /* REFSPEC_H */