bisect--helper: reimplement bisect_autostart
shell function in C
Reimplement the `bisect_autostart()` shell function in C and add the C implementation from `bisect_next()` which was previously left uncovered. Add `--bisect-autostart` subcommand to be called from git-bisect.sh. Using `--bisect-autostart` subcommand is a temporary measure to port the shell function to C so as to use the existing test suite. As more functions are ported, this subcommand will be retired and bisect_autostart() will be called directly by `bisect_state()`. Change behavior of shell script that returned success when user aborted the bisection. Mentored-by: Lars Schneider <larsxschneider@gmail.com> Mentored-by: Christian Couder <chriscool@tuxfamily.org> Mentored-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Pranit Bauva <pranit.bauva@gmail.com> Signed-off-by: Tanushree Tumane <tanushreetumane@gmail.com> Signed-off-by: Miriam Rubio <mirucam@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
7b4de74b5d
commit
09535f056b
@ -29,6 +29,7 @@ static const char * const git_bisect_helper_usage[] = {
|
|||||||
N_("git bisect--helper --bisect-terms [--term-good | --term-old | --term-bad | --term-new]"),
|
N_("git bisect--helper --bisect-terms [--term-good | --term-old | --term-bad | --term-new]"),
|
||||||
N_("git bisect--helper --bisect-start [--term-{old,good}=<term> --term-{new,bad}=<term>]"
|
N_("git bisect--helper --bisect-start [--term-{old,good}=<term> --term-{new,bad}=<term>]"
|
||||||
" [--no-checkout] [--first-parent] [<bad> [<good>...]] [--] [<paths>...]"),
|
" [--no-checkout] [--first-parent] [<bad> [<good>...]] [--] [<paths>...]"),
|
||||||
|
N_("git bisect--helper --bisect-autostart"),
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -653,6 +654,38 @@ finish:
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int file_is_not_empty(const char *path)
|
||||||
|
{
|
||||||
|
return !is_empty_or_missing_file(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int bisect_autostart(struct bisect_terms *terms)
|
||||||
|
{
|
||||||
|
int res;
|
||||||
|
const char *yesno;
|
||||||
|
|
||||||
|
if (file_is_not_empty(git_path_bisect_start()))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
fprintf_ln(stderr, _("You need to start by \"git bisect "
|
||||||
|
"start\"\n"));
|
||||||
|
|
||||||
|
if (!isatty(STDIN_FILENO))
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* TRANSLATORS: Make sure to include [Y] and [n] in your
|
||||||
|
* translation. The program will only accept English input
|
||||||
|
* at this point.
|
||||||
|
*/
|
||||||
|
yesno = git_prompt(_("Do you want me to do it for you "
|
||||||
|
"[Y/n]? "), PROMPT_ECHO);
|
||||||
|
res = tolower(*yesno) == 'n' ?
|
||||||
|
-1 : bisect_start(terms, empty_strvec, 0);
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
int cmd_bisect__helper(int argc, const char **argv, const char *prefix)
|
int cmd_bisect__helper(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
enum {
|
enum {
|
||||||
@ -665,7 +698,8 @@ int cmd_bisect__helper(int argc, const char **argv, const char *prefix)
|
|||||||
CHECK_AND_SET_TERMS,
|
CHECK_AND_SET_TERMS,
|
||||||
BISECT_NEXT_CHECK,
|
BISECT_NEXT_CHECK,
|
||||||
BISECT_TERMS,
|
BISECT_TERMS,
|
||||||
BISECT_START
|
BISECT_START,
|
||||||
|
BISECT_AUTOSTART,
|
||||||
} cmdmode = 0;
|
} cmdmode = 0;
|
||||||
int res = 0, nolog = 0;
|
int res = 0, nolog = 0;
|
||||||
struct option options[] = {
|
struct option options[] = {
|
||||||
@ -689,6 +723,8 @@ int cmd_bisect__helper(int argc, const char **argv, const char *prefix)
|
|||||||
N_("print out the bisect terms"), BISECT_TERMS),
|
N_("print out the bisect terms"), BISECT_TERMS),
|
||||||
OPT_CMDMODE(0, "bisect-start", &cmdmode,
|
OPT_CMDMODE(0, "bisect-start", &cmdmode,
|
||||||
N_("start the bisect session"), BISECT_START),
|
N_("start the bisect session"), BISECT_START),
|
||||||
|
OPT_CMDMODE(0, "bisect-autostart", &cmdmode,
|
||||||
|
N_("start the bisection if it has not yet been started"), BISECT_AUTOSTART),
|
||||||
OPT_BOOL(0, "no-log", &nolog,
|
OPT_BOOL(0, "no-log", &nolog,
|
||||||
N_("no log for BISECT_WRITE")),
|
N_("no log for BISECT_WRITE")),
|
||||||
OPT_END()
|
OPT_END()
|
||||||
@ -748,6 +784,12 @@ int cmd_bisect__helper(int argc, const char **argv, const char *prefix)
|
|||||||
set_terms(&terms, "bad", "good");
|
set_terms(&terms, "bad", "good");
|
||||||
res = bisect_start(&terms, argv, argc);
|
res = bisect_start(&terms, argv, argc);
|
||||||
break;
|
break;
|
||||||
|
case BISECT_AUTOSTART:
|
||||||
|
if (argc)
|
||||||
|
return error(_("--bisect-autostart does not accept arguments"));
|
||||||
|
set_terms(&terms, "bad", "good");
|
||||||
|
res = bisect_autostart(&terms);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
BUG("unknown subcommand %d", cmdmode);
|
BUG("unknown subcommand %d", cmdmode);
|
||||||
}
|
}
|
||||||
|
@ -49,27 +49,6 @@ bisect_head()
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
bisect_autostart() {
|
|
||||||
test -s "$GIT_DIR/BISECT_START" || {
|
|
||||||
gettextln "You need to start by \"git bisect start\"" >&2
|
|
||||||
if test -t 0
|
|
||||||
then
|
|
||||||
# TRANSLATORS: Make sure to include [Y] and [n] in your
|
|
||||||
# translation. The program will only accept English input
|
|
||||||
# at this point.
|
|
||||||
gettext "Do you want me to do it for you [Y/n]? " >&2
|
|
||||||
read yesno
|
|
||||||
case "$yesno" in
|
|
||||||
[Nn]*)
|
|
||||||
exit ;;
|
|
||||||
esac
|
|
||||||
bisect_start
|
|
||||||
else
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bisect_start() {
|
bisect_start() {
|
||||||
git bisect--helper --bisect-start $@ || exit
|
git bisect--helper --bisect-start $@ || exit
|
||||||
|
|
||||||
@ -108,7 +87,7 @@ bisect_skip() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bisect_state() {
|
bisect_state() {
|
||||||
bisect_autostart
|
git bisect--helper --bisect-autostart || exit
|
||||||
state=$1
|
state=$1
|
||||||
git bisect--helper --check-and-set-terms $state $TERM_GOOD $TERM_BAD || exit
|
git bisect--helper --check-and-set-terms $state $TERM_GOOD $TERM_BAD || exit
|
||||||
get_terms
|
get_terms
|
||||||
@ -149,7 +128,7 @@ bisect_auto_next() {
|
|||||||
|
|
||||||
bisect_next() {
|
bisect_next() {
|
||||||
case "$#" in 0) ;; *) usage ;; esac
|
case "$#" in 0) ;; *) usage ;; esac
|
||||||
bisect_autostart
|
git bisect--helper --bisect-autostart || exit
|
||||||
git bisect--helper --bisect-next-check $TERM_GOOD $TERM_BAD $TERM_GOOD|| exit
|
git bisect--helper --bisect-next-check $TERM_GOOD $TERM_BAD $TERM_GOOD|| exit
|
||||||
|
|
||||||
# Perform all bisection computation, display and checkout
|
# Perform all bisection computation, display and checkout
|
||||||
|
Loading…
Reference in New Issue
Block a user