mirror of
https://github.com/fluencelabs/redis
synced 2025-04-07 18:08:04 +00:00
Linenoise lib updated.
This commit is contained in:
parent
d61e820faf
commit
35a8302b7c
51
deps/linenoise/linenoise.c
vendored
51
deps/linenoise/linenoise.c
vendored
@ -56,10 +56,6 @@
|
|||||||
* flickering effect with some slow terminal, but the lesser sequences
|
* flickering effect with some slow terminal, but the lesser sequences
|
||||||
* the more compatible.
|
* the more compatible.
|
||||||
*
|
*
|
||||||
* CHA (Cursor Horizontal Absolute)
|
|
||||||
* Sequence: ESC [ n G
|
|
||||||
* Effect: moves cursor to column n
|
|
||||||
*
|
|
||||||
* EL (Erase Line)
|
* EL (Erase Line)
|
||||||
* Sequence: ESC [ n K
|
* Sequence: ESC [ n K
|
||||||
* Effect: if n is 0 or missing, clear from cursor to end of line
|
* Effect: if n is 0 or missing, clear from cursor to end of line
|
||||||
@ -68,7 +64,19 @@
|
|||||||
*
|
*
|
||||||
* CUF (CUrsor Forward)
|
* CUF (CUrsor Forward)
|
||||||
* Sequence: ESC [ n C
|
* Sequence: ESC [ n C
|
||||||
* Effect: moves cursor forward of n chars
|
* Effect: moves cursor forward n chars
|
||||||
|
*
|
||||||
|
* CUB (CUrsor Backward)
|
||||||
|
* Sequence: ESC [ n D
|
||||||
|
* Effect: moves cursor backward n chars
|
||||||
|
*
|
||||||
|
* The following is used to get the terminal width if getting
|
||||||
|
* the width with the TIOCGWINSZ ioctl fails
|
||||||
|
*
|
||||||
|
* DSR (Device Status Report)
|
||||||
|
* Sequence: ESC [ 6 n
|
||||||
|
* Effect: reports the current cusor position as ESC [ n ; m R
|
||||||
|
* where n is the row and m is the column
|
||||||
*
|
*
|
||||||
* When multi line mode is enabled, we also use an additional escape
|
* When multi line mode is enabled, we also use an additional escape
|
||||||
* sequence. However multi line editing is disabled by default.
|
* sequence. However multi line editing is disabled by default.
|
||||||
@ -81,14 +89,15 @@
|
|||||||
* Sequence: ESC [ n B
|
* Sequence: ESC [ n B
|
||||||
* Effect: moves cursor down of n chars.
|
* Effect: moves cursor down of n chars.
|
||||||
*
|
*
|
||||||
* The following are used to clear the screen: ESC [ H ESC [ 2 J
|
* When linenoiseClearScreen() is called, two additional escape sequences
|
||||||
* This is actually composed of two sequences:
|
* are used in order to clear the screen and position the cursor at home
|
||||||
|
* position.
|
||||||
*
|
*
|
||||||
* cursorhome
|
* CUP (Cursor position)
|
||||||
* Sequence: ESC [ H
|
* Sequence: ESC [ H
|
||||||
* Effect: moves the cursor to upper left corner
|
* Effect: moves the cursor to upper left corner
|
||||||
*
|
*
|
||||||
* ED2 (Clear entire screen)
|
* ED (Erase display)
|
||||||
* Sequence: ESC [ 2 J
|
* Sequence: ESC [ 2 J
|
||||||
* Effect: clear the whole screen
|
* Effect: clear the whole screen
|
||||||
*
|
*
|
||||||
@ -471,7 +480,7 @@ static void refreshSingleLine(struct linenoiseState *l) {
|
|||||||
|
|
||||||
abInit(&ab);
|
abInit(&ab);
|
||||||
/* Cursor to left edge */
|
/* Cursor to left edge */
|
||||||
snprintf(seq,64,"\x1b[0G");
|
snprintf(seq,64,"\r");
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
/* Write the prompt and the current buffer content */
|
/* Write the prompt and the current buffer content */
|
||||||
abAppend(&ab,l->prompt,strlen(l->prompt));
|
abAppend(&ab,l->prompt,strlen(l->prompt));
|
||||||
@ -480,7 +489,7 @@ static void refreshSingleLine(struct linenoiseState *l) {
|
|||||||
snprintf(seq,64,"\x1b[0K");
|
snprintf(seq,64,"\x1b[0K");
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
/* Move cursor to original position. */
|
/* Move cursor to original position. */
|
||||||
snprintf(seq,64,"\x1b[0G\x1b[%dC", (int)(pos+plen));
|
snprintf(seq,64,"\r\x1b[%dC", (int)(pos+plen));
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
if (write(fd,ab.b,ab.len) == -1) {} /* Can't recover from write error. */
|
if (write(fd,ab.b,ab.len) == -1) {} /* Can't recover from write error. */
|
||||||
abFree(&ab);
|
abFree(&ab);
|
||||||
@ -496,6 +505,7 @@ static void refreshMultiLine(struct linenoiseState *l) {
|
|||||||
int rows = (plen+l->len+l->cols-1)/l->cols; /* rows used by current buf. */
|
int rows = (plen+l->len+l->cols-1)/l->cols; /* rows used by current buf. */
|
||||||
int rpos = (plen+l->oldpos+l->cols)/l->cols; /* cursor relative row. */
|
int rpos = (plen+l->oldpos+l->cols)/l->cols; /* cursor relative row. */
|
||||||
int rpos2; /* rpos after refresh. */
|
int rpos2; /* rpos after refresh. */
|
||||||
|
int col; /* colum position, zero-based. */
|
||||||
int old_rows = l->maxrows;
|
int old_rows = l->maxrows;
|
||||||
int fd = l->ofd, j;
|
int fd = l->ofd, j;
|
||||||
struct abuf ab;
|
struct abuf ab;
|
||||||
@ -515,13 +525,13 @@ static void refreshMultiLine(struct linenoiseState *l) {
|
|||||||
/* Now for every row clear it, go up. */
|
/* Now for every row clear it, go up. */
|
||||||
for (j = 0; j < old_rows-1; j++) {
|
for (j = 0; j < old_rows-1; j++) {
|
||||||
lndebug("clear+up");
|
lndebug("clear+up");
|
||||||
snprintf(seq,64,"\x1b[0G\x1b[0K\x1b[1A");
|
snprintf(seq,64,"\r\x1b[0K\x1b[1A");
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Clean the top line. */
|
/* Clean the top line. */
|
||||||
lndebug("clear");
|
lndebug("clear");
|
||||||
snprintf(seq,64,"\x1b[0G\x1b[0K");
|
snprintf(seq,64,"\r\x1b[0K");
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
|
|
||||||
/* Write the prompt and the current buffer content */
|
/* Write the prompt and the current buffer content */
|
||||||
@ -536,7 +546,7 @@ static void refreshMultiLine(struct linenoiseState *l) {
|
|||||||
{
|
{
|
||||||
lndebug("<newline>");
|
lndebug("<newline>");
|
||||||
abAppend(&ab,"\n",1);
|
abAppend(&ab,"\n",1);
|
||||||
snprintf(seq,64,"\x1b[0G");
|
snprintf(seq,64,"\r");
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
rows++;
|
rows++;
|
||||||
if (rows > (int)l->maxrows) l->maxrows = rows;
|
if (rows > (int)l->maxrows) l->maxrows = rows;
|
||||||
@ -554,8 +564,12 @@ static void refreshMultiLine(struct linenoiseState *l) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Set column. */
|
/* Set column. */
|
||||||
lndebug("set col %d", 1+((plen+(int)l->pos) % (int)l->cols));
|
col = (plen+(int)l->pos) % (int)l->cols;
|
||||||
snprintf(seq,64,"\x1b[%dG", 1+((plen+(int)l->pos) % (int)l->cols));
|
lndebug("set col %d", 1+col);
|
||||||
|
if (col)
|
||||||
|
snprintf(seq,64,"\r\x1b[%dC", col);
|
||||||
|
else
|
||||||
|
snprintf(seq,64,"\r");
|
||||||
abAppend(&ab,seq,strlen(seq));
|
abAppend(&ab,seq,strlen(seq));
|
||||||
|
|
||||||
lndebug("\n");
|
lndebug("\n");
|
||||||
@ -757,6 +771,7 @@ static int linenoiseEdit(int stdin_fd, int stdout_fd, char *buf, size_t buflen,
|
|||||||
case ENTER: /* enter */
|
case ENTER: /* enter */
|
||||||
history_len--;
|
history_len--;
|
||||||
free(history[history_len]);
|
free(history[history_len]);
|
||||||
|
if (mlmode) linenoiseEditMoveEnd(&l);
|
||||||
return (int)l.len;
|
return (int)l.len;
|
||||||
case CTRL_C: /* ctrl-c */
|
case CTRL_C: /* ctrl-c */
|
||||||
errno = EAGAIN;
|
errno = EAGAIN;
|
||||||
@ -765,7 +780,7 @@ static int linenoiseEdit(int stdin_fd, int stdout_fd, char *buf, size_t buflen,
|
|||||||
case 8: /* ctrl-h */
|
case 8: /* ctrl-h */
|
||||||
linenoiseEditBackspace(&l);
|
linenoiseEditBackspace(&l);
|
||||||
break;
|
break;
|
||||||
case CTRL_D: /* ctrl-d, remove char at right of cursor, or of the
|
case CTRL_D: /* ctrl-d, remove char at right of cursor, or if the
|
||||||
line is empty, act as end-of-file. */
|
line is empty, act as end-of-file. */
|
||||||
if (l.len > 0) {
|
if (l.len > 0) {
|
||||||
linenoiseEditDelete(&l);
|
linenoiseEditDelete(&l);
|
||||||
@ -904,7 +919,7 @@ void linenoisePrintKeyCodes(void) {
|
|||||||
|
|
||||||
printf("'%c' %02x (%d) (type quit to exit)\n",
|
printf("'%c' %02x (%d) (type quit to exit)\n",
|
||||||
isprint(c) ? c : '?', (int)c, (int)c);
|
isprint(c) ? c : '?', (int)c, (int)c);
|
||||||
printf("\x1b[0G"); /* Go left edge manually, we are in raw mode. */
|
printf("\r"); /* Go left edge manually, we are in raw mode. */
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
}
|
}
|
||||||
disableRawMode(STDIN_FILENO);
|
disableRawMode(STDIN_FILENO);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user