source: tags/ms_r18q1/CORE/arb_sort.cxx

Last change on this file was 16763, checked in by westram, 6 years ago
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 1.7 KB
Line 
1// =============================================================== //
2//                                                                 //
3//   File      : arb_sort.cxx                                      //
4//   Purpose   :                                                   //
5//                                                                 //
6//   Institute of Microbiology (Technical University Munich)       //
7//   http://www.arb-home.de/                                       //
8//                                                                 //
9// =============================================================== //
10
11#include "arb_sort.h"
12#include <cstring>
13#include "arb_assert.h"
14
15
16struct comparator {
17    gb_compare_function  compare;
18    void                *client_data;
19};
20
21static comparator Compare; // current compare function + client data
22
23static int qsort_compare(const void *v1, const void *v2) {
24    return Compare.compare(*(void**)v1, *(void**)v2, Compare.client_data);
25}
26
27void GB_sort(void **array, size_t first, size_t behind_last, gb_compare_function compare, void *client_data) {
28    /* sort 'array' of pointers from 'first' to last element
29     * (specified by following element 'behind_last')
30     * 'compare' is a compare function, with a strcmp-like result value
31     */
32
33    if (!array) {
34        arb_assert(first == behind_last); // accept empty NULp-array
35        return;
36    }
37
38    Compare.compare     = compare;
39    Compare.client_data = client_data;
40
41    qsort(array, behind_last-first, sizeof(*array), qsort_compare);
42}
43
44// --------------------------
45//      some comparators
46
47int GB_string_comparator(const void *v0, const void *v1, void */*unused*/) {
48    return strcmp((const char *)v0, (const char *)v1);
49}
50
Note: See TracBrowser for help on using the repository browser.