Merge pull request #786 from devsaurus/fix-cr
Re-add detection of CR as newline. Fixes #784 and fixes #785.
This commit is contained in:
commit
6488c95476
|
@ -541,6 +541,7 @@ extern bool uart0_echo;
|
|||
extern bool run_input;
|
||||
extern uint16_t need_len;
|
||||
extern int16_t end_char;
|
||||
static char last_nl_char = '\0';
|
||||
static bool readline(lua_Load *load){
|
||||
// NODE_DBG("readline() is called.\n");
|
||||
bool need_dojob = false;
|
||||
|
@ -549,11 +550,18 @@ static bool readline(lua_Load *load){
|
|||
{
|
||||
if(run_input)
|
||||
{
|
||||
/* skip CR key */
|
||||
if (ch == '\r')
|
||||
char tmp_last_nl_char = last_nl_char;
|
||||
// reset marker, will be finally set below when newline is processed
|
||||
last_nl_char = '\0';
|
||||
|
||||
/* handle CR & LF characters
|
||||
filters second char of LF&CR (\n\r) or CR&LF (\r\n) sequences */
|
||||
if ((ch == '\r' && tmp_last_nl_char == '\n') || // \n\r sequence -> skip \r
|
||||
(ch == '\n' && tmp_last_nl_char == '\r')) // \r\n sequence -> skip \n
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
/* backspace key */
|
||||
else if (ch == 0x7f || ch == 0x08)
|
||||
{
|
||||
|
@ -578,8 +586,10 @@ static bool readline(lua_Load *load){
|
|||
// }
|
||||
|
||||
/* end of line */
|
||||
if (ch == '\n')
|
||||
if (ch == '\r' || ch == '\n')
|
||||
{
|
||||
last_nl_char = ch;
|
||||
|
||||
load->line[load->line_position] = 0;
|
||||
if(uart0_echo) uart_putc('\n');
|
||||
uart_on_data_cb(load->line, load->line_position);
|
||||
|
|
Loading…
Reference in New Issue