From e2c0a043f79952b9fff975f1920659d3aa77a00b Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Sat, 6 Nov 1999 21:30:16 +0000 Subject: (jm_AC_FUNC_LINK_FOLLOWS_SYMLINK): New file/macro. --- m4/link-follow.m4 | 55 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 m4/link-follow.m4 (limited to 'm4/link-follow.m4') diff --git a/m4/link-follow.m4 b/m4/link-follow.m4 new file mode 100644 index 000000000..a57ab88a6 --- /dev/null +++ b/m4/link-follow.m4 @@ -0,0 +1,55 @@ +#serial 1 +dnl Run a program to determine whether whether link(2) follows symlinks. +dnl Set LINK_FOLLOWS_SYMLINKS accordingly. + +AC_DEFUN(jm_AC_FUNC_LINK_FOLLOWS_SYMLINK, +[dnl + AC_CACHE_CHECK([whether link(2) follows symlinks], + jm_ac_cv_func_link_follows_symlink, + [ + # Create a regular file, `conftest.file'. + echo > conftest.file + AC_TRY_RUN( + [ +# include +# include +# ifdef HAVE_UNISTD_H +# include +# endif + +# define SAME_INODE(Stat_buf_1, Stat_buf_2) \ + ((Stat_buf_1).st_ino == (Stat_buf_2).st_ino \ + && (Stat_buf_1).st_dev == (Stat_buf_2).st_dev) + + int + main () + { + const char *file = "conftest.file"; + const char *sym = "conftest.sym"; + const char *hard = "conftest.hard"; + struct stat sb_file, sb_hard; + + /* Create a symlink `conftest.sym' to it. */ + if (symlink (file, sym)) + abort (); + + /* Create a hard link `conftest.hard' to that symlink. */ + if (link (sym, hard)) + abort (); + + if (lstat (hard, &sb_hard)) + abort (); + if (lstat (file, &sb_file)) + abort (); + + /* If the dev/inode of hard and file are the same, then + the link call followed the symlink. */ + return SAME_INODE (sb_hard, sb_file) ? 0 : 1; + } + ], + jm_ac_cv_func_link_follows_symlink=yes, + jm_ac_cv_func_link_follows_symlink=no, + jm_ac_cv_func_link_follows_symlink=yes, We're cross compiling. + ) + ]) +]) -- cgit v1.2.3-54-g00ecf