mirror of
https://git.savannah.gnu.org/git/gnulib.git
synced 2025-08-18 23:42:00 +03:00
lstat: fix Solaris 9 bug
lstat("file/",buf) mistakenly succeeded. * lib/lstat.c (lstat): Also check for trailing slash on non-symlink, non-directories. Use stat module to simplify logic. * doc/posix-functions/lstat.texi (lstat): Document it. * modules/lstat-tests (Depends-on): Add errno, same-inode. (configure.ac): Check for symlink. * tests/test-lstat.c (main): Add more tests. Signed-off-by: Eric Blake <ebb9@byu.net>
This commit is contained in:
@@ -9,8 +9,13 @@ Gnulib module: lstat
|
||||
Portability problems fixed by Gnulib:
|
||||
@itemize
|
||||
@item
|
||||
When the argument ends in a slash, some platforms don't dereference the
|
||||
argument.
|
||||
For symlinks, when the argument ends in a slash, some platforms don't
|
||||
dereference the argument:
|
||||
Solaris 9.
|
||||
@item
|
||||
On some platforms, @code{lstat("file/",buf)} succeeds instead of
|
||||
failing with @code{ENOTDIR}.
|
||||
Solaris 9.
|
||||
@item
|
||||
On Windows platforms (excluding Cygwin), symlinks are not supported, so
|
||||
@code{lstat} does not exist.
|
||||
@@ -22,4 +27,12 @@ Portability problems not fixed by Gnulib:
|
||||
On platforms where @code{off_t} is a 32-bit type, @code{lstat} may not
|
||||
correctly report the size of files or block devices larger than 2 GB. The fix
|
||||
is to use the @code{AC_SYS_LARGEFILE} macro.
|
||||
@item
|
||||
On Windows platforms (excluding Cygwin), @code{st_ino} is always 0.
|
||||
@item
|
||||
Because of the definition of @code{struct stat}, it is not possible to
|
||||
portably replace @code{stat} via an object-like macro. Therefore,
|
||||
expressions such as @code{(islnk ? lstat : stat) (name, buf)} are not
|
||||
portable, and should instead be written @code{islnk ? lstat (name,
|
||||
buf) : stat (name, buf)}.
|
||||
@end itemize
|
||||
|
Reference in New Issue
Block a user