mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-05 01:00:14 +00:00
Update.
1998-03-21 09:15 Ulrich Drepper <drepper@cygnus.com> * manual/filesys.texi (Scanning Directory Content): Add description of 64 bits scandir function and friends.
This commit is contained in:
parent
dfae7a5920
commit
5679cdb6e2
@ -1,3 +1,8 @@
|
|||||||
|
1998-03-21 09:15 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* manual/filesys.texi (Scanning Directory Content): Add description
|
||||||
|
of 64 bits scandir function and friends.
|
||||||
|
|
||||||
1998-03-20 Ulrich Drepper <drepper@cygnus.com>
|
1998-03-20 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
* glibcbug.in: Use mktemp to generate unique file name for
|
* glibcbug.in: Use mktemp to generate unique file name for
|
||||||
|
@ -447,7 +447,9 @@ A higher-level interface to the directory handling functions is the
|
|||||||
entries in a directory, possibly sort them and get as the result a list
|
entries in a directory, possibly sort them and get as the result a list
|
||||||
of names.
|
of names.
|
||||||
|
|
||||||
@deftypefun int scandir (const char *@var{dir}, struct dirent ***@var{namelist}, int (*@var{selector}) (struct dirent *), int (*@var{cmp}) (const void *, const void *))
|
@comment dirent.h
|
||||||
|
@comment BSD/SVID
|
||||||
|
@deftypefun int scandir (const char *@var{dir}, struct dirent ***@var{namelist}, int (*@var{selector}) (const struct dirent *), int (*@var{cmp}) (const void *, const void *))
|
||||||
|
|
||||||
The @code{scandir} function scans the contents of the directory selected
|
The @code{scandir} function scans the contents of the directory selected
|
||||||
by @var{dir}. The result in @var{namelist} is an array of pointers to
|
by @var{dir}. The result in @var{namelist} is an array of pointers to
|
||||||
@ -475,8 +477,10 @@ a pointer to a sorting function. For the convenience of the programmer
|
|||||||
the GNU C library contains implementations of functions which are very
|
the GNU C library contains implementations of functions which are very
|
||||||
helpful for this purpose.
|
helpful for this purpose.
|
||||||
|
|
||||||
|
@comment dirent.h
|
||||||
|
@comment BSD/SVID
|
||||||
@deftypefun int alphasort (const void *@var{a}, const void *@var{b})
|
@deftypefun int alphasort (const void *@var{a}, const void *@var{b})
|
||||||
The @code{alphasort} function behaves like the @code{strcmp} function
|
The @code{alphasort} function behaves like the @code{strcoll} function
|
||||||
(@pxref{String/Array Comparison}). The difference is that the arguments
|
(@pxref{String/Array Comparison}). The difference is that the arguments
|
||||||
are not string pointers but instead they are of type
|
are not string pointers but instead they are of type
|
||||||
@code{struct dirent **}.
|
@code{struct dirent **}.
|
||||||
@ -485,11 +489,60 @@ Return value of is less than, equal to, or greater than zero depending
|
|||||||
on the order of the two entries @var{a} and @var{b}.
|
on the order of the two entries @var{a} and @var{b}.
|
||||||
@end deftypefun
|
@end deftypefun
|
||||||
|
|
||||||
|
@comment dirent.h
|
||||||
|
@comment GNU
|
||||||
@deftypefun int versionsort (const void *@var{a}, const void *@var{b})
|
@deftypefun int versionsort (const void *@var{a}, const void *@var{b})
|
||||||
The @code{versionsort} function is like @code{alphasort}, excepted that it
|
The @code{versionsort} function is like @code{alphasort}, excepted that it
|
||||||
uses the @code{strverscmp} function internally.
|
uses the @code{strverscmp} function internally.
|
||||||
@end deftypefun
|
@end deftypefun
|
||||||
|
|
||||||
|
If the filesystem supports large files we cannot use the @code{scandir}
|
||||||
|
anymore since the @code{dirent} structure might not able to contain all
|
||||||
|
the information. The LFS provides the new type @w{@code{struct
|
||||||
|
dirent64}}. To use this we need a new function.
|
||||||
|
|
||||||
|
@comment dirent.h
|
||||||
|
@comment GNU
|
||||||
|
@deftypefun int scandir64 (const char *@var{dir}, struct dirent64 ***@var{namelist}, int (*@var{selector}) (const struct dirent64 *), int (*@var{cmp}) (const void *, const void *))
|
||||||
|
The @code{scandir64} function works like the @code{scandir} function
|
||||||
|
only that the directory entries it returns are described by elements of
|
||||||
|
type @w{@code{struct dirent64}}. The function pointed to by
|
||||||
|
@var{selector} is again used to select the wanted entries only that
|
||||||
|
@var{selector} now must point to a function which takes a
|
||||||
|
@w{@code{struct dirent64 *} parameter.
|
||||||
|
|
||||||
|
The @var{cmp} now must be a function which expects its two arguments to
|
||||||
|
be of type @code{struct dirent64 **}.
|
||||||
|
@end deftypefun
|
||||||
|
|
||||||
|
As just said the function expected as the fourth is different from the
|
||||||
|
function expected in @code{scandir}. Therefore we cannot use the
|
||||||
|
@code{alphasort} and @code{versionsort} functions anymore. Instead we
|
||||||
|
have two similar functions available.
|
||||||
|
|
||||||
|
@comment dirent.h
|
||||||
|
@comment GNU
|
||||||
|
@deftypefun int alphasort64 (const void *@var{a}, const void *@var{b})
|
||||||
|
The @code{alphasort64} function behaves like the @code{strcoll} function
|
||||||
|
(@pxref{String/Array Comparison}). The difference is that the arguments
|
||||||
|
are not string pointers but instead they are of type
|
||||||
|
@code{struct dirent64 **}.
|
||||||
|
|
||||||
|
Return value of is less than, equal to, or greater than zero depending
|
||||||
|
on the order of the two entries @var{a} and @var{b}.
|
||||||
|
@end deftypefun
|
||||||
|
|
||||||
|
@comment dirent.h
|
||||||
|
@comment GNU
|
||||||
|
@deftypefun int versionsort64 (const void *@var{a}, const void *@var{b})
|
||||||
|
The @code{versionsort64} function is like @code{alphasort64}, excepted that it
|
||||||
|
uses the @code{strverscmp} function internally.
|
||||||
|
@end deftypefun
|
||||||
|
|
||||||
|
It is important not to mix the use of @code{scandir} and the 64 bits
|
||||||
|
comparison functions or vice versa. There are systems on which this
|
||||||
|
work but on others it will fail miserably.
|
||||||
|
|
||||||
@node Simple Directory Lister Mark II
|
@node Simple Directory Lister Mark II
|
||||||
@subsection Simple Program to List a Directory, Mark II
|
@subsection Simple Program to List a Directory, Mark II
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user