Mercurial > hg > octave-kai > gnulib-hg
annotate lib/mpsort.c @ 11527:4fe203c3f828
Replace wcrtomb, wcsrtombs, wcsnrtombs if mbstate_t has to be replaced.
author | Bruno Haible <bruno@clisp.org> |
---|---|
date | Fri, 01 May 2009 18:01:52 +0200 |
parents | bbbbbf4cd1c5 |
children | e8d2c6fc33ad |
rev | line source |
---|---|
8046
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
1 /* Sort a vector of pointers to data. |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
2 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
3 Copyright (C) 2007 Free Software Foundation, Inc. |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
4 |
9309
bbbbbf4cd1c5
Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents:
8052
diff
changeset
|
5 This program is free software: you can redistribute it and/or modify |
8046
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
6 it under the terms of the GNU General Public License as published by |
9309
bbbbbf4cd1c5
Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents:
8052
diff
changeset
|
7 the Free Software Foundation; either version 3 of the License, or |
bbbbbf4cd1c5
Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents:
8052
diff
changeset
|
8 (at your option) any later version. |
8046
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
9 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
10 This program is distributed in the hope that it will be useful, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
11 but WITHOUT ANY WARRANTY; without even the implied warranty of |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
13 GNU General Public License for more details. |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
14 |
9309
bbbbbf4cd1c5
Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents:
8052
diff
changeset
|
15 You should have received a copy of the GNU General Public License |
bbbbbf4cd1c5
Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents:
8052
diff
changeset
|
16 along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
8046
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
17 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
18 /* Written by Paul Eggert. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
19 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
20 #include <config.h> |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
21 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
22 #include "mpsort.h" |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
23 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
24 #include <string.h> |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
25 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
26 /* The type of qsort-style comparison functions. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
27 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
28 typedef int (*comparison_function) (void const *, void const *); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
29 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
30 static void mpsort_with_tmp (void const **restrict, size_t, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
31 void const **restrict, comparison_function); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
32 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
33 /* Sort a vector BASE containing N pointers, placing the sorted array |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
34 into TMP. Compare pointers with CMP. N must be at least 2. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
35 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
36 static void |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
37 mpsort_into_tmp (void const **restrict base, size_t n, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
38 void const **restrict tmp, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
39 comparison_function cmp) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
40 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
41 size_t n1 = n / 2; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
42 size_t n2 = n - n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
43 size_t a = 0; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
44 size_t alim = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
45 size_t b = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
46 size_t blim = n; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
47 void const *ba; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
48 void const *bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
49 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
50 mpsort_with_tmp (base + n1, n2, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
51 mpsort_with_tmp (base, n1, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
52 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
53 ba = base[a]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
54 bb = base[b]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
55 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
56 for (;;) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
57 if (cmp (ba, bb) <= 0) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
58 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
59 *tmp++ = ba; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
60 a++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
61 if (a == alim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
62 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
63 a = b; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
64 alim = blim; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
65 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
66 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
67 ba = base[a]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
68 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
69 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
70 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
71 *tmp++ = bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
72 b++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
73 if (b == blim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
74 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
75 bb = base[b]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
76 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
77 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
78 memcpy (tmp, base + a, (alim - a) * sizeof *base); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
79 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
80 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
81 /* Sort a vector BASE containing N pointers, in place. Use TMP |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
82 (containing N / 2 pointers) for temporary storage. Compare |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
83 pointers with CMP. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
84 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
85 static void |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
86 mpsort_with_tmp (void const **restrict base, size_t n, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
87 void const **restrict tmp, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
88 comparison_function cmp) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
89 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
90 if (n <= 2) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
91 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
92 if (n == 2) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
93 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
94 void const *p0 = base[0]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
95 void const *p1 = base[1]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
96 if (! (cmp (p0, p1) <= 0)) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
97 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
98 base[0] = p1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
99 base[1] = p0; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
100 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
101 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
102 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
103 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
104 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
105 size_t n1 = n / 2; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
106 size_t n2 = n - n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
107 size_t i; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
108 size_t t = 0; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
109 size_t tlim = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
110 size_t b = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
111 size_t blim = n; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
112 void const *bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
113 void const *tt; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
114 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
115 mpsort_with_tmp (base + n1, n2, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
116 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
117 if (n1 < 2) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
118 tmp[0] = base[0]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
119 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
120 mpsort_into_tmp (base, n1, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
121 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
122 tt = tmp[t]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
123 bb = base[b]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
124 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
125 for (i = 0; ; ) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
126 if (cmp (tt, bb) <= 0) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
127 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
128 base[i++] = tt; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
129 t++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
130 if (t == tlim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
131 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
132 tt = tmp[t]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
133 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
134 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
135 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
136 base[i++] = bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
137 b++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
138 if (b == blim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
139 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
140 memcpy (base + i, tmp + t, (tlim - t) * sizeof *base); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
141 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
142 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
143 bb = base[b]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
144 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
145 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
146 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
147 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
148 /* Sort a vector BASE containing N pointers, in place. BASE must |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
149 contain enough storage to hold N + N / 2 vectors; the trailing |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
150 vectors are used for temporaries. Compare pointers with CMP. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
151 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
152 void |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
153 mpsort (void const **base, size_t n, comparison_function cmp) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
154 { |
8052
f4e98fccacf0
* lib/mpsort.c (mpsort): Remove spurious "return" in void function.
Jim Meyering <jim@meyering.net>
parents:
8046
diff
changeset
|
155 mpsort_with_tmp (base, n, base + n, cmp); |
8046
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
156 } |