about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--mach/devstream.c14
2 files changed, 15 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 1bf429ddce..e259705895 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Thu Mar 21 11:19:15 1996  Roland McGrath  <roland@charlie-brown.gnu.ai.mit.edu>
+
+	* mach/devstream.c (input): Translate \r to \n on input.
+
 Wed Mar 20 11:28:49 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>
 
 	* stdio-common/printf.h, stdio-common/printf_fp.c,
diff --git a/mach/devstream.c b/mach/devstream.c
index a2162db98b..c35e548dd2 100644
--- a/mach/devstream.c
+++ b/mach/devstream.c
@@ -1,7 +1,7 @@
 /* stdio on a Mach device port.
-   Translates \n to \r\n on output, echos input.
+   Translates \n to \r\n on output, echos and translates \r to \n on input.
 
-Copyright (C) 1992, 1993, 1994 Free Software Foundation, Inc.
+Copyright (C) 1992, 1993, 1994, 1996 Free Software Foundation, Inc.
 This file is part of the GNU C Library.
 
 The GNU C Library is free software; you can redistribute it and/or
@@ -63,6 +63,14 @@ input (FILE *f)
   err = device_write_inband ((device_t) f->__cookie, 0, f->__target,
 			     buffer, nread, (int *) &to_read);
 
+  /* Translate LF to CR.  */
+  {
+    char *p;
+    for (p = memchr (buffer, '\r', nread); p;
+	 p = memchr (p + 1, '\r', (buffer + nread) - (p + 1)))
+      *p = '\n';
+  }
+
   if (f->__buffer == NULL)
     return (unsigned char) c;
 
@@ -84,7 +92,7 @@ output (FILE *f, int c)
       while (to_write > 0)
 	{
 	  if (err = device_write ((device_t) f->__cookie, 0,
-				  f->__target, (char *)p, 
+				  f->__target, (char *)p,
 				  to_write, &wrote))
 	    {
 	      errno = err;