Attempt to resolve #1568 and add basic escape character support
This commit is contained in:
parent
273d00353f
commit
99fb1bc3e8
@ -730,7 +730,6 @@ void get_command()
|
|||||||
serial_char = MYSERIAL.read();
|
serial_char = MYSERIAL.read();
|
||||||
if(serial_char == '\n' ||
|
if(serial_char == '\n' ||
|
||||||
serial_char == '\r' ||
|
serial_char == '\r' ||
|
||||||
(serial_char == ':' && comment_mode == false) ||
|
|
||||||
serial_count >= (MAX_CMD_SIZE - 1) )
|
serial_count >= (MAX_CMD_SIZE - 1) )
|
||||||
{
|
{
|
||||||
if(!serial_count) { //if empty line
|
if(!serial_count) { //if empty line
|
||||||
@ -739,7 +738,6 @@ void get_command()
|
|||||||
}
|
}
|
||||||
cmdbuffer[bufindw][serial_count] = 0; //terminate string
|
cmdbuffer[bufindw][serial_count] = 0; //terminate string
|
||||||
if(!comment_mode){
|
if(!comment_mode){
|
||||||
comment_mode = false; //for new command
|
|
||||||
fromsd[bufindw] = false;
|
fromsd[bufindw] = false;
|
||||||
if(strchr(cmdbuffer[bufindw], 'N') != NULL)
|
if(strchr(cmdbuffer[bufindw], 'N') != NULL)
|
||||||
{
|
{
|
||||||
@ -823,8 +821,17 @@ void get_command()
|
|||||||
}
|
}
|
||||||
serial_count = 0; //clear buffer
|
serial_count = 0; //clear buffer
|
||||||
}
|
}
|
||||||
else
|
else if(serial_char == '\\') { //Handle escapes
|
||||||
{
|
|
||||||
|
if(MYSERIAL.available() > 0 && buflen < BUFSIZE) {
|
||||||
|
// if we have one more character, copy it over
|
||||||
|
MYSERIAL.read();
|
||||||
|
cmdbuffer[bufindw][serial_count++] = serial_char;
|
||||||
|
}
|
||||||
|
|
||||||
|
//otherwise do nothing
|
||||||
|
}
|
||||||
|
else { // its not a newline, carriage return or escape char
|
||||||
if(serial_char == ';') comment_mode = true;
|
if(serial_char == ';') comment_mode = true;
|
||||||
if(!comment_mode) cmdbuffer[bufindw][serial_count++] = serial_char;
|
if(!comment_mode) cmdbuffer[bufindw][serial_count++] = serial_char;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user