X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Ffputc.c;h=ae998eaacb0562c01070589c56f4400ae9451c8c;hb=84d648157e22cecc65902ecfdd4e3a1b88d5e53f;hp=8f9737884b43f972beaa2cc56d7d1fe0d11b979c;hpb=a6dd99e5c0b3af81082d24751218c21f7f3e7443;p=pdclib.old diff --git a/functions/stdio/fputc.c b/functions/stdio/fputc.c index 8f97378..ae998ea 100644 --- a/functions/stdio/fputc.c +++ b/functions/stdio/fputc.c @@ -10,27 +10,38 @@ #ifndef REGTEST +#include <_PDCLIB_glue.h> + /* Write the value c (cast to unsigned char) to the given stream. Returns c if successful, EOF otherwise. - If a write error occurs, sets the error indicator of the stream is set. + If a write error occurs, the error indicator of the stream is set. */ -int fputc( int c, struct _PDCLIB_file_t * stream ) +int fputc_unlocked( int c, struct _PDCLIB_file_t * stream ) { - /* FIXME: This is devoid of any error checking (file writeable? r/w - constraints honored?) (Text format translations?) - */ + if ( _PDCLIB_prepwrite( stream ) == EOF ) + { + return EOF; + } stream->buffer[stream->bufidx++] = (char)c; if ( ( stream->bufidx == stream->bufsize ) /* _IOFBF */ - || ( ( stream->status & _IOLBF ) && (char)c == '\n' ) /* _IOLBF */ + || ( ( stream->status & _IOLBF ) && ( (char)c == '\n' ) ) /* _IOLBF */ || ( stream->status & _IONBF ) /* _IONBF */ ) { /* buffer filled, unbuffered stream, or end-of-line. */ - fflush( stream ); + return ( _PDCLIB_flushbuffer( stream ) == 0 ) ? c : EOF; } return c; } +int fputc( int c, struct _PDCLIB_file_t * stream ) +{ + flockfile( stream ); + int r = fputc_unlocked( c, stream ); + funlockfile( stream ); + return r; +} + #endif #ifdef TEST @@ -38,7 +49,7 @@ int fputc( int c, struct _PDCLIB_file_t * stream ) int main( void ) { - TESTCASE( NO_TESTDRIVER ); + /* Testing covered by ftell.c */ return TEST_RESULTS; }