uart_commands.c: Backspace/Delete capability
This commit is contained in:
parent
cc060261d4
commit
b9471a6637
1 changed files with 34 additions and 18 deletions
|
@ -29,20 +29,21 @@ volatile unsigned char mode;
|
||||||
char const UART_STR_NOTIMPL[] PROGMEM = "\r\nnot implemented";
|
char const UART_STR_NOTIMPL[] PROGMEM = "\r\nnot implemented";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
char const UART_STR_PROMPT[] PROGMEM = "\r\n> ";
|
char const UART_STR_BACKSPACE[] PROGMEM = "\033[D \033[D";
|
||||||
char const UART_STR_ERROR[] PROGMEM = "\r\ntransmission error";
|
char const UART_STR_PROMPT[] PROGMEM = "\r\n> ";
|
||||||
char const UART_STR_UNKNOWN[] PROGMEM = "\r\nunknown command";
|
char const UART_STR_ERROR[] PROGMEM = "\r\ntransmission error";
|
||||||
char const UART_STR_TOOLONG[] PROGMEM = "\r\ncommand to long";
|
char const UART_STR_UNKNOWN[] PROGMEM = "\r\nunknown command";
|
||||||
char const UART_STR_HELP[] PROGMEM = "\r\nallowed commands: "
|
char const UART_STR_TOOLONG[] PROGMEM = "\r\ncommand to long";
|
||||||
"erase help msg next prev reset scroll";
|
char const UART_STR_HELP[] PROGMEM = "\r\nallowed commands: erase help "
|
||||||
|
"msg next prev reset scroll";
|
||||||
|
|
||||||
char const UART_CMD_ERASE[] PROGMEM = "erase";
|
char const UART_CMD_ERASE[] PROGMEM = "erase";
|
||||||
char const UART_CMD_HELP[] PROGMEM = "help";
|
char const UART_CMD_HELP[] PROGMEM = "help";
|
||||||
char const UART_CMD_MSG[] PROGMEM = "msg ";
|
char const UART_CMD_MSG[] PROGMEM = "msg ";
|
||||||
char const UART_CMD_NEXT[] PROGMEM = "next";
|
char const UART_CMD_NEXT[] PROGMEM = "next";
|
||||||
char const UART_CMD_PREV[] PROGMEM = "prev";
|
char const UART_CMD_PREV[] PROGMEM = "prev";
|
||||||
char const UART_CMD_RESET[] PROGMEM = "reset";
|
char const UART_CMD_RESET[] PROGMEM = "reset";
|
||||||
char const UART_CMD_SCROLL[] PROGMEM = "scroll ";
|
char const UART_CMD_SCROLL[] PROGMEM = "scroll ";
|
||||||
|
|
||||||
|
|
||||||
bool g_uartcmd_permit_processing = 1;
|
bool g_uartcmd_permit_processing = 1;
|
||||||
|
@ -164,12 +165,27 @@ static bool uartcmd_read_until_enter(void) {
|
||||||
|
|
||||||
switch (uart_result & 0xFF00u) {
|
switch (uart_result & 0xFF00u) {
|
||||||
case 0:
|
case 0:
|
||||||
if (!(uart_result == '\r' || uart_result == '\n')) {
|
switch ((char)uart_result) {
|
||||||
|
case '\r': // carriage return
|
||||||
|
case '\n': // line feed
|
||||||
|
if (g_rx_index != 0) {
|
||||||
|
g_rx_buffer[g_rx_index++] = 0;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case '\b': // BS
|
||||||
|
case '\177': // DEL
|
||||||
|
if (g_rx_index != 0) {
|
||||||
|
g_rx_buffer[--g_rx_index] = 0;
|
||||||
|
uart_puts_p(UART_STR_BACKSPACE);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 27: // ignore Esc
|
||||||
|
break;
|
||||||
|
default:
|
||||||
g_rx_buffer[g_rx_index++] = uart_result;
|
g_rx_buffer[g_rx_index++] = uart_result;
|
||||||
uart_putc(uart_result);
|
uart_putc(uart_result);
|
||||||
} else {
|
break;
|
||||||
g_rx_buffer[g_rx_index++] = 0;
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -202,7 +218,7 @@ static bool uartcmd_read_until_enter(void) {
|
||||||
*/
|
*/
|
||||||
void uartcmd_process(void) {
|
void uartcmd_process(void) {
|
||||||
if (uartcmd_processing_allowed() && uartcmd_read_until_enter()) {
|
if (uartcmd_processing_allowed() && uartcmd_read_until_enter()) {
|
||||||
if (!strncmp_P(g_rx_buffer, UART_CMD_ERASE, 5)) {
|
if (!strncmp_P(g_rx_buffer, UART_CMD_ERASE, UART_BUFFER_SIZE)) {
|
||||||
uartcmd_erase_eeprom();
|
uartcmd_erase_eeprom();
|
||||||
} else if (!strncmp_P(g_rx_buffer, UART_CMD_HELP, UART_BUFFER_SIZE)) {
|
} else if (!strncmp_P(g_rx_buffer, UART_CMD_HELP, UART_BUFFER_SIZE)) {
|
||||||
uart_puts_p(UART_STR_HELP);
|
uart_puts_p(UART_STR_HELP);
|
||||||
|
|
Loading…
Reference in a new issue