diff options
author | Paul Eggert <eggert@cs.ucla.edu> | 2005-12-07 18:22:05 +0000 |
---|---|---|
committer | Paul Eggert <eggert@cs.ucla.edu> | 2005-12-07 18:22:05 +0000 |
commit | 5ea987eadef4c2cc50adc6fa114e4e9099dc94e6 (patch) | |
tree | 6e03aa039b92f54e9a8b7c5acd20ddab9b9de15c /m4 | |
parent | c25ad39393734a7cfd94120b831ce94ff7f3ae15 (diff) | |
download | coreutils-5ea987eadef4c2cc50adc6fa114e4e9099dc94e6.tar.xz |
* lib/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>.
* m4/stat-time.m4 (gl_STAT_TIME): Likewise.
Diffstat (limited to 'm4')
-rw-r--r-- | m4/ChangeLog | 7 | ||||
-rw-r--r-- | m4/stat-time.m4 | 31 |
2 files changed, 37 insertions, 1 deletions
diff --git a/m4/ChangeLog b/m4/ChangeLog index 3824cc0f1..25dad52d1 100644 --- a/m4/ChangeLog +++ b/m4/ChangeLog @@ -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. diff --git a/m4/stat-time.m4 b/m4/stat-time.m4 index 0f42f673d..89a7aa4b8 100644 --- a/m4/stat-time.m4 +++ b/m4/stat-time.m4 @@ -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], [], |