From c23f91464c4b68fb0190a8f395f302ab9f1e451d Mon Sep 17 00:00:00 2001 From: Kaz Kylheku Date: Tue, 4 Apr 2017 20:10:53 -0700 Subject: linenoise: support forcing of noninteractive mode. * linenoise/linenoise.c (struct lino_state): New member, noninteractive. (lino_set_noninteractive, lino_get_noninteractive): New functions. (linenoise): Check noninteractive flag; if set, treat the situation like !isatty(ls->ifd). * linenoise/linenoise.h (lino_set_noninteractive, lino_get_noninteractive): Delared. --- linenoise/linenoise.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'linenoise/linenoise.c') diff --git a/linenoise/linenoise.c b/linenoise/linenoise.c index 90fd1529..1209816a 100644 --- a/linenoise/linenoise.c +++ b/linenoise/linenoise.c @@ -124,6 +124,7 @@ struct lino_state { int need_refresh; /* Need refresh. */ int selmode; /* Visual selection being made. */ int selinclusive; /* Selections include character right of endpoint. */ + int noninteractive; /* No character editing, even if input is tty. */ struct lino_undo *undo_stack; lino_error_t error; /* Most recent error. */ }; @@ -174,6 +175,16 @@ int lino_get_selinculsive(lino_t *ls) return ls->selinclusive; } +void lino_set_noninteractive(lino_t *ls, int ni) +{ + ls->noninteractive = ni; +} + +int lino_get_noninteractive(lino_t *ls) +{ + return ls->noninteractive; +} + void lino_set_atom_cb(lino_t *l, lino_atom_cb_t *cb, void *ctx) { l->atom_callback = cb; @@ -2186,7 +2197,7 @@ char *linenoise(lino_t *ls, const char *prompt) { int count; - if (ls->ifs || !isatty(ls->ifd)) { + if (ls->ifs || ls->noninteractive || !isatty(ls->ifd)) { if (!ls->ifs) { int fd = dup(ls->ifd); FILE *fi = (fd > 0) ? fdopen(fd, "r") : 0; -- cgit v1.2.3