X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdio%2Fgets.c;h=798df766c08590d1d3953667714f3331a105becb;hb=HEAD;hp=6cefc486f5c14ddf58ed8636b1a7116b442886c9;hpb=d02c3e151568281380732d9a6f4849a8d7e5d2fb;p=pdclib.old diff --git a/functions/stdio/gets.c b/functions/stdio/gets.c index 6cefc48..798df76 100644 --- a/functions/stdio/gets.c +++ b/functions/stdio/gets.c @@ -9,29 +9,28 @@ #include #ifndef REGTEST - -#define _PDCLIB_GLUE_H _PDCLIB_GLUE_H -#include <_PDCLIB_glue.h> +#include <_PDCLIB_io.h> +#include char * gets( char * s ) { + _PDCLIB_flockfile( stdin ); if ( _PDCLIB_prepread( stdin ) == EOF ) { + _PDCLIB_funlockfile( stdin ); return NULL; } char * dest = s; - while ( ( *dest = stdin->buffer[stdin->bufidx++] ) != '\n' ) - { - ++dest; - if ( stdin->bufidx == stdin->bufend ) - { - if ( _PDCLIB_fillbuffer( stdin ) == EOF ) - { - break; - } - } + + dest += _PDCLIB_getchars( dest, SIZE_MAX, '\n', stdin ); + _PDCLIB_funlockfile( stdin ); + + if(*(dest - 1) == '\n') { + *(--dest) = '\0'; + } else { + *dest = '\0'; } - *dest = '\0'; + return ( dest == s ) ? NULL : s; } @@ -63,7 +62,8 @@ int main( void ) TESTCASE( feof( fh ) ); TESTCASE( fseek( fh, 0, SEEK_END ) == 0 ); TESTCASE( gets( buffer ) == NULL ); - // remove( testfile ); + TESTCASE( fclose( fh ) == 0 ); + TESTCASE( remove( testfile ) == 0 ); return TEST_RESULTS; }