[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[commits] r2752 - in /fsf/trunk/libc: ./ stdio-common/
- To: commits@xxxxxxxxxx
- Subject: [commits] r2752 - in /fsf/trunk/libc: ./ stdio-common/
- From: eglibc@xxxxxxxxxx
- Date: Sun, 08 Jul 2007 07:03:21 -0000
Author: eglibc
Date: Sun Jul 8 00:03:20 2007
New Revision: 2752
Log:
Import glibc-mainline for 2007-07-08
Added:
fsf/trunk/libc/stdio-common/bug18.c
fsf/trunk/libc/stdio-common/bug18a.c
fsf/trunk/libc/stdio-common/bug19.c
fsf/trunk/libc/stdio-common/bug19a.c
Modified:
fsf/trunk/libc/ChangeLog
fsf/trunk/libc/stdio-common/Makefile
fsf/trunk/libc/stdio-common/vfscanf.c
Modified: fsf/trunk/libc/ChangeLog
==============================================================================
--- fsf/trunk/libc/ChangeLog (original)
+++ fsf/trunk/libc/ChangeLog Sun Jul 8 00:03:20 2007
@@ -1,3 +1,15 @@
+2007-07-07 Ulrich Drepper <drepper@xxxxxxxxxx>
+
+ [BZ #4745]
+ * stdio-common/vfscanf.c (_IO_vfscanf): Add additional test for EOF
+ in loop to look for conversion specifier to avoid testing of
+ wrong errno value.
+ * stdio-common/Makefile (tests): Add bug18, bug18a, bug19, bug19a.
+ * stdio-common/bug18.c: New file.
+ * stdio-common/bug18a.c: New file.
+ * stdio-common/bug19.c: New file.
+ * stdio-common/bug19a.c: New file.
+
2007-07-05 Mike Frysinger <vapier@xxxxxxxxxx>
* Makeconfig ($(common-objpfx)gnu/lib-names.stmp): Use LC_ALL=C when
Modified: fsf/trunk/libc/stdio-common/Makefile
==============================================================================
--- fsf/trunk/libc/stdio-common/Makefile (original)
+++ fsf/trunk/libc/stdio-common/Makefile Sun Jul 8 00:03:20 2007
@@ -54,7 +54,8 @@
tst-swprintf tst-fseek tst-fmemopen test-vfprintf tst-gets \
tst-perror tst-sprintf tst-rndseek tst-fdopen tst-fphex bug14 bug15 \
tst-popen tst-unlockedio tst-fmemopen2 tst-put-error tst-fgets \
- tst-fwrite bug16 bug17 tst-swscanf tst-sprintf2
+ tst-fwrite bug16 bug17 tst-swscanf tst-sprintf2 bug18 bug18a \
+ bug19 bug19a
test-srcs = tst-unbputc tst-printf
Added: fsf/trunk/libc/stdio-common/bug18.c
==============================================================================
--- fsf/trunk/libc/stdio-common/bug18.c (added)
+++ fsf/trunk/libc/stdio-common/bug18.c Sun Jul 8 00:03:20 2007
@@ -1,0 +1,48 @@
+#include <assert.h>
+#include <errno.h>
+#include <stdio.h>
+
+#ifndef CHAR
+# define CHAR char
+# define L(str) str
+# define SSCANF sscanf
+#endif
+
+
+static int
+do_test (void)
+{
+ printf("setting errno to EINTR\n");
+ errno = EINTR;
+
+ printf("checking sscanf\n");
+
+ CHAR str[] = L("7-11");
+ int i, j, n;
+
+ i = j = n = 0;
+ SSCANF (str, L(" %i - %i %n"), &i, &j, &n);
+ printf ("found %i-%i (length=%i)\n", i, j, n);
+
+ int result = 0;
+ if (i != 7)
+ {
+ printf ("i is %d, expected 7\n", i);
+ result = 1;
+ }
+ if (j != 11)
+ {
+ printf ("j is %d, expected 11\n", j);
+ result = 1;
+ }
+ if (n != 4)
+ {
+ printf ("n is %d, expected 4\n", j);
+ result = 1;
+ }
+
+ return result;
+}
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"
Added: fsf/trunk/libc/stdio-common/bug18a.c
==============================================================================
--- fsf/trunk/libc/stdio-common/bug18a.c (added)
+++ fsf/trunk/libc/stdio-common/bug18a.c Sun Jul 8 00:03:20 2007
@@ -1,0 +1,6 @@
+#include <wchar.h>
+#define CHAR wchar_t
+#define L(str) L##str
+#define SSCANF swscanf
+
+#include "bug18.c"
Added: fsf/trunk/libc/stdio-common/bug19.c
==============================================================================
--- fsf/trunk/libc/stdio-common/bug19.c (added)
+++ fsf/trunk/libc/stdio-common/bug19.c Sun Jul 8 00:03:20 2007
@@ -1,0 +1,58 @@
+#include <assert.h>
+#include <errno.h>
+#include <stdio.h>
+
+#ifndef CHAR
+# define CHAR char
+# define L(str) str
+# define FPUTS fputs
+# define FSCANF fscanf
+#endif
+
+
+static int
+do_test (void)
+{
+ FILE *fp = tmpfile ();
+ if (fp == NULL)
+ {
+ puts ("cannot open file");
+ return 1;
+ }
+
+ FPUTS (L("7-11"), fp);
+ rewind (fp);
+
+ printf("setting errno to EINTR\n");
+ errno = EINTR;
+
+ printf("checking sscanf\n");
+
+ int i, j, n;
+
+ i = j = n = 0;
+ FSCANF (fp, L(" %i - %i %n"), &i, &j, &n);
+ printf ("found %i-%i (length=%i)\n", i, j, n);
+
+ int result = 0;
+ if (i != 7)
+ {
+ printf ("i is %d, expected 7\n", i);
+ result = 1;
+ }
+ if (j != 11)
+ {
+ printf ("j is %d, expected 11\n", j);
+ result = 1;
+ }
+ if (n != 4)
+ {
+ printf ("n is %d, expected 4\n", j);
+ result = 1;
+ }
+
+ return result;
+}
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"
Added: fsf/trunk/libc/stdio-common/bug19a.c
==============================================================================
--- fsf/trunk/libc/stdio-common/bug19a.c (added)
+++ fsf/trunk/libc/stdio-common/bug19a.c Sun Jul 8 00:03:20 2007
@@ -1,0 +1,7 @@
+#include <wchar.h>
+#define CHAR wchar_t
+#define L(str) L##str
+#define FPUTS fputws
+#define FSCANF fwscanf
+
+#include "bug19.c"
Modified: fsf/trunk/libc/stdio-common/vfscanf.c
==============================================================================
--- fsf/trunk/libc/stdio-common/vfscanf.c (original)
+++ fsf/trunk/libc/stdio-common/vfscanf.c Sun Jul 8 00:03:20 2007
@@ -530,12 +530,17 @@
{
/* Eat whitespace. */
int save_errno = errno;
- errno = 0;
+ __set_errno (0);
do
- if (__builtin_expect (inchar () == EOF && errno == EINTR, 0))
+ /* We add the additional test for EOF here since otherwise
+ inchar will restore the old errno value which might be
+ EINTR but does not indicate an interrupt since nothing
+ was read at this time. */
+ if (__builtin_expect ((c == EOF || inchar () == EOF)
+ && errno == EINTR, 0))
input_error ();
while (ISSPACE (c));
- errno = save_errno;
+ __set_errno (save_errno);
ungetc (c, s);
skip_space = 0;
}