Fix libio/bug-ungetwc1.c warning.

This patch fixes a warning "variable 'wc' set but not used" in
libio/bug-ungetwc1.c.

The test didn't verify much about the results of the functions it
called.  This patch makes it check the result of getwc (thereby fixing
the warning), check end of file does not arrive too late in the getwc
loop, and check EOF is no longer set after ungetwc.

Tested for x86_64.

	* libio/bug-ungetwc1.c (do_test): Verify results of getwc and
	feof.
This commit is contained in:
Joseph Myers 2014-11-27 16:01:04 +00:00
parent 9114625bad
commit 49051f8ea4
2 changed files with 22 additions and 2 deletions

View File

@ -1,5 +1,8 @@
2014-11-27 Joseph Myers <joseph@codesourcery.com> 2014-11-27 Joseph Myers <joseph@codesourcery.com>
* libio/bug-ungetwc1.c (do_test): Verify results of getwc and
feof.
* dlfcn/failtestmod.c (constr): Do not store result of dlsym in a * dlfcn/failtestmod.c (constr): Do not store result of dlsym in a
variable. variable.

View File

@ -53,8 +53,22 @@ do_test (void)
/* Read from the file. */ /* Read from the file. */
fp = fopen (fname, "r"); fp = fopen (fname, "r");
size_t i = 0;
while (!feof (fp)) while (!feof (fp))
{
wc = getwc (fp); wc = getwc (fp);
if (i >= sizeof (write_chars))
{
printf ("Did not get end-of-file when expected.\n");
return 1;
}
else if (wc != (write_chars[i] ? write_chars[i] : WEOF))
{
printf ("Unexpected %lu from getwc.\n", (unsigned long int) wc);
return 1;
}
i++;
}
printf ("\nThe end-of-file indicator is set.\n"); printf ("\nThe end-of-file indicator is set.\n");
/* Unget a wide character. */ /* Unget a wide character. */
@ -63,7 +77,10 @@ do_test (void)
/* Check the end-of-file indicator. */ /* Check the end-of-file indicator. */
if (feof (fp)) if (feof (fp))
{
printf ("The end-of-file indicator is still set.\n"); printf ("The end-of-file indicator is still set.\n");
return 1;
}
else else
printf ("The end-of-file flag is cleared.\n"); printf ("The end-of-file flag is cleared.\n");