#ifndef BISECT_H #define BISECT_H struct commit_list; struct repository; struct object_id; /* * 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`. */ void find_bisection(struct commit_list **list, int *reaches, int *all, unsigned bisect_flags); 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) #define FIND_BISECTION_ALL (1u<<0) #define FIND_BISECTION_FIRST_PARENT_ONLY (1u<<1) struct rev_list_info { struct rev_info *revs; int flags; int show_timestamp; int hdr_termination; const char *header_prefix; }; /* * enum bisect_error represents the following return codes: * BISECT_OK: success code. Internally, it means that next * commit has been found (and possibly checked out) and it * should be tested. * BISECT_FAILED error code: default error code. * BISECT_ONLY_SKIPPED_LEFT error code: only skipped * commits left to be tested. * BISECT_MERGE_BASE_CHECK error code: merge base check failed. * BISECT_NO_TESTABLE_COMMIT error code: no testable commit found. * BISECT_INTERNAL_SUCCESS_1ST_BAD_FOUND early success code: * first term_bad commit found. * BISECT_INTERNAL_SUCCESS_MERGE_BASE early success * code: found merge base that should be tested. * Early success codes BISECT_INTERNAL_SUCCESS_1ST_BAD_FOUND and * BISECT_INTERNAL_SUCCESS_MERGE_BASE should be only internal codes. */ enum bisect_error { BISECT_OK = 0, BISECT_FAILED = -1, BISECT_ONLY_SKIPPED_LEFT = -2, BISECT_MERGE_BASE_CHECK = -3, BISECT_NO_TESTABLE_COMMIT = -4, BISECT_INTERNAL_SUCCESS_1ST_BAD_FOUND = -10, BISECT_INTERNAL_SUCCESS_MERGE_BASE = -11 }; /* * Stores how many good/bad commits we have stored for a bisect. nr_bad can * only be 0 or 1. */ struct bisect_state { unsigned int nr_good; unsigned int nr_bad; }; enum bisect_error bisect_next_all(struct repository *r, const char *prefix); int estimate_bisect_steps(int all); void read_bisect_terms(char **bad, char **good); int bisect_clean_state(void); enum bisect_error bisect_checkout(const struct object_id *bisect_rev, int no_checkout); #endif