vasnprintf: Correct handling of unconvertible wide string arguments.
[gnulib.git] / m4 / link-follow.m4
index eb98c3b..256b2a9 100644 (file)
@@ -1,8 +1,8 @@
-# serial 13
+# serial 15
 dnl Run a program to determine whether link(2) follows symlinks.
 dnl Set LINK_FOLLOWS_SYMLINKS accordingly.
 
-# Copyright (C) 1999-2001, 2004-2006, 2009 Free Software Foundation, Inc.
+# Copyright (C) 1999-2001, 2004-2006, 2009-2010 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.
@@ -23,7 +23,7 @@ AC_DEFUN([gl_FUNC_LINK_FOLLOWS_SYMLINK],
   gl_link_follows_symlinks=0 # assume GNU behavior
   if test $ac_cv_func_readlink = yes; then
     AC_CACHE_CHECK([whether link(2) dereferences a symlink],
-                   gl_cv_func_link_follows_symlink,
+                    gl_cv_func_link_follows_symlink,
     [
       # Create a regular file.
       echo > conftest.file
@@ -34,43 +34,44 @@ AC_DEFUN([gl_FUNC_LINK_FOLLOWS_SYMLINK],
 #       include <stdlib.h>
 
 #       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)
+          ((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;
+        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 to the regular file. */
-         if (symlink (file, sym))
-           abort ();
+          /* Create a symlink to the regular file. */
+          if (symlink (file, sym))
+            return 2;
 
-         /* Create a hard link to that symlink.  */
-         if (link (sym, hard))
-           abort ();
+          /* Create a hard link to that symlink.  */
+          if (link (sym, hard))
+            return 3;
 
-         if (lstat (hard, &sb_hard))
-           abort ();
-         if (lstat (file, &sb_file))
-           abort ();
+          if (lstat (hard, &sb_hard))
+            return 4;
+          if (lstat (file, &sb_file))
+            return 5;
 
-         /* 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;
-       }
+          /* 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) ? 1 : 0;
+        }
       ]])],
-       [gl_cv_func_link_follows_symlink=yes],
-       [gl_cv_func_link_follows_symlink=no],
-       [gl_cv_func_link_follows_symlink=unknown] dnl We're cross compiling.
+        [gl_cv_func_link_follows_symlink=no], dnl GNU behavior
+        [gl_cv_func_link_follows_symlink=yes], dnl Followed link/compile failed
+        [gl_cv_func_link_follows_symlink=unknown] dnl We're cross compiling.
       )
+      rm -f conftest.file conftest.sym conftest.hard
     ])
     case $gl_cv_func_link_follows_symlink in
-      yes) ;;
-      no) gl_link_follows_symlinks=1 ;;
+      yes) gl_link_follows_symlinks=1 ;;
+      no) ;; # already defaulted to 0
       *) gl_link_follows_symlinks=-1 ;;
     esac
   fi