Mercurial > hg > octave-jordi > gnulib-hg
annotate tests/test-qsort_r.c @ 17744:9c8d212db038
qsort_r: new module, for GNU-style qsort_r
This works even on FreeBSD, which has an incompatible qsort_r API.
* MODULES.html.sh: Add it.
* doc/glibc-functions/qsort_r.texi: It's now supported.
* lib/qsort.c: New file, taken from glibc with minor changes
inside "#ifndef _LIBC" and with an unnecessary "#include <alloca.h>"
removed.
* lib/qsort_r.c: New file, compiled only on FreeBSD.
* lib/stdlib.in.h (qsort_r): Declare in the usual way.
* m4/stdlib_h.m4 (gl_STDLIB_H_DEFAULTS):
* modules/qsort_r, modules/qsort_r-tests: New files.
* modules/stdlib (Makefile): Set up its defaults.
* tests/test-qsort_r.c: New file.
author | Paul Eggert <eggert@cs.ucla.edu> |
---|---|
date | Fri, 29 Aug 2014 13:00:16 -0700 |
parents | |
children | ab58d4870664 |
rev | line source |
---|---|
17744
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
1 /* Test qsort_r. |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
2 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
3 Copyright 2014 Free Software Foundation, Inc. |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
4 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
5 This program is free software: you can redistribute it and/or modify |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
6 it under the terms of the GNU General Public License as published by |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
7 the Free Software Foundation; either version 3 of the License, or |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
8 (at your option) any later version. |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
9 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
10 This program is distributed in the hope that it will be useful, |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
11 but WITHOUT ANY WARRANTY; without even the implied warranty of |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
13 GNU General Public License for more details. |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
14 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
15 You should have received a copy of the GNU General Public License |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
16 along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
17 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
18 /* Written by Paul Eggert. */ |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
19 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
20 #include <config.h> |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
21 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
22 #include <stdlib.h> |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
23 #include <string.h> |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
24 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
25 int |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
26 cmp (void const *va, void const *vb, void *varg) |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
27 { |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
28 char const *a = va; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
29 char const *b = vb; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
30 int *arg = varg; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
31 return (*a < *b ? -1 : *a > *b) * *arg; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
32 } |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
33 |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
34 int |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
35 main (void) |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
36 { |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
37 char buf[] = "thequickbrownfoxjumpedoverthelazydogs"; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
38 int forward = 1; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
39 int reverse = -1; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
40 qsort_r (buf, sizeof buf - 1, 1, cmp, &forward); |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
41 if (strcmp (buf, "abcddeeeefghhijklmnoooopqrrsttuuvwxyz") != 0) |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
42 return 1; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
43 qsort_r (buf, sizeof buf - 1, 1, cmp, &reverse); |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
44 if (strcmp (buf, "zyxwvuuttsrrqpoooonmlkjihhgfeeeeddcba") != 0) |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
45 return 1; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
46 return 0; |
9c8d212db038
qsort_r: new module, for GNU-style qsort_r
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
47 } |