Skip to content

Commit

Permalink
extract XTVERSION, drain XTSMGRAPHICS on failure #1469
Browse files Browse the repository at this point in the history
  • Loading branch information
dankamongmen committed Jun 13, 2021
1 parent c0b724e commit 398ebca
Showing 1 changed file with 11 additions and 2 deletions.
13 changes: 11 additions & 2 deletions src/lib/input.c
Original file line number Diff line number Diff line change
Expand Up @@ -624,6 +624,7 @@ typedef struct init_state {
STATE_XTGETTCAP1, // XTGETTCAP, got '0/1' (DCS 0/1 + r Pt ST)
STATE_XTGETTCAP2, // XTGETTCAP, got '+' (DCS 0/1 + r Pt ST)
STATE_XTGETTCAP3, // XTGETTCAP, got 'r' (DCS 0/1 + r Pt ST)
STATE_DCS_DRAIN, // throw away input until we hit escape
STATE_TDA, // tertiary DA
STATE_SDA, // secondary DA (CSI > Pp ; Pv ; Pc c)
STATE_DA, // primary DA (CSI ? ... c) OR XTSMGRAPHICS
Expand Down Expand Up @@ -651,7 +652,7 @@ static int
pump_control_read(init_state* inits, unsigned char c){
fprintf(stderr, "state: %2d char: %1c %3d %02x\n", inits->state, isprint(c) ? c : ' ', c, c);
if(c == NCKEY_ESC){
if(inits->state != STATE_NULL && inits->state != STATE_DCS && inits->state != STATE_XTGETTCAP3){
if(inits->state != STATE_NULL && inits->state != STATE_DCS && inits->state != STATE_DCS_DRAIN && inits->state != STATE_XTVERSION2 && inits->state != STATE_XTGETTCAP3 && inits->state != STATE_DA_DRAIN){
fprintf(stderr, "Unexpected escape in state %d\n", inits->state);
}
inits->state = STATE_ESC;
Expand Down Expand Up @@ -694,16 +695,22 @@ pump_control_read(init_state* inits, unsigned char c){
}else if(c == '>'){
inits->state = STATE_XTVERSION1;
}else{
// FIXME error?
inits->state = STATE_DCS_DRAIN;
}
break;
case STATE_DCS_DRAIN:
// we drain to ST, which is an escape, and thus already handled, so...
break;
case STATE_XTVERSION1:
if(c == '|'){
inits->state = STATE_XTVERSION2;
}else{
// FIXME error?
}
break;
case STATE_XTVERSION2:
// FIXME roll up string
break;
case STATE_XTGETTCAP1:
if(c == '+'){
inits->state = STATE_XTGETTCAP2;
Expand Down Expand Up @@ -810,6 +817,8 @@ pump_control_read(init_state* inits, unsigned char c){
case STATE_SIXEL_SEMI1:
if(c == '0'){
inits->state = STATE_SIXEL_SUCCESS;
}else if(c == '2'){
inits->state = STATE_XTSMGRAPHICS_DRAIN;
}else{
// FIXME error?
}
Expand Down

0 comments on commit 398ebca

Please sign in to comment.