]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
* lib/stat-time.h (STATE_TIMESPEC, STAT_TIMESPEC_NS): Add check for
authorPaul Eggert <eggert@cs.ucla.edu>
Wed, 7 Dec 2005 18:22:05 +0000 (18:22 +0000)
committerPaul Eggert <eggert@cs.ucla.edu>
Wed, 7 Dec 2005 18:22:05 +0000 (18:22 +0000)
TYPEOF_STRUCT_STAT_ST_ATIM_IS_STRUCT_TIMESPEC, to fix IRIX 5.3
porting problem reported by Georg Schwarz in
<http://lists.gnu.org/archive/html/bug-coreutils/2005-12/msg00083.html>.
* m4/stat-time.m4 (gl_STAT_TIME): Likewise.

lib/ChangeLog
lib/stat-time.h
m4/ChangeLog
m4/stat-time.m4

index 87200440a574cb122e0d39abd0b62cf1e4814ba7..84e45289402aa5c0677db75b8efdf53e0dee9041 100644 (file)
@@ -1,3 +1,10 @@
+2005-12-07  Paul Eggert  <eggert@cs.ucla.edu>
+
+       * stat-time.h (STATE_TIMESPEC, STAT_TIMESPEC_NS): Add check for
+       TYPEOF_STRUCT_STAT_ST_ATIM_IS_STRUCT_TIMESPEC, to fix IRIX 5.3
+       porting problem reported by Georg Schwarz in
+       <http://lists.gnu.org/archive/html/bug-coreutils/2005-12/msg00083.html>.
+
 2005-12-04  Jim Meyering  <jim@meyering.net>
 
        * openat-priv.h (EXPECTED_ERRNO): Add ENOSYS, for Solaris 8.
index f72faf91875d849fecb0aa70d346001fa5fe4288..734e366574c49db5c55b838d7166e6bacb42bf58 100644 (file)
 
    These macros are private to stat-time.h.  */
 #if defined HAVE_STRUCT_STAT_ST_ATIM_TV_NSEC
-# define STAT_TIMESPEC(st, st_xtim) ((st)->st_xtim)
+# ifdef TYPEOF_STRUCT_STAT_ST_ATIM_IS_STRUCT_TIMESPEC
+#  define STAT_TIMESPEC(st, st_xtim) ((st)->st_xtim)
+# else
+#  define STAT_TIMESPEC_NS(st, st_xtim) ((st)->st_xtim.tv_nsec)
+# endif
 #elif defined HAVE_STRUCT_STAT_ST_ATIMESPEC_TV_NSEC
 # define STAT_TIMESPEC(st, st_xtim) ((st)->st_xtim##espec)
 #elif defined HAVE_STRUCT_STAT_ST_ATIMENSEC
index 3824cc0f1e6e4c18f65c2ee3e4410872bdb456b4..25dad52d11177401f88c8a6b3524943e8c8358c2 100644 (file)
@@ -1,3 +1,10 @@
+2005-12-07  Paul Eggert  <eggert@cs.ucla.edu>
+
+       * stat-time.m4 (gl_STAT_TIME): Add check for
+       TYPEOF_STRUCT_STAT_ST_ATIM_IS_STRUCT_TIMESPEC, to fix IRIX 5.3
+       porting problem reported by Georg Schwarz in
+       <http://lists.gnu.org/archive/html/bug-coreutils/2005-12/msg00083.html>.
+
 2005-12-02  Paul Eggert  <eggert@cs.ucla.edu>
 
        * socklen.m4 (gl_TYPE_SOCKLEN_T): Renamed from gl_SOCKLEN_T.
index 0f42f673db84ad9fc882e1fa96c5f11e58dfeed3..89a7aa4b8d8f436d9b885d043862cd667fa00b03 100644 (file)
@@ -20,7 +20,36 @@ AC_DEFUN([gl_STAT_TIME],
   AC_REQUIRE([AC_C_INLINE])
   AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
 
-  AC_CHECK_MEMBERS([struct stat.st_atim.tv_nsec], [],
+  AC_CHECK_MEMBERS([struct stat.st_atim.tv_nsec],
+    [AC_CACHE_CHECK([whether struct stat.st_atim is of type struct timespec],
+       [ac_cv_typeof_struct_stat_st_atim_is_struct_timespec],
+       [AC_TRY_COMPILE(
+         [
+           #include <sys/types.h>
+           #if TIME_WITH_SYS_TIME
+           # include <sys/time.h>
+           # include <time.h>
+           #else
+           # if HAVE_SYS_TIME_H
+           #  include <sys/time.h>
+           # else
+           #  include <time.h>
+           # endif
+           #endif
+           #include <sys/stat.h>
+           struct timespec ts;
+           struct stat st;
+         ],
+         [
+           st.st_atim = ts;
+         ],
+         [ac_cv_typeof_struct_stat_st_atim_is_struct_timespec=yes],
+         [ac_cv_typeof_struct_stat_st_atim_is_struct_timespec=no])])
+     if test $ac_cv_typeof_struct_stat_st_atim_is_struct_timespec = yes; then
+       AC_DEFINE([TYPEOF_STRUCT_STAT_ST_ATIM_IS_STRUCT_TIMESPEC], 1,
+         [Define to 1 if the type of the st_atim member of a struct stat is
+         struct timespec.])
+     fi],
     [AC_CHECK_MEMBERS([struct stat.st_atimespec.tv_nsec], [],
        [AC_CHECK_MEMBERS([struct stat.st_atimensec], [],
          [AC_CHECK_MEMBERS([struct stat.st_atim.st__tim.tv_nsec], [],