Provide the correct errno.
authorBruno Haible <bruno@clisp.org>
Thu, 26 Jun 2003 11:03:35 +0000 (11:03 +0000)
committerBruno Haible <bruno@clisp.org>
Thu, 26 Jun 2003 11:03:35 +0000 (11:03 +0000)
lib/readlink.c

index 72d0e04475de401cc67f5d2f0e3a410511c5fcca..c264efd8c8da994ae3a92f82546d07df02689c2e 100644 (file)
 #endif
 
 #include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
 
 #if !HAVE_READLINK
 
 /* readlink() substitute for systems that don't have a readlink() function,
    such as DJGPP 2.03 and mingw32.  */
 
+/* The official POSIX return type of readlink() is ssize_t, but since here
+   we have no declaration in a public header file, we use 'int' as return
+   type.  */
+
 int
-readlink (const char *filename, char *buffer, size_t bufsize)
+readlink (const char *path, char *buf, size_t bufsize)
 {
-  errno = EINVAL;
+  struct stat statbuf;
+
+  /* In general we should use lstat() here, not stat().  But on platforms
+     without symbolic links lstat() - if it exists - would be equivalent to
+     stat(), therefore we can use stat().  This saves us a configure check.  */
+  if (stat (path, &statbuf) >= 0)
+    errno = EINVAL;
   return -1;
 }