]> pd.if.org Git - pdclib/blobdiff - functions/stdio/clearerr.c
A couple of artifacts resulting in compile errors. Fixed.
[pdclib] / functions / stdio / clearerr.c
index 6d80c8aeb381639c62b9fbf0a4194ff68b083bc7..2bfe7c508448eb92830605de1f78031825ef16d2 100644 (file)
@@ -22,7 +22,36 @@ void clearerr( struct _PDCLIB_file_t * stream )
 
 int main( void )
 {
+#ifndef REGTEST
+    FILE file = { 0, { 0, 0 }, NULL, 0, 0, 0, _IONBF, NULL, NULL };
+    FILE * fh = &file;
+    TESTCASE( ! ferror( fh ) );
+    TESTCASE( ! feof( fh ) );
+    fh->status |= _PDCLIB_ERRORFLAG;
+    TESTCASE( ferror( fh ) );
+    TESTCASE( ! feof( fh ) );
+    clearerr( fh );
+    TESTCASE( ! ferror( fh ) );
+    TESTCASE( ! feof( fh ) );
+    fh->status |= _PDCLIB_EOFFLAG;
+    TESTCASE( ! ferror( fh ) );
+    TESTCASE( feof( fh ) );
+    clearerr( fh );
+    TESTCASE( ! ferror( fh ) );
+    TESTCASE( ! feof( fh ) );
+    fh->status |= _PDCLIB_EOFFLAG | _PDCLIB_ERRORFLAG;
+    TESTCASE( ferror( fh ) );
+    TESTCASE( feof( fh ) );
+    clearerr( fh );
+    TESTCASE( ! ferror( fh ) );
+    TESTCASE( ! feof( fh ) );
+#else
+    /* TODO: The above is ad-hoc and PDCLib specific. A better test driver
+       should be internals-agnostic (provoking the error / eof flag by
+       "regular" operations).
+    */
     TESTCASE( NO_TESTDRIVER );
+#endif
     return TEST_RESULTS;
 }