Formerly ../mach/devstream.c.~16~
[kopensolaris-gnu/glibc.git] / mach / devstream.c
index 851bb6c..cb1dfb6 100644 (file)
@@ -1,7 +1,7 @@
 /* stdio on a Mach device port.
    Translates \n to \r\n on output.
 
-Copyright (C) 1992 Free Software Foundation, Inc.
+Copyright (C) 1992, 1993, 1994 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
@@ -30,7 +30,8 @@ input (FILE *f)
 {
   kern_return_t err;
   char *buffer;
-  size_t to_read, nread;
+  size_t to_read;
+  mach_msg_type_size_t nread;
   char c;
 
   if (f->__buffer == NULL)
@@ -46,6 +47,7 @@ input (FILE *f)
 
   f->__eof = 0;
 
+  nread = to_read;
   if (err = device_read_inband ((device_t) f->__cookie, 0, f->__target,
                                to_read, buffer, &nread))
     {
@@ -64,6 +66,67 @@ input (FILE *f)
   return (unsigned char) *f->__bufp++;
 }
 
+
+static void
+output (FILE *f, int c)
+{
+  inline void write_some (const char *p, size_t to_write)
+    {
+      kern_return_t err;
+      int wrote;
+      while (to_write > 0)
+       {
+         if (err = device_write ((device_t) f->__cookie, 0,
+                                 f->__target, (char *)p, 
+                                 to_write, &wrote))
+           {
+             errno = err;
+             f->__error = 1;
+             break;
+           }
+         p += wrote;
+         to_write -= wrote;
+         f->__target += wrote;
+       }
+    }
+
+  if (f->__buffer != NULL)
+    {
+      if (f->__put_limit == f->__buffer)
+       {
+         /* Prime the stream for writing.  */
+         f->__put_limit = f->__buffer + f->__bufsize;
+         f->__bufp = f->__buffer;
+         if (c != EOF)
+           {
+             *f->__bufp++ = (unsigned char) c;
+             c = EOF;
+           }
+       }
+
+
+      /* Write out the buffer.  */
+
+      write_some (f->__buffer, f->__bufp - f->__buffer);
+
+      f->__bufp = f->__buffer;
+    }
+
+  if (c != EOF && !ferror (f))
+    {
+      if (f->__linebuf && (unsigned char) c == '\n')
+       {
+         static const char nl = '\n';
+         write_some (&nl, 1);
+       }
+      else
+       *f->__bufp++ = (unsigned char) c;
+    }
+}
+
+
+
+#if 0                          /* Translates \n to \r\n.  */
 static void
 output (FILE *f, int c)
 {
@@ -153,9 +216,10 @@ output (FILE *f, int c)
        *f->__bufp++ = (unsigned char) c;
     }
 }
+#endif
 
 FILE *
-mach_open_devstream (device_t dev, const char *mode)
+mach_open_devstream (mach_port_t dev, const char *mode)
 {
   FILE *stream = fopencookie ((void *) dev, mode, __default_io_functions);
   if (stream == NULL)
@@ -163,7 +227,7 @@ mach_open_devstream (device_t dev, const char *mode)
 
   stream->__room_funcs.__input = input;
   stream->__room_funcs.__output = output;
-  stream->__io_funcs.__close = device_close;
+  stream->__io_funcs.__close = (__io_close_fn *) device_close;
   stream->__seen = 1;
 
   return stream;