X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=doc%2Fposix-functions%2Flstat.texi;h=39d2dcefc562d39507755f69844d16afb715a45a;hb=54b5ce0e1a4f6a4af37f970e45e6e173e5b0a1c6;hp=7a82d87bfe0481b510bb4794c2cf40459ba2efff;hpb=09ef7461110822a3970aa8eebcfaa740996a82f2;p=gnulib.git diff --git a/doc/posix-functions/lstat.texi b/doc/posix-functions/lstat.texi index 7a82d87bf..39d2dcefc 100644 --- a/doc/posix-functions/lstat.texi +++ b/doc/posix-functions/lstat.texi @@ -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,16 @@ 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)}. +@item +On some file systems, @code{st_size} contains bogus information for +symlinks; use the gnulib module areadlink-with-size for a better way +to get symlink contents. @end itemize