1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

Fix `telnet-resize-iac'. (IAC bytes were not duplicated when they

occurred in a NAWS subnegotiation. Result: a terminal width or
height of 255 was not being correctly sent to the server.)

[originally from svn r2421]
This commit is contained in:
Simon Tatham 2003-01-02 11:14:35 +00:00
parent a298b2fe4b
commit 50fbac19eb

View File

@ -786,7 +786,8 @@ static int telnet_sendbuffer(void *handle)
static void telnet_size(void *handle, int width, int height) static void telnet_size(void *handle, int width, int height)
{ {
Telnet telnet = (Telnet) handle; Telnet telnet = (Telnet) handle;
unsigned char b[16]; unsigned char b[24];
int n;
char *logbuf; char *logbuf;
telnet->term_width = width; telnet->term_width = width;
@ -794,19 +795,23 @@ static void telnet_size(void *handle, int width, int height)
if (telnet->s == NULL || telnet->opt_states[o_naws.index] != ACTIVE) if (telnet->s == NULL || telnet->opt_states[o_naws.index] != ACTIVE)
return; return;
b[0] = IAC; n = 0;
b[1] = SB; b[n++] = IAC;
b[2] = TELOPT_NAWS; b[n++] = SB;
b[3] = telnet->term_width >> 8; b[n++] = TELOPT_NAWS;
b[4] = telnet->term_width & 0xFF; b[n++] = telnet->term_width >> 8;
b[5] = telnet->term_height >> 8; if (b[n-1] == IAC) b[n++] = IAC; /* duplicate any IAC byte occurs */
b[6] = telnet->term_height & 0xFF; b[n++] = telnet->term_width & 0xFF;
b[7] = IAC; if (b[n-1] == IAC) b[n++] = IAC; /* duplicate any IAC byte occurs */
b[8] = SE; b[n++] = telnet->term_height >> 8;
telnet->bufsize = sk_write(telnet->s, b, 9); if (b[n-1] == IAC) b[n++] = IAC; /* duplicate any IAC byte occurs */
b[n++] = telnet->term_height & 0xFF;
if (b[n-1] == IAC) b[n++] = IAC; /* duplicate any IAC byte occurs */
b[n++] = IAC;
b[n++] = SE;
telnet->bufsize = sk_write(telnet->s, b, n);
logbuf = dupprintf("client:\tSB NAWS %d,%d", logbuf = dupprintf("client:\tSB NAWS %d,%d",
((unsigned char) b[3] << 8) + (unsigned char) b[4], telnet->term_width, telnet->term_height);
((unsigned char) b[5] << 8) + (unsigned char) b[6]);
logevent(telnet->frontend, logbuf); logevent(telnet->frontend, logbuf);
sfree(logbuf); sfree(logbuf);
} }