|
version 1.7.2.1, 2013/08/12 20:15:55
|
version 1.9.2.2, 2013/11/20 16:18:34
|
|
Line 88 clrscrEOL(linebuffer_t * __restrict buf)
|
Line 88 clrscrEOL(linebuffer_t * __restrict buf)
|
| { |
{ |
| register int i; |
register int i; |
| |
|
| if (buf) { | if (buf && buf->line_prompt) { |
| write(buf->line_out, K_CR, 1); |
write(buf->line_out, K_CR, 1); |
| |
|
| for (i = 0; i < buf->line_len; i++) |
for (i = 0; i < buf->line_len; i++) |
|
Line 100 static inline void
|
Line 100 static inline void
|
| printfEOL(linebuffer_t * __restrict buf, int len, int prompt) |
printfEOL(linebuffer_t * __restrict buf, int len, int prompt) |
| { |
{ |
| if (buf) { |
if (buf) { |
| write(buf->line_out, K_CR, 1); | if (prompt && buf->line_prompt) { |
| write(buf->line_out, K_CR, 1); |
| if (prompt && buf->line_prompt) | |
| write(buf->line_out, buf->line_prompt, buf->line_bol); |
write(buf->line_out, buf->line_prompt, buf->line_bol); |
| |
} |
| |
|
| write(buf->line_out, buf->line_buf, len == -1 ? buf->line_eol - buf->line_bol: len); | write(buf->line_out, buf->line_buf, len == -1 ? |
| | buf->line_eol - buf->line_bol: len); |
| } |
} |
| } |
} |
| |
|
| static inline void |
static inline void |
| printfCR(linebuffer_t * __restrict buf, int prompt) |
printfCR(linebuffer_t * __restrict buf, int prompt) |
| { |
{ |
| if (buf) { | if (buf && prompt && buf->line_prompt) { |
| write(buf->line_out, K_CR, 1); |
write(buf->line_out, K_CR, 1); |
| write(buf->line_out, buf->line_prompt, buf->line_bol); |
| if (prompt) | |
| if (prompt && buf->line_prompt) | |
| write(buf->line_out, buf->line_prompt, buf->line_bol); | |
| } |
} |
| } |
} |
| |
|
|
Line 422 bufComp(int idx, void * __restrict cli_buffer)
|
Line 420 bufComp(int idx, void * __restrict cli_buffer)
|
| memset(szLine, 0, STRSIZ); |
memset(szLine, 0, STRSIZ); |
| if (*s) { |
if (*s) { |
| memset(items, 0, sizeof(char*) * MAX_PROMPT_ITEMS); |
memset(items, 0, sizeof(char*) * MAX_PROMPT_ITEMS); |
| for (app = items, i = 0; app < items + MAX_PROMPT_ITEMS - 1 && (*app = strsep(&s, " \t")); | for (app = items, i = 0; app < items + MAX_PROMPT_ITEMS - 1 && |
| | (*app = strsep(&s, " \t")); |
| *app ? i++ : i, *app ? app++ : app); |
*app ? i++ : i, *app ? app++ : app); |
| |
|
| if (i) { |
if (i) { |
| SLIST_FOREACH(cmd, &buf->line_cmds, cmd_next) { |
SLIST_FOREACH(cmd, &buf->line_cmds, cmd_next) { |
| if (cmd->cmd_level == buf->line_level && | if (cmd->cmd_level & (1 << buf->line_level) && |
| !strncmp(cmd->cmd_name, items[0], strlen(items[0]))) { | !strncmp(cmd->cmd_name, items[0], |
| if (strncmp(cmd->cmd_name, CLI_CMD_SEP, strlen(CLI_CMD_SEP))) { | strlen(items[0]))) { |
| | if (strncmp(cmd->cmd_name, CLI_CMD_SEP, |
| | strlen(CLI_CMD_SEP))) { |
| j++; |
j++; |
| c = cmd; |
c = cmd; |
| strlcat(szLine, " ", STRSIZ); |
strlcat(szLine, " ", STRSIZ); |
|
Line 451 bufComp(int idx, void * __restrict cli_buffer)
|
Line 452 bufComp(int idx, void * __restrict cli_buffer)
|
| } else { |
} else { |
| /* we on 0 position of prompt, show commands for this level */ |
/* we on 0 position of prompt, show commands for this level */ |
| SLIST_FOREACH(cmd, &buf->line_cmds, cmd_next) { |
SLIST_FOREACH(cmd, &buf->line_cmds, cmd_next) { |
| if (cmd->cmd_level == buf->line_level) | if (cmd->cmd_level & (1 << buf->line_level)) |
| if (strncmp(cmd->cmd_name, CLI_CMD_SEP, strlen(CLI_CMD_SEP))) { |
if (strncmp(cmd->cmd_name, CLI_CMD_SEP, strlen(CLI_CMD_SEP))) { |
| j++; |
j++; |
| c = cmd; |
c = cmd; |
|
Line 498 bufHelp(int idx, void * __restrict cli_buffer)
|
Line 499 bufHelp(int idx, void * __restrict cli_buffer)
|
| if (!cli_buffer || idx < 0 || idx > MAX_BINDKEY) |
if (!cli_buffer || idx < 0 || idx > MAX_BINDKEY) |
| return RETCODE_ERR; |
return RETCODE_ERR; |
| |
|
| cli_Cmd_Help(buf, -1, NULL); | cli_Cmd_Help(buf, buf->line_level, NULL); |
| |
|
| printfEOL(buf, buf->line_len - 1, 1); |
printfEOL(buf, buf->line_len - 1, 1); |
| printfEOL(buf, -1, 1); |
printfEOL(buf, -1, 1); |
| return RETCODE_OK; |
return RETCODE_OK; |
| } |
} |
| |
|
| |
static int |
| |
bufEndNode(int idx, void * __restrict cli_buffer) |
| |
{ |
| |
linebuffer_t *buf = cli_buffer; |
| |
|
| |
if (!cli_buffer || idx < 0 || idx > MAX_BINDKEY) |
| |
return RETCODE_ERR; |
| |
|
| |
if (buf->line_level > 0) { |
| |
printfNL(cli_buffer, 0); |
| |
buf->line_level--; |
| |
cli_Printf(buf, "Enter to config level %d\n", buf->line_level); |
| |
} |
| |
|
| |
return bufCLR(idx, cli_buffer); |
| |
} |
| |
|
| |
|
| /* |
/* |
| * cli_Printf() - Send message to CLI session |
* cli_Printf() - Send message to CLI session |
| * |
* |
|
Line 585 cli_BindKey(bindkey_t * __restrict key, linebuffer_t *
|
Line 603 cli_BindKey(bindkey_t * __restrict key, linebuffer_t *
|
| * |
* |
| * @cli_buffer = CLI buffer |
* @cli_buffer = CLI buffer |
| * @csCmd = Command name |
* @csCmd = Command name |
| * @cliLevel = Level in CLI, -1 unprivi(view from all), 0 main config, 1 sub config ... | * @cliLevel = Level in CLI, -1 view from all levels, 0 hidden, >0 mask levels |
| * @funcCmd = Callback function when user call command |
* @funcCmd = Callback function when user call command |
| * @csInfo = Inline information for command |
* @csInfo = Inline information for command |
| * @csHelp = Help line when call help |
* @csHelp = Help line when call help |
|
Line 626 cli_addCommand(linebuffer_t * __restrict cli_buffer, c
|
Line 644 cli_addCommand(linebuffer_t * __restrict cli_buffer, c
|
| * |
* |
| * @cli_buffer = CLI buffer |
* @cli_buffer = CLI buffer |
| * @csCmd = Command name |
* @csCmd = Command name |
| * @cliLevel = Level in CLI, -1 unprivi(view from all), 0 main config, 1 sub config ... | * @cliLevel = Level in CLI, -1 view from all levels, 0 hidden, >0 mask levels |
| * return: RETCODE_ERR error, RETCODE_OK ok |
* return: RETCODE_ERR error, RETCODE_OK ok |
| */ |
*/ |
| int |
int |
|
Line 656 cli_delCommand(linebuffer_t * __restrict cli_buffer, c
|
Line 674 cli_delCommand(linebuffer_t * __restrict cli_buffer, c
|
| * |
* |
| * @cli_buffer = CLI buffer |
* @cli_buffer = CLI buffer |
| * @csCmd = Command name |
* @csCmd = Command name |
| * @cliLevel = Level in CLI, -1 unprivi(view from all), 0 main config, 1 sub config ... | * @cliLevel = Level in CLI, -1 view from all levels, 0 hidden, >0 mask levels |
| * @funcCmd = Callback function when user call command |
* @funcCmd = Callback function when user call command |
| * @csInfo = Inline information for command |
* @csInfo = Inline information for command |
| * @csHelp = Help line when call help |
* @csHelp = Help line when call help |
|
Line 675 cli_updCommand(linebuffer_t * __restrict cli_buffer, c
|
Line 693 cli_updCommand(linebuffer_t * __restrict cli_buffer, c
|
| return RETCODE_ERR; |
return RETCODE_ERR; |
| } |
} |
| |
|
| SLIST_FOREACH(cmd, &cli_buffer->line_cmds, cmd_next) | SLIST_FOREACH(cmd, &cli_buffer->line_cmds, cmd_next) |
| if (cmd->cmd_level == cliLevel && !strcmp(cmd->cmd_name, csCmd)) { | if ((!cmd->cmd_level || cmd->cmd_level == cliLevel) && |
| ret = 1; | !strcmp(cmd->cmd_name, csCmd)) { |
| if (!cmd->cmd_level) |
| | cmd->cmd_level = cliLevel; |
| if (funcCmd) |
if (funcCmd) |
| cmd->cmd_func = funcCmd; |
cmd->cmd_func = funcCmd; |
| if (csInfo) |
if (csInfo) |
|
Line 982 cliInit(int fin, int fout, const char *prompt)
|
Line 1001 cliInit(int fin, int fout, const char *prompt)
|
| } else |
} else |
| cli_buffer->line_eol = cli_buffer->line_bol = |
cli_buffer->line_eol = cli_buffer->line_bol = |
| strlen(cli_buffer->line_prompt); |
strlen(cli_buffer->line_prompt); |
| } | } else |
| | cli_buffer->line_mode = LINEMODE_OVER; |
| } |
} |
| cli_buffer->line_buf = e_malloc(BUFSIZ); |
cli_buffer->line_buf = e_malloc(BUFSIZ); |
| if (!cli_buffer->line_buf) { |
if (!cli_buffer->line_buf) { |
|
Line 1007 cliInit(int fin, int fout, const char *prompt)
|
Line 1027 cliInit(int fin, int fout, const char *prompt)
|
| memset(keys, 0, sizeof(bindkey_t) * (MAX_BINDKEY + 1)); |
memset(keys, 0, sizeof(bindkey_t) * (MAX_BINDKEY + 1)); |
| |
|
| /* add helper functions */ |
/* add helper functions */ |
| cli_addCommand(cli_buffer, "exit", 0, cli_Cmd_Exit, "exit <cr>", "Exit from console"); | cli_addCommand(cli_buffer, "exit", 1, cli_Cmd_Exit, "exit <cr>", "Exit from console"); |
| cli_addCommand(cli_buffer, "help", 0, cli_Cmd_Help, "help [command] <cr>", "Help screen"); | cli_addCommand(cli_buffer, "help", -1, cli_Cmd_Help, "help [command] <cr>", "Help screen"); |
| cli_addCommand(cli_buffer, "-------", 0, NULL, "-------------------------", NULL); | cli_addCommand(cli_buffer, "-------", -1, NULL, "-------------------------", NULL); |
| | cli_addCommand(cli_buffer, "where", -1, cli_Cmd_WhereAmI, "where <cr>", |
| | "Query current level of console"); |
| | cli_addCommand(cli_buffer, "top", -1, cli_Cmd_Top, "top <cr>", "Top level of console"); |
| | cli_addCommand(cli_buffer, "end", -1, cli_Cmd_End, "end <cr>", "End level of console"); |
| | cli_addCommand(cli_buffer, "config", -1, cli_Cmd_Config, "config <cr>", |
| | "Config next level of console"); |
| | cli_addCommand(cli_buffer, "-------", -1, NULL, "-------------------------", NULL); |
| |
|
| /* fill key bindings */ |
/* fill key bindings */ |
| /* ascii chars & ctrl+chars */ |
/* ascii chars & ctrl+chars */ |
|
Line 1021 cliInit(int fin, int fout, const char *prompt)
|
Line 1048 cliInit(int fin, int fout, const char *prompt)
|
| keys[i].key_func = bufEOF; |
keys[i].key_func = bufEOF; |
| if (i == *K_CTRL_M || i == *K_CTRL_J) |
if (i == *K_CTRL_M || i == *K_CTRL_J) |
| keys[i].key_func = bufEOL; |
keys[i].key_func = bufEOL; |
| if (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 (i == *K_CTRL_C) | if (cli_buffer->line_prompt && i == *K_CTRL_C) |
| keys[i].key_func = bufCLR; |
keys[i].key_func = bufCLR; |
| if (i == *K_CTRL_A) | if (cli_buffer->line_prompt && i == *K_CTRL_A) |
| keys[i].key_func = bufBEGIN; |
keys[i].key_func = bufBEGIN; |
| if (i == *K_CTRL_E) | if (cli_buffer->line_prompt && i == *K_CTRL_E) |
| keys[i].key_func = bufEND; |
keys[i].key_func = bufEND; |
| if (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) |
| |
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; |
| if (i > *K_BACKSPACE && i < 0xff) |
if (i > *K_BACKSPACE && i < 0xff) |
| keys[i].key_func = bufCHAR; |
keys[i].key_func = bufCHAR; |
| if (i == '?') | if (cli_buffer->line_prompt && i == '?') |
| keys[i].key_func = bufHelp; |
keys[i].key_func = bufHelp; |
| } |
} |
| /* alt+chars */ |
/* alt+chars */ |
|
Line 1131 cliInit(int fin, int fout, const char *prompt)
|
Line 1160 cliInit(int fin, int fout, const char *prompt)
|
| memcpy(keys[i].key_ch, K_CTRL_F12, keys[i].key_len); |
memcpy(keys[i].key_ch, K_CTRL_F12, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_HOME - 1; |
keys[i].key_len = sizeof K_HOME - 1; |
| keys[i].key_func = bufBEGIN; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufBEGIN; |
| memcpy(keys[i].key_ch, K_HOME, keys[i].key_len); |
memcpy(keys[i].key_ch, K_HOME, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_END - 1; |
keys[i].key_len = sizeof K_END - 1; |
| keys[i].key_func = bufEND; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufEND; |
| memcpy(keys[i].key_ch, K_END, keys[i].key_len); |
memcpy(keys[i].key_ch, K_END, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_UP - 1; |
keys[i].key_len = sizeof K_UP - 1; |
| keys[i].key_func = bufUP; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufUP; |
| memcpy(keys[i].key_ch, K_UP, keys[i].key_len); |
memcpy(keys[i].key_ch, K_UP, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_DOWN - 1; |
keys[i].key_len = sizeof K_DOWN - 1; |
| keys[i].key_func = bufDOWN; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufDOWN; |
| memcpy(keys[i].key_ch, K_DOWN, keys[i].key_len); |
memcpy(keys[i].key_ch, K_DOWN, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_RIGHT - 1; |
keys[i].key_len = sizeof K_RIGHT - 1; |
| keys[i].key_func = bufRIGHT; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufRIGHT; |
| memcpy(keys[i].key_ch, K_RIGHT, keys[i].key_len); |
memcpy(keys[i].key_ch, K_RIGHT, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_LEFT - 1; |
keys[i].key_len = sizeof K_LEFT - 1; |
| keys[i].key_func = bufLEFT; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufLEFT; |
| memcpy(keys[i].key_ch, K_LEFT, keys[i].key_len); |
memcpy(keys[i].key_ch, K_LEFT, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_BTAB - 1; |
keys[i].key_len = sizeof K_BTAB - 1; |
| keys[i].key_func = bufBTAB; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufBTAB; |
| memcpy(keys[i].key_ch, K_BTAB, keys[i].key_len); |
memcpy(keys[i].key_ch, K_BTAB, keys[i].key_len); |
| i++; |
i++; |
| /* 4 bytes */ |
/* 4 bytes */ |
| keys[i].key_len = sizeof K_INS - 1; |
keys[i].key_len = sizeof K_INS - 1; |
| keys[i].key_func = bufMODE; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufMODE; |
| memcpy(keys[i].key_ch, K_INS, keys[i].key_len); |
memcpy(keys[i].key_ch, K_INS, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_DEL - 1; |
keys[i].key_len = sizeof K_DEL - 1; |
| keys[i].key_func = bufDEL; | if (cli_buffer->line_prompt) |
| | keys[i].key_func = bufDEL; |
| memcpy(keys[i].key_ch, K_DEL, keys[i].key_len); |
memcpy(keys[i].key_ch, K_DEL, keys[i].key_len); |
| i++; |
i++; |
| keys[i].key_len = sizeof K_PGUP - 1; |
keys[i].key_len = sizeof K_PGUP - 1; |
|
Line 1216 cliInitLine(linebuffer_t * __restrict cli_buffer)
|
Line 1254 cliInitLine(linebuffer_t * __restrict cli_buffer)
|
| |
|
| memset(&t, 0, sizeof t); |
memset(&t, 0, sizeof t); |
| tcgetattr(cli_buffer->line_in, &t); |
tcgetattr(cli_buffer->line_in, &t); |
| t.c_lflag &= ~(ICANON | ISIG | IEXTEN | ECHO | ECHOCTL | ECHOE | ECHOK | ECHOKE | ECHONL | ECHOPRT); | t.c_lflag &= ~(ICANON | ISIG | IEXTEN | ECHO | |
| | ECHOCTL | ECHOE | ECHOK | ECHOKE | ECHONL | ECHOPRT); |
| t.c_iflag |= IGNBRK; |
t.c_iflag |= IGNBRK; |
| t.c_cc[VMIN] = 1; |
t.c_cc[VMIN] = 1; |
| t.c_cc[VTIME] = 0; |
t.c_cc[VTIME] = 0; |
|
Line 1227 cliInitLine(linebuffer_t * __restrict cli_buffer)
|
Line 1266 cliInitLine(linebuffer_t * __restrict cli_buffer)
|
| * cliReadLine() - Read line from opened CLI session |
* cliReadLine() - Read line from opened CLI session |
| * |
* |
| * @cli_buffer = CLI buffer |
* @cli_buffer = CLI buffer |
| |
* @timeout = Session timeout (-1 infinit) |
| |
* @cmd_name = If timeout reached, we should call with this cmd_name (default name is "exit") |
| * return: NULL if error or !=NULL readed line, must be e_free after use! |
* return: NULL if error or !=NULL readed line, must be e_free after use! |
| */ |
*/ |
| char * |
char * |
| cliReadLine(linebuffer_t * __restrict cli_buffer) | cliReadLine(linebuffer_t * __restrict cli_buffer, int timeout, const char *cmd_name) |
| { |
{ |
| int code, readLen; | int code, readLen, ret; |
| register int i; |
register int i; |
| struct pollfd fds; |
struct pollfd fds; |
| char buf[BUFSIZ], *str = NULL; |
char buf[BUFSIZ], *str = NULL; |
|
Line 1248 cliReadLine(linebuffer_t * __restrict cli_buffer)
|
Line 1289 cliReadLine(linebuffer_t * __restrict cli_buffer)
|
| |
|
| printfCR(cli_buffer, 1); |
printfCR(cli_buffer, 1); |
| while (42) { |
while (42) { |
| if (poll(&fds, 1, -1) < 1) { | if ((ret = poll(&fds, 1, timeout)) < 1) { |
| LOGERR; | if (!ret) { |
| | if (str) |
| | e_free(str); |
| | str = e_strdup(cmd_name ? cmd_name : "exit"); |
| | } else |
| | LOGERR; |
| return str; |
return str; |
| } |
} |
| |
|
|
Line 1304 recheck:
|
Line 1350 recheck:
|
| * @cli_buffer = CLI buffer |
* @cli_buffer = CLI buffer |
| * @csHistFile = History file name |
* @csHistFile = History file name |
| * @sock = client socket |
* @sock = client socket |
| |
* @timeout = Session timeout (-1 infinit) |
| |
* @cmd_name = If timeout reached, we should call with this cmd_name (default name is "exit") |
| * return: RETCODE_ERR error, RETCODE_OK ok |
* return: RETCODE_ERR error, RETCODE_OK ok |
| */ |
*/ |
| int |
int |
| cliNetLoop(linebuffer_t * __restrict cli_buffer, const char *csHistFile, int sock) | cliNetLoop(linebuffer_t * __restrict cli_buffer, const char *csHistFile, |
| | int sock, int timeout, const char *cmd_name) |
| { |
{ |
| u_char buf[BUFSIZ]; |
u_char buf[BUFSIZ]; |
| int pid, stat, pty, r, s, alen, flg, attrlen = 0, ret = 0; |
int pid, stat, pty, r, s, alen, flg, attrlen = 0, ret = 0; |
|
Line 1326 cliNetLoop(linebuffer_t * __restrict cli_buffer, const
|
Line 1375 cliNetLoop(linebuffer_t * __restrict cli_buffer, const
|
| } else |
} else |
| close(sock); |
close(sock); |
| |
|
| ret = cliLoop(cli_buffer, csHistFile) < 0 ? 1 : 0; | ret = cliLoop(cli_buffer, csHistFile, timeout, cmd_name) < 0 ? 1 : 0; |
| cliEnd(cli_buffer); |
cliEnd(cli_buffer); |
| |
|
| _exit(ret); |
_exit(ret); |
|
Line 1419 cliNetLoop(linebuffer_t * __restrict cli_buffer, const
|
Line 1468 cliNetLoop(linebuffer_t * __restrict cli_buffer, const
|
| * |
* |
| * @cli_buffer = CLI buffer |
* @cli_buffer = CLI buffer |
| * @csHistFile = History file name |
* @csHistFile = History file name |
| |
* @timeout = Session timeout (-1 infinit) |
| |
* @cmd_name = If timeout reached, we should call with this cmd_name (default name is "exit") |
| * return: RETCODE_ERR error, RETCODE_OK ok |
* return: RETCODE_ERR error, RETCODE_OK ok |
| */ |
*/ |
| int |
int |
| cliLoop(linebuffer_t * __restrict cli_buffer, const char *csHistFile) | cliLoop(linebuffer_t * __restrict cli_buffer, const char *csHistFile, |
| | int timeout, const char *cmd_name) |
| { |
{ |
| char *line, *s, *t, **app, *items[MAX_PROMPT_ITEMS]; |
char *line, *s, *t, **app, *items[MAX_PROMPT_ITEMS]; |
| register int i; |
register int i; |
|
Line 1436 cliLoop(linebuffer_t * __restrict cli_buffer, const ch
|
Line 1488 cliLoop(linebuffer_t * __restrict cli_buffer, const ch
|
| return RETCODE_ERR; |
return RETCODE_ERR; |
| |
|
| do { |
do { |
| line = cliReadLine(cli_buffer); | line = cliReadLine(cli_buffer, timeout, cmd_name); |
| if (!line) { |
if (!line) { |
| printfNL(cli_buffer, 0); |
printfNL(cli_buffer, 0); |
| break; |
break; |
|
Line 1451 cliLoop(linebuffer_t * __restrict cli_buffer, const ch
|
Line 1503 cliLoop(linebuffer_t * __restrict cli_buffer, const ch
|
| |
|
| if (*s) { |
if (*s) { |
| memset(items, 0, sizeof(char*) * MAX_PROMPT_ITEMS); |
memset(items, 0, sizeof(char*) * MAX_PROMPT_ITEMS); |
| for (app = items; app < items + MAX_PROMPT_ITEMS - 1 && (*app = strsep(&s, " \t")); | for (app = items; app < items + MAX_PROMPT_ITEMS - 1 && |
| *app ? app++ : app); | (*app = strsep(&s, " \t")); *app ? app++ : app); |
| |
|
| // exec_cmd ... |
// exec_cmd ... |
| i = 0; |
i = 0; |
| SLIST_FOREACH(cmd, &cli_buffer->line_cmds, cmd_next) { |
SLIST_FOREACH(cmd, &cli_buffer->line_cmds, cmd_next) { |
| |
if (!(cmd->cmd_level & (1 << cli_buffer->line_level))) |
| |
continue; |
| if (*items[0] && !strncmp(cmd->cmd_name, items[0], strlen(items[0]))) |
if (*items[0] && !strncmp(cmd->cmd_name, items[0], strlen(items[0]))) |
| break; |
break; |
| else |
else |
|
Line 1469 cliLoop(linebuffer_t * __restrict cli_buffer, const ch
|
Line 1523 cliLoop(linebuffer_t * __restrict cli_buffer, const ch
|
| } else |
} else |
| if (cmd->cmd_func) { |
if (cmd->cmd_func) { |
| cli_Printf(cli_buffer, "\n"); |
cli_Printf(cli_buffer, "\n"); |
| ret = cmd->cmd_func(cli_buffer, i, items); | ret = cmd->cmd_func(cli_buffer, |
| | cli_buffer->line_level, items); |
| } else { |
} else { |
| clrscrEOL(cli_buffer); |
clrscrEOL(cli_buffer); |
| printfCR(cli_buffer, 1); |
printfCR(cli_buffer, 1); |