X-Git-Url: https://pd.if.org/git/?p=pdclib;a=blobdiff_plain;f=functions%2Fstdio%2Ffscanf.c;h=9bb775ffc6597178c5dc811b12b760127e951bef;hp=2be1758375c1abb015c50de9360586c555da7b85;hb=da0f3f353d417fed71f358a48d5d5394145e460d;hpb=0a5395faab237ba9008352b0f4bee9659bbd3d5f diff --git a/functions/stdio/fscanf.c b/functions/stdio/fscanf.c index 2be1758..9bb775f 100644 --- a/functions/stdio/fscanf.c +++ b/functions/stdio/fscanf.c @@ -1,85 +1,54 @@ -// ---------------------------------------------------------------------------- -// $Id$ -// ---------------------------------------------------------------------------- -// Public Domain C Library - http://pdclib.sourceforge.net -// This code is Public Domain. Use, modify, and redistribute at will. -// ---------------------------------------------------------------------------- +/* fscanf( FILE *, const char *, ... ) -int fscanf( FILE * restrict stream, const char * restrict format, ... ) { /* TODO */ }; + This file is part of the Public Domain C Library (PDCLib). + Permission is granted to use, modify, and / or redistribute at will. +*/ -/* PDPC code - unreviewed -{ - va_list arg; - int ret; +#include +#include + +#ifndef REGTEST +#include "_PDCLIB_io.h" - va_start(arg, format); - ret = vvscanf(format, arg, stream, NULL); - va_end(arg); - return (ret); +int _PDCLIB_fscanf_unlocked( FILE * _PDCLIB_restrict stream, + const char * _PDCLIB_restrict format, ... ) +{ + int rc; + va_list ap; + va_start( ap, format ); + rc = _PDCLIB_vfscanf_unlocked( stream, format, ap ); + va_end( ap ); + return rc; } -static int vvscanf(const char *format, va_list arg, FILE *fp, const char *s) +int fscanf( FILE * _PDCLIB_restrict stream, + const char * _PDCLIB_restrict format, ... ) { - int ch; - int fin = 0; - int cnt = 0; - char *cptr; - int *iptr; + int rc; + va_list ap; + va_start( ap, format ); + rc = vfscanf( stream, format, ap ); + va_end( ap ); + return rc; +} + +#endif - inch(); - while (!fin) - { - if (*format == '\0') - { - fin = 1; - } - else if (*format == '%') - { - format++; - if (*format == '%') - { - if (ch != '%') return (cnt); - inch(); - } - else if (*format == 's') - { - cptr = va_arg(arg, char *); - *cptr++ = (char)ch; - inch(); - while ((ch >= 0) && (!isspace(ch))) - { - *cptr++ = (char)ch; - inch(); - } - *cptr = '\0'; - if (ch < 0) - { - fin = 1; - } - } - else if (*format == 'd') - { - iptr = va_arg(arg, int *); - if (!isdigit(ch)) return (cnt); - *iptr = ch - '0'; - inch(); - while ((ch >= 0) && (isdigit(ch))) - { - *iptr = *iptr * 10 + (ch - '0'); - inch(); - } - if (ch < 0) - { - fin = 1; - } - } - } - else - { - if (ch != *format) return (cnt); - inch(); - } - } - return (cnt); +#ifdef TEST +#define _PDCLIB_FILEID "stdio/fscanf.c" +#define _PDCLIB_FILEIO + +#include "_PDCLIB_test.h" + +#define testscanf( stream, format, ... ) fscanf( stream, format, __VA_ARGS__ ) + +int main( void ) +{ + FILE * source; + TESTCASE( ( source = tmpfile() ) != NULL ); +#include "scanf_testcases.h" + TESTCASE( fclose( source ) == 0 ); + return TEST_RESULTS; } -*/ + +#endif