changeset 9280:a1f6fe4c68c1

Add support for QNX (untested).
author Bruno Haible <bruno@clisp.org>
date Wed, 03 Oct 2007 22:16:40 +0200
parents 079ab5207ac7
children 11622c689309
files ChangeLog lib/fbufmode.c lib/fpurge.c lib/freadable.c lib/freadahead.c lib/freading.c lib/fseeko.c lib/fseterr.c lib/fwritable.c lib/fwriting.c
diffstat 10 files changed, 51 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,16 @@
+2007-10-03  Bruno Haible  <bruno@clisp.org>
+
+	Port the stdio extensions to QNX (untested).
+	* lib/fseterr.c (fseterr): Add support for QNX.
+	* lib/fbufmode.c (fbufmode): Likewise.
+	* lib/freadable.c (freadable): Likewise.
+	* lib/fwritable.c (fwritable): Likewise.
+	* lib/freading.c (freading): Likewise.
+	* lib/fwriting.c (fwriting): Likewise.
+	* lib/freadahead.c (freadahed): Likewise.
+	* lib/fpurge.c (fpurge): Likewise.
+	* lib/fseeko.c (rpl_fseeko): Likewise.
+
 2007-10-03  Bruno Haible  <bruno@clisp.org>
             Jim Meyering  <jim@meyering.net>
             Eric Blake  <ebb9@byu.net>
--- a/lib/fbufmode.c
+++ b/lib/fbufmode.c
@@ -75,6 +75,12 @@
   if (fp->__modeflags & __FLAG_NBF)
     return _IONBF;
   return _IOFBF;
+#elif defined __QNX__               /* QNX */
+  if (fp->_Mode & _MLBF)
+    return _IOLBF;
+  if (fp->_Mode & _MNBF)
+    return _IONBF;
+  return _IOFBF;
 #else
  #error "Please port gnulib fbufmode.c to your platform! Look at the setvbuf implementation."
 #endif
--- a/lib/fpurge.c
+++ b/lib/fpurge.c
@@ -104,6 +104,15 @@
     fp->__bufpos = fp->__bufread;
 #  endif
   return 0;
+# elif defined __QNX__              /* QNX */
+  fp->_Rback = fp->_Back + sizeof (fp->_Back);
+  fp->_Rsave = NULL;
+  if (fp->_Mode & _MWRITE)
+    /* fp->_Buf <= fp->_Next <= fp->_Wend */
+    fp->_Next = fp->_Buf;
+  else
+    /* fp->_Buf <= fp->_Next <= fp->_Rend */
+    fp->_Rend = fp->_Next;
 # else
  #error "Please port gnulib fpurge.c to your platform! Look at the definitions of fflush, setvbuf and ungetc on your system, then report this to bug-gnulib."
 # endif
--- a/lib/freadable.c
+++ b/lib/freadable.c
@@ -32,7 +32,9 @@
   return (fp->_flags & (__SRW | __SRD)) != 0;
 #elif defined _IOERR                /* AIX, HP-UX, IRIX, OSF/1, Solaris, mingw */
   return (fp->_flag & (_IORW | _IOREAD)) != 0;
+#elif defined __QNX__               /* QNX */
+  return (fp->_Mode & _MOPENR) != 0;
 #else
- #error "Please port gnulib freadable.c to your platform!"
+ #error "Please port gnulib freadable.c to your platform! Look at the definition of fopen, fdopen on your system, then report this to bug-gnulib."
 #endif
 }
--- a/lib/freadahead.c
+++ b/lib/freadahead.c
@@ -56,6 +56,11 @@
 # else
   return 0;
 # endif
+#elif defined __QNX__               /* QNX */
+  if ((fp->_Mode & _MWRITE) != 0)
+    return 0;
+  /* fp->_Buf <= fp->_Next <= fp->_Rend */
+  return fp->_Rend - fp->_Next;
 #else
  #error "Please port gnulib freadahead.c to your platform! Look at the definition of fflush, fread on your system, then report this to bug-gnulib."
 #endif
--- a/lib/freading.c
+++ b/lib/freading.c
@@ -40,6 +40,9 @@
   return (fp->_flag & _IOREAD) != 0;
 #elif defined __UCLIBC__            /* uClibc */
   return (fp->__modeflags & (__FLAG_READONLY | __FLAG_READING)) != 0;
+#elif defined __QNX__               /* QNX */
+  return ((fp->_Mode & _MOPENW) == 0
+	  || (fp->_Mode & _MREAD) != 0);
 #else
  #error "Please port gnulib freading.c to your platform!"
 #endif
--- a/lib/fseeko.c
+++ b/lib/fseeko.c
@@ -90,6 +90,10 @@
        || fp->__bufpos == fp->__bufstart)
       && ((fp->__modeflags & (__FLAG_READONLY | __FLAG_READING)) == 0
 	  || fp->__bufpos == fp->__bufread))
+#elif defined __QNX__               /* QNX */
+  if ((fp->_Mode & _MWRITE ? fp->_Next == fp->_Buf : fp->_Next == fp->_Rend)
+      && fp->_Rback == fp->_Back + sizeof (fp->_Back)
+      && fp->_Rsave == NULL)
 #else
   #error "Please port gnulib fseeko.c to your platform! Look at the code in fpurge.c, then report this to bug-gnulib."
 #endif
--- a/lib/fseterr.c
+++ b/lib/fseterr.c
@@ -47,6 +47,8 @@
 # endif
 #elif defined __UCLIBC__            /* uClibc */
   fp->__modeflags |= __FLAG_ERROR;
+#elif defined __QNX__               /* QNX */
+  fp->_Mode |= _MERR;
 #elif 0                             /* unknown  */
   /* Portable fallback, based on an idea by Rich Felker.
      Wow! 6 system calls for something that is just a bit operation!
--- a/lib/fwritable.c
+++ b/lib/fwritable.c
@@ -32,7 +32,9 @@
   return (fp->_flags & (__SRW | __SWR)) != 0;
 #elif defined _IOERR                /* AIX, HP-UX, IRIX, OSF/1, Solaris, mingw */
   return (fp->_flag & (_IORW | _IOWRT)) != 0;
+#elif defined __QNX__               /* QNX */
+  return (fp->_mode & _MOPENW) != 0;
 #else
- #error "Please port gnulib fwritable.c to your platform!"
+ #error "Please port gnulib fwritable.c to your platform! Look at the definition of fopen, fdopen on your system, then report this to bug-gnulib."
 #endif
 }
--- a/lib/fwriting.c
+++ b/lib/fwriting.c
@@ -34,6 +34,9 @@
   return (fp->_flag & _IOWRT) != 0;
 #elif defined __UCLIBC__            /* uClibc */
   return (fp->__modeflags & __FLAG_WRITING) != 0;
+#elif defined __QNX__               /* QNX */
+  return ((fp->_Mode & _MOPENR) == 0
+	  || (fp->_Mode & _MWRITE) != 0);
 #else
  #error "Please port gnulib fwriting.c to your platform!"
 #endif