worktree: make add <path> <branch> dwim
[gitweb.git] / bisect.h
index 31c99fe5f4deceb657b50d1fb1f446568c208400..a5d9248a47675194e7e0d16aed37018cbb67eb33 100644 (file)
--- a/bisect.h
+++ b/bisect.h
@@ -1,11 +1,39 @@
 #ifndef BISECT_H
 #define BISECT_H
 
-extern struct commit_list *find_bisection(struct commit_list *list,
-                                         int *reaches, int *all,
-                                         int find_all);
+/*
+ * Find bisection. If something is found, `reaches` will be the number of
+ * commits that the best commit reaches. `all` will be the count of
+ * non-SAMETREE commits. If nothing is found, `list` will be NULL.
+ * Otherwise, it will be either all non-SAMETREE commits or the single
+ * best commit, as chosen by `find_all`.
+ */
+extern void find_bisection(struct commit_list **list, int *reaches, int *all,
+                          int find_all);
 
-extern int show_bisect_vars(struct rev_info *revs, int reaches, int all,
-                           int show_all);
+extern struct commit_list *filter_skipped(struct commit_list *list,
+                                         struct commit_list **tried,
+                                         int show_all,
+                                         int *count,
+                                         int *skipped_first);
+
+#define BISECT_SHOW_ALL                (1<<0)
+#define REV_LIST_QUIET         (1<<1)
+
+struct rev_list_info {
+       struct rev_info *revs;
+       int flags;
+       int show_timestamp;
+       int hdr_termination;
+       const char *header_prefix;
+};
+
+extern int bisect_next_all(const char *prefix, int no_checkout);
+
+extern int estimate_bisect_steps(int all);
+
+extern void read_bisect_terms(const char **bad, const char **good);
+
+extern int bisect_clean_state(void);
 
 #endif