|
|
| version 1.9.2.1, 2013/11/20 16:04:42 | version 1.12.2.1, 2013/12/03 20:09:14 |
|---|---|
| Line 1050 cliInit(int fin, int fout, const char *prompt) | Line 1050 cliInit(int fin, int fout, const char *prompt) |
| keys[i].key_func = bufEOL; | keys[i].key_func = bufEOL; |
| if (cli_buffer->line_prompt && (i == *K_CTRL_H || i == *K_BACKSPACE)) | if (cli_buffer->line_prompt && (i == *K_CTRL_H || i == *K_BACKSPACE)) |
| keys[i].key_func = bufBS; | keys[i].key_func = bufBS; |
| if (cli_buffer->line_prompt && i == *K_CTRL_C) | if (i == *K_CTRL_C) |
| keys[i].key_func = bufCLR; | keys[i].key_func = bufCLR; |
| if (cli_buffer->line_prompt && i == *K_CTRL_A) | if (cli_buffer->line_prompt && i == *K_CTRL_A) |
| keys[i].key_func = bufBEGIN; | keys[i].key_func = bufBEGIN; |
| Line 1058 cliInit(int fin, int fout, const char *prompt) | Line 1058 cliInit(int fin, int fout, const char *prompt) |
| keys[i].key_func = bufEND; | keys[i].key_func = bufEND; |
| if (cli_buffer->line_prompt && i == *K_TAB) | if (cli_buffer->line_prompt && i == *K_TAB) |
| keys[i].key_func = bufComp; | keys[i].key_func = bufComp; |
| if (cli_buffer->line_prompt && i == *K_CTRL_Z) | if (i == *K_CTRL_Z) |
| keys[i].key_func = bufEndNode; | keys[i].key_func = bufEndNode; |
| if (i >= *K_SPACE && i < *K_BACKSPACE) | if (i >= *K_SPACE && i < *K_BACKSPACE) |
| keys[i].key_func = bufCHAR; | keys[i].key_func = bufCHAR; |
| Line 1280 cliReadLine(linebuffer_t * __restrict cli_buffer, int | Line 1280 cliReadLine(linebuffer_t * __restrict cli_buffer, int |
| if (!cli_buffer) { | if (!cli_buffer) { |
| cli_SetErr(EINVAL, "Invalid input parameters ..."); | cli_SetErr(EINVAL, "Invalid input parameters ..."); |
| return NULL; | return NULL; |
| } | } else if (timeout > 0) |
| timeout *= 1000; /* convert from sec to ms */ | |
| memset(&fds, 0, sizeof fds); | memset(&fds, 0, sizeof fds); |
| fds.fd = cli_buffer->line_in; | fds.fd = cli_buffer->line_in; |
| Line 1289 cliReadLine(linebuffer_t * __restrict cli_buffer, int | Line 1290 cliReadLine(linebuffer_t * __restrict cli_buffer, int |
| printfCR(cli_buffer, 1); | printfCR(cli_buffer, 1); |
| while (42) { | while (42) { |
| if ((ret = poll(&fds, 1, timeout)) < 1) { | if ((ret = poll(&fds, 1, timeout)) < 1) { |
| LOGERR; | if (!ret) { |
| return ret ? str : ""; | cli_buffer->line_kill = 1; |
| if (str) { | |
| e_free(str); | |
| str = NULL; | |
| } | |
| } else | |
| LOGERR; | |
| return str; | |
| } | } |
| memset(buf, 0, sizeof buf); | memset(buf, 0, sizeof buf); |
| Line 1525 cliLoop(linebuffer_t * __restrict cli_buffer, const ch | Line 1533 cliLoop(linebuffer_t * __restrict cli_buffer, const ch |
| cli_freeLine(cli_buffer); | cli_freeLine(cli_buffer); |
| cli_resetHistory(cli_buffer); | cli_resetHistory(cli_buffer); |
| e_free(line); | e_free(line); |
| } while (ret < 1); | } while (cli_buffer->line_kill || ret < 1); |
| cli_saveHistory(cli_buffer, csHistFile, HISTORY_LINES); | cli_saveHistory(cli_buffer, csHistFile, HISTORY_LINES); |
| return ret; | return ret; |