Mercurial > hg > octave-shane > gnulib-hg
annotate lib/mpsort.c @ 8052:f4e98fccacf0
* lib/mpsort.c (mpsort): Remove spurious "return" in void function.
author | Jim Meyering <jim@meyering.net> |
---|---|
date | Tue, 30 Jan 2007 21:39:19 +0000 |
parents | d95ff1660f83 |
children | bbbbbf4cd1c5 |
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 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
5 This program is free software; you can redistribute it and/or modify |
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 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
7 the Free Software Foundation; either version 2, or (at your option) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
8 any later version. |
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 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
15 You should have received a copy of the GNU General Public License along |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
16 with this program; if not, write to the Free Software Foundation, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
17 Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
18 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
19 /* Written by Paul Eggert. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
20 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
21 #include <config.h> |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
22 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
23 #include "mpsort.h" |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
24 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
25 #include <string.h> |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
26 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
27 /* The type of qsort-style comparison functions. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
28 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
29 typedef int (*comparison_function) (void const *, void const *); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
30 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
31 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
|
32 void const **restrict, comparison_function); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
33 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
34 /* 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
|
35 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
|
36 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
37 static void |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
38 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
|
39 void const **restrict tmp, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
40 comparison_function cmp) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
41 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
42 size_t n1 = n / 2; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
43 size_t n2 = n - n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
44 size_t a = 0; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
45 size_t alim = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
46 size_t b = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
47 size_t blim = n; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
48 void const *ba; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
49 void const *bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
50 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
51 mpsort_with_tmp (base + n1, n2, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
52 mpsort_with_tmp (base, n1, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
53 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
54 ba = base[a]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
55 bb = base[b]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
56 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
57 for (;;) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
58 if (cmp (ba, bb) <= 0) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
59 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
60 *tmp++ = ba; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
61 a++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
62 if (a == alim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
63 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
64 a = b; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
65 alim = blim; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
66 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
67 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
68 ba = base[a]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
69 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
70 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
71 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
72 *tmp++ = bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
73 b++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
74 if (b == blim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
75 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
76 bb = base[b]; |
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 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
79 memcpy (tmp, base + a, (alim - a) * sizeof *base); |
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 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
82 /* 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
|
83 (containing N / 2 pointers) for temporary storage. Compare |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
84 pointers with CMP. */ |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
85 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
86 static void |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
87 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
|
88 void const **restrict tmp, |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
89 comparison_function cmp) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
90 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
91 if (n <= 2) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
92 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
93 if (n == 2) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
94 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
95 void const *p0 = base[0]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
96 void const *p1 = base[1]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
97 if (! (cmp (p0, p1) <= 0)) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
98 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
99 base[0] = p1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
100 base[1] = p0; |
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 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
104 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
105 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
106 size_t n1 = n / 2; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
107 size_t n2 = n - n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
108 size_t i; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
109 size_t t = 0; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
110 size_t tlim = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
111 size_t b = n1; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
112 size_t blim = n; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
113 void const *bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
114 void const *tt; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
115 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
116 mpsort_with_tmp (base + n1, n2, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
117 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
118 if (n1 < 2) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
119 tmp[0] = base[0]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
120 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
121 mpsort_into_tmp (base, n1, tmp, cmp); |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
122 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
123 tt = tmp[t]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
124 bb = base[b]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
125 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
126 for (i = 0; ; ) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
127 if (cmp (tt, bb) <= 0) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
128 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
129 base[i++] = tt; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
130 t++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
131 if (t == tlim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
132 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
133 tt = tmp[t]; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
134 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
135 else |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
136 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
137 base[i++] = bb; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
138 b++; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
139 if (b == blim) |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
140 { |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
141 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
|
142 break; |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
143 } |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
144 bb = base[b]; |
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 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
149 /* 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
|
150 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
|
151 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
|
152 |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
153 void |
d95ff1660f83
* MODULES.html.sh: New module mpsort.
Paul Eggert <eggert@cs.ucla.edu>
parents:
diff
changeset
|
154 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
|
155 { |
8052
f4e98fccacf0
* lib/mpsort.c (mpsort): Remove spurious "return" in void function.
Jim Meyering <jim@meyering.net>
parents:
8046
diff
changeset
|
156 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
|
157 } |