mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Allow terminating OSC sequences during setup.
A user reports that the xterm OSC 112 sequence (reset cursor colour) is sometimes sent as simply OSC 112 BEL, rather than OSC 112 ; BEL. When xterm parses this, the BEL still acts as an OSC terminator, even though it appears before the separating semicolon that shifts into the 'absorb the notional command string' state. PuTTY doesn't support that sequence at all. But currently, the way it doesn't support it is by treating the BEL completely normally, so that you get an annoying beep when a client application sends that abbreviated sequence. Now we recognise all the OSC terminator sequences even in the OSC setup termstates, as well as the final OSC_STRING state. That goes equally for BEL, ST in the form of ESC \, ST in the form of single-byte 0x9C, and ST in the UTF-8 encoding.
This commit is contained in:
parent
e9de549e7e
commit
de66b0313a
@ -3822,6 +3822,19 @@ static void term_out(Terminal *term, bool called_from_term_data)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case '\007': { /* BEL: Bell */
|
case '\007': { /* BEL: Bell */
|
||||||
|
if (term->termstate == SEEN_OSC ||
|
||||||
|
term->termstate == SEEN_OSC_W) {
|
||||||
|
/*
|
||||||
|
* In an OSC context, BEL is one of the ways to terminate
|
||||||
|
* the whole sequence. We process it as such even if we
|
||||||
|
* haven't got into the final OSC_STRING state yet, so that
|
||||||
|
* OSC sequences without a string will be handled cleanly.
|
||||||
|
*/
|
||||||
|
do_osc(term);
|
||||||
|
term->termstate = TOPLEVEL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
struct beeptime *newbeep;
|
struct beeptime *newbeep;
|
||||||
unsigned long ticks;
|
unsigned long ticks;
|
||||||
|
|
||||||
@ -3907,7 +3920,11 @@ static void term_out(Terminal *term, bool called_from_term_data)
|
|||||||
case '\033': /* ESC: Escape */
|
case '\033': /* ESC: Escape */
|
||||||
if (term->vt52_mode)
|
if (term->vt52_mode)
|
||||||
term->termstate = VT52_ESC;
|
term->termstate = VT52_ESC;
|
||||||
else {
|
else if (term->termstate == SEEN_OSC ||
|
||||||
|
term->termstate == SEEN_OSC_W) {
|
||||||
|
/* Be prepared to terminate an OSC early */
|
||||||
|
term->termstate = OSC_MAYBE_ST;
|
||||||
|
} else {
|
||||||
compatibility(ANSIMIN);
|
compatibility(ANSIMIN);
|
||||||
term->termstate = SEEN_ESC;
|
term->termstate = SEEN_ESC;
|
||||||
term->esc_query = 0;
|
term->esc_query = 0;
|
||||||
@ -5156,6 +5173,17 @@ static void term_out(Terminal *term, bool called_from_term_data)
|
|||||||
else
|
else
|
||||||
term->esc_args[term->esc_nargs-1] = UINT_MAX;
|
term->esc_args[term->esc_nargs-1] = UINT_MAX;
|
||||||
break;
|
break;
|
||||||
|
case 0x9C:
|
||||||
|
/* Terminate even though we aren't in OSC_STRING yet */
|
||||||
|
do_osc(term);
|
||||||
|
term->termstate = TOPLEVEL;
|
||||||
|
break;
|
||||||
|
case 0xC2:
|
||||||
|
if (in_utf(term)) {
|
||||||
|
/* Or be prepared for the UTF-8 version of that */
|
||||||
|
term->termstate = OSC_MAYBE_ST_UTF8;
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
/*
|
/*
|
||||||
* _Most_ other characters here terminate the
|
* _Most_ other characters here terminate the
|
||||||
@ -5325,6 +5353,17 @@ static void term_out(Terminal *term, bool called_from_term_data)
|
|||||||
else
|
else
|
||||||
term->esc_args[0] = UINT_MAX;
|
term->esc_args[0] = UINT_MAX;
|
||||||
break;
|
break;
|
||||||
|
case 0x9C:
|
||||||
|
/* Terminate even though we aren't in OSC_STRING yet */
|
||||||
|
do_osc(term);
|
||||||
|
term->termstate = TOPLEVEL;
|
||||||
|
break;
|
||||||
|
case 0xC2:
|
||||||
|
if (in_utf(term)) {
|
||||||
|
/* Or be prepared for the UTF-8 version of that */
|
||||||
|
term->termstate = OSC_MAYBE_ST_UTF8;
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
term->termstate = OSC_STRING;
|
term->termstate = OSC_STRING;
|
||||||
term->osc_strlen = 0;
|
term->osc_strlen = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user