From 6e7baf246a2d12480d4dbc04c47efb66408c1927 Mon Sep 17 00:00:00 2001 From: Jeff King Date: Mon, 20 May 2019 08:11:13 -0400 Subject: [PATCH] am: drop tty requirement for --interactive We have required that the stdin of "am --interactive" be a tty since a1451104ac (git-am: interactive should fail gracefully., 2005-10-12). However, this isn't strictly necessary, and makes the tool harder to test (and is unlike all of our other --interactive commands). The goal of that commit was to make sure that somebody does not do: git am --interactive Signed-off-by: Junio C Hamano --- builtin/am.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/builtin/am.c b/builtin/am.c index 9d8437cc26..9cbbd8eda8 100644 --- a/builtin/am.c +++ b/builtin/am.c @@ -1640,9 +1640,6 @@ static int do_interactive(struct am_state *state) { assert(state->msg); - if (!isatty(0)) - die(_("cannot be interactive without stdin connected to a terminal.")); - for (;;) { char reply[64]; @@ -2327,6 +2324,9 @@ int cmd_am(int argc, const char **argv, const char *prefix) argv_array_push(&paths, mkpath("%s/%s", prefix, argv[i])); } + if (state.interactive && !paths.argc) + die(_("interactive mode requires patches on the command line")); + am_setup(&state, patch_format, paths.argv, keep_cr); argv_array_clear(&paths);