Cygwin: pty: Take account of CR+NL line feed in input.
- Currently, individual CR or NL is treated as line feed in accept_input() and transfer_input(). This patch takes account of CR+NL as well.
This commit is contained in:
parent
51095fe2ba
commit
21860254da
|
@ -571,16 +571,21 @@ fhandler_pty_master::accept_input ()
|
|||
paranoid_printf ("about to write %u chars to slave", bytes_left);
|
||||
/* Write line by line for transfer input. */
|
||||
char *p0 = p;
|
||||
char *p1 = p;
|
||||
char *p_cr = (char *) memchr (p0, '\r', bytes_left - (p0 - p));
|
||||
char *p_nl = (char *) memchr (p0, '\n', bytes_left - (p0 - p));
|
||||
DWORD n;
|
||||
while ((p1 = (char *) memchr (p0, '\n', bytes_left - (p0 - p)))
|
||||
|| (p1 = (char *) memchr (p0, '\r', bytes_left - (p0 - p))))
|
||||
while (p_cr || p_nl)
|
||||
{
|
||||
char *p1 =
|
||||
p_cr ? (p_nl ? ((p_cr + 1 == p_nl)
|
||||
? p_nl : min(p_cr, p_nl)) : p_cr) : p_nl;
|
||||
n = p1 - p0 + 1;
|
||||
rc = WriteFile (write_to, p0, n, &n, NULL);
|
||||
if (rc)
|
||||
written += n;
|
||||
p0 = p1 + 1;
|
||||
p_cr = (char *) memchr (p0, '\r', bytes_left - (p0 - p));
|
||||
p_nl = (char *) memchr (p0, '\n', bytes_left - (p0 - p));
|
||||
}
|
||||
if (rc && (n = bytes_left - (p0 - p)))
|
||||
{
|
||||
|
@ -3905,16 +3910,20 @@ fhandler_pty_slave::transfer_input (tty::xfer_dir dir, HANDLE from, tty *ttyp,
|
|||
}
|
||||
/* Call WriteFile() line by line */
|
||||
char *p0 = ptr;
|
||||
char *p_cr, *p_nl;
|
||||
while ((p_cr = (char *) memchr (p0, '\r', len - (p0 - ptr)))
|
||||
|| (p_nl = (char *) memchr (p0, '\n', len - (p0 - ptr))))
|
||||
char *p_cr = (char *) memchr (p0, '\r', len - (p0 - ptr));
|
||||
char *p_nl = (char *) memchr (p0, '\n', len - (p0 - ptr));
|
||||
while (p_cr || p_nl)
|
||||
{
|
||||
char *p1 = p_cr ? (p_nl ? min (p_cr, p_nl) : p_cr) : p_nl;
|
||||
char *p1 =
|
||||
p_cr ? (p_nl ? ((p_cr + 1 == p_nl)
|
||||
? p_nl : min(p_cr, p_nl)) : p_cr) : p_nl;
|
||||
*p1 = '\n';
|
||||
n = p1 - p0 + 1;
|
||||
if (n && WriteFile (to, p0, n, &n, NULL) && n)
|
||||
transfered = true;
|
||||
p0 = p1 + 1;
|
||||
p_cr = (char *) memchr (p0, '\r', len - (p0 - ptr));
|
||||
p_nl = (char *) memchr (p0, '\n', len - (p0 - ptr));
|
||||
}
|
||||
n = len - (p0 - ptr);
|
||||
if (n && WriteFile (to, p0, n, &n, NULL) && n)
|
||||
|
|
Loading…
Reference in New Issue