mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-22 15:07:43 +08:00
bf9897549d
(qsort_r): Declare. * libc/search/Makefile.am (ELIX_2_SOURCES): Rename from ELIX_SOURCES. (ELIX_4_SOURCES): Define. Add bsd_qsort_r.c and qsort_r.c. (libsearch_la_SOURCES): Adapt accordingly. (lib_a_SOURCES): Adapt accordingly. (CHEWOUT_FILES): Add qsort_r.def. * libc/search/Makefile.in: Regenerate. * libc/search/bsd_qsort_r.c: New file. * libc/search/qsort.c: Update from FreeBSD HEAD. Adapt for both BSD and GNU qsort_r flavors. * libc/search/qsort_r.c: New file.
57 lines
1.7 KiB
C
57 lines
1.7 KiB
C
/*
|
|
FUNCTION
|
|
<<qsort_r>>---sort an array
|
|
|
|
INDEX
|
|
qsort_r
|
|
|
|
ANSI_SYNOPSIS
|
|
#define _BSD_SOURCE
|
|
#include <stdlib.h>
|
|
void qsort_r(void *<[base]>, size_t <[nmemb]>, size_t <[size]>,
|
|
void *<[thunk]>,
|
|
int (*<[compar]>)(void*, const void *, const void *));
|
|
|
|
#define _GNU_SOURCE
|
|
#include <stdlib.h>
|
|
void qsort_r(void *<[base]>, size_t <[nmemb]>, size_t <[size]>,
|
|
int (*<[compar]>)(const void *, const void *, void *),
|
|
void *<[thunk]>);
|
|
|
|
TRAD_SYNOPSIS
|
|
#include <stdlib.h>
|
|
qsort_r(<[base]>, <[nmemb]>, <[size]>, <[compar]>, <[thumb]>)
|
|
char *<[base]>;
|
|
size_t <[nmemb]>;
|
|
size_t <[size]>;
|
|
int (*<[compar]>)();
|
|
char *<[thumb]>;
|
|
|
|
DESCRIPTION
|
|
<<qsort_r>> sorts an array (beginning at <[base]>) of <[nmemb]> objects.
|
|
<[size]> describes the size of each element of the array.
|
|
|
|
You must supply a pointer to a comparison function, using the argument
|
|
shown as <[compar]>. (This permits sorting objects of unknown
|
|
properties.) There are two forms of this function, in each the
|
|
comparison function is defined to accept three arguments, but in a
|
|
different order. Two are pointers to an element of the array starting at
|
|
<[base]>, and another being an arbitrary pointer <[thunk]>. The
|
|
result of <<(*<[compar]>)>> must be negative if the first argument is
|
|
less than the second, zero if the two arguments match, and positive if
|
|
the first argument is greater than the second (where ``less than'' and
|
|
``greater than'' refer to whatever arbitrary ordering is appropriate).
|
|
|
|
The array is sorted in place; that is, when <<qsort_r>> returns, the
|
|
array elements beginning at <[base]> have been reordered.
|
|
|
|
RETURNS
|
|
<<qsort_r>> does not return a result.
|
|
|
|
PORTABILITY
|
|
<<qsort_r>>, in various forms, appears in both BSD and glibc.
|
|
*/
|
|
|
|
#define I_AM_GNU_QSORT_R
|
|
#include "qsort.c"
|