move __string_read into vsscanf source file
authorRich Felker <dalias@aerifal.cx>
Fri, 17 Apr 2020 20:18:07 +0000 (16:18 -0400)
committerRich Felker <dalias@aerifal.cx>
Fri, 17 Apr 2020 20:18:07 +0000 (16:18 -0400)
apparently this function was intended at some point to be used by
strto* family as well, and thus was put in its own file; however, as
far as I can tell, it's only ever been used by vsscanf. move it to the
same file to reduce the number of source files and external symbols.

src/internal/stdio_impl.h
src/stdio/__string_read.c [deleted file]
src/stdio/vsscanf.c

index d7398f5..0b2438d 100644 (file)
@@ -60,8 +60,6 @@ hidden size_t __stdout_write(FILE *, const unsigned char *, size_t);
 hidden off_t __stdio_seek(FILE *, off_t, int);
 hidden int __stdio_close(FILE *);
 
-hidden size_t __string_read(FILE *, unsigned char *, size_t);
-
 hidden int __toread(FILE *);
 hidden int __towrite(FILE *);
 
diff --git a/src/stdio/__string_read.c b/src/stdio/__string_read.c
deleted file mode 100644 (file)
index 7b50a7e..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-#include "stdio_impl.h"
-#include <string.h>
-
-size_t __string_read(FILE *f, unsigned char *buf, size_t len)
-{
-       char *src = f->cookie;
-       size_t k = len+256;
-       char *end = memchr(src, 0, k);
-       if (end) k = end-src;
-       if (k < len) len = k;
-       memcpy(buf, src, len);
-       f->rpos = (void *)(src+len);
-       f->rend = (void *)(src+k);
-       f->cookie = src+k;
-       return len;
-}
index 9850022..4d6d259 100644 (file)
@@ -1,15 +1,25 @@
 #include "stdio_impl.h"
+#include <string.h>
 
-static size_t do_read(FILE *f, unsigned char *buf, size_t len)
+static size_t string_read(FILE *f, unsigned char *buf, size_t len)
 {
-       return __string_read(f, buf, len);
+       char *src = f->cookie;
+       size_t k = len+256;
+       char *end = memchr(src, 0, k);
+       if (end) k = end-src;
+       if (k < len) len = k;
+       memcpy(buf, src, len);
+       f->rpos = (void *)(src+len);
+       f->rend = (void *)(src+k);
+       f->cookie = src+k;
+       return len;
 }
 
 int vsscanf(const char *restrict s, const char *restrict fmt, va_list ap)
 {
        FILE f = {
                .buf = (void *)s, .cookie = (void *)s,
-               .read = do_read, .lock = -1
+               .read = string_read, .lock = -1
        };
        return vfscanf(&f, fmt, ap);
 }