X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fftruncate.m4;h=95d3daba1c6632fe0fef630c5c2b3f2a3b6af5a1;hb=5004e3e684c76f9b2d6800a995316c06c3915781;hp=1be562ed9fb38d635a90f6c4346bdd51b02e09fd;hpb=27ef3b8633ec7b4aba91535ec51c43f39b42a25a;p=gnulib.git diff --git a/m4/ftruncate.m4 b/m4/ftruncate.m4 index 1be562ed9..95d3daba1 100644 --- a/m4/ftruncate.m4 +++ b/m4/ftruncate.m4 @@ -1,27 +1,48 @@ -#serial 2 +# serial 15 -# See if we need to emulate a missing ftruncate function using fcntl. +# See if we need to emulate a missing ftruncate function using fcntl or chsize. -AC_DEFUN(jm_FUNC_FTRUNCATE, -[ - AC_CHECK_FUNCS(ftruncate, , [ftruncate_missing=yes]) +# Copyright (C) 2000-2001, 2003-2007, 2009-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. + +# FIXME: remove this macro, along with all uses of HAVE_FTRUNCATE in 2012, +# if the check below provokes no more reports. So far, the only report +# arose from a test build of this gnulib module, cross-compiling to mingw: +# +# Now (in 2010), MSVC has been raised as a possible target: +# - if test "$ftruncate_missing" = yes; then - AC_CHECK_HEADERS(unistd.h) - AC_MSG_CHECKING([fcntl emulation of ftruncate]) - AC_CACHE_VAL(fu_cv_sys_ftruncate_emulation, - [AC_TRY_LINK([ -#include -#include ], [ -#if !defined(F_CHSIZE) && !defined(F_FREESP) - chsize(); -#endif - ], - fu_cv_sys_ftruncate_emulation=yes, - fu_cv_sys_ftruncate_emulation=no)]) - AC_MSG_RESULT($fu_cv_sys_ftruncate_emulation) - if test $fu_cv_sys_ftruncate_emulation = yes; then - AC_LIBOBJ(ftruncate) - fi +AC_DEFUN([gl_FUNC_FTRUNCATE], +[ + AC_REQUIRE([gl_UNISTD_H_DEFAULTS]) + AC_REQUIRE([AC_CANONICAL_HOST]) + AC_CHECK_FUNCS_ONCE([ftruncate]) + if test $ac_cv_func_ftruncate = no; then + HAVE_FTRUNCATE=0 + AC_LIBOBJ([ftruncate]) + gl_PREREQ_FTRUNCATE + case "$host_os" in + mingw*) + # Yes, we know mingw lacks ftruncate. + ;; + *) + # If someone lacks ftruncate, make configure fail, and request + # a bug report to inform us about it. + if test x"$SKIP_FTRUNCATE_CHECK" != xyes; then + AC_MSG_FAILURE([Your system lacks the ftruncate function. + Please report this, along with the output of "uname -a", to the + bug-coreutils@gnu.org mailing list. To continue past this point, + rerun configure with SKIP_FTRUNCATE_CHECK=yes. + E.g., ./configure SKIP_FTRUNCATE_CHECK=yes]) + fi + esac fi ]) + +# Prerequisites of lib/ftruncate.c. +AC_DEFUN([gl_PREREQ_FTRUNCATE], +[ + AC_CHECK_FUNCS([chsize]) +])