X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Ffflush.m4;h=f7645deff6d30d5ced48db5b26cb1920adeb76e7;hb=1138b90e8056cdc1d170ed6661223c6e3ec1dab4;hp=fca7769be1e0289ee693ed0ccb0830612bfa8f7e;hpb=16332895663c60d815322830a027ec5f660e2639;p=gnulib.git diff --git a/m4/fflush.m4 b/m4/fflush.m4 old mode 100755 new mode 100644 index fca7769be..f7645deff --- a/m4/fflush.m4 +++ b/m4/fflush.m4 @@ -1,6 +1,6 @@ -#serial 3 +# fflush.m4 serial 8 -# Copyright (C) 2007 Free Software Foundation, Inc. +# Copyright (C) 2007-2011 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. @@ -21,19 +21,41 @@ AC_DEFUN([gl_FUNC_FFLUSH], #include ]], [[FILE *f = fopen ("conftest.txt", "r"); char buffer[10]; - int fd = fileno (f); - if (!f || 0 > fd || fread (buffer, 1, 5, f) != 5) - return 2; - /* For deterministic results, ensure f read a bigger buffer. */ - if (lseek (fd, 0, SEEK_CUR) == 5) - return 3; - /* POSIX requires fflush-fseek to set file offset of fd. */ - if (fflush (f) != 0 || fseek (f, 0, SEEK_CUR) != 0) - return 4; - return !(lseek (fd, 0, SEEK_CUR) == 5); + int fd; + int c; + if (f == NULL) + return 1; + fd = fileno (f); + if (fd < 0 || fread (buffer, 1, 5, f) != 5) + return 2; + /* For deterministic results, ensure f read a bigger buffer. */ + if (lseek (fd, 0, SEEK_CUR) == 5) + return 3; + /* POSIX requires fflush-fseek to set file offset of fd. This fails + on BSD systems and on mingw. */ + if (fflush (f) != 0 || fseek (f, 0, SEEK_CUR) != 0) + return 4; + if (lseek (fd, 0, SEEK_CUR) != 5) + return 5; + /* Verify behaviour of fflush after ungetc. See + */ + /* Verify behaviour of fflush after a backup ungetc. This fails on + mingw. */ + c = fgetc (f); + ungetc (c, f); + fflush (f); + if (fgetc (f) != c) + return 6; + /* Verify behaviour of fflush after a non-backup ungetc. This fails + on glibc 2.8 and on BSD systems. */ + c = fgetc (f); + ungetc ('@', f); + fflush (f); + if (fgetc (f) != c) + return 7; + return 0; ]])], [gl_cv_func_fflush_stdin=yes], [gl_cv_func_fflush_stdin=no], - [dnl Pessimistically assume fflush is broken. This is wrong for - dnl at least glibc and cygwin; but lib/fflush.c takes this into account. + [dnl Pessimistically assume fflush is broken. gl_cv_func_fflush_stdin=no]) rm conftest.txt ]) @@ -45,12 +67,15 @@ AC_DEFUN([gl_FUNC_FFLUSH], AC_DEFUN([gl_REPLACE_FFLUSH], [ AC_LIBOBJ([fflush]) - AC_LIBOBJ([fseeko]) AC_REQUIRE([gl_STDIO_H_DEFAULTS]) REPLACE_FFLUSH=1 - gl_CHECK_FSEEKO - if test $gl_cv_func_fseeko = yes; then - AC_DEFINE([HAVE_FSEEKO], 1, - [Define to 1 if you have the fseeko() function or macro.]) - fi + gl_PREREQ_FFLUSH + gl_REPLACE_FSEEKO +]) + +# Prerequisites of lib/fflush.c. +AC_DEFUN([gl_PREREQ_FFLUSH], +[ + AC_REQUIRE([AC_C_INLINE]) + : ])