| 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 |  | 
|---|
| 16 | struct comparator { | 
|---|
| 17 | gb_compare_function  compare; | 
|---|
| 18 | void                *client_data; | 
|---|
| 19 | }; | 
|---|
| 20 |  | 
|---|
| 21 | static comparator Compare; // current compare function + client data | 
|---|
| 22 |  | 
|---|
| 23 | static int qsort_compare(const void *v1, const void *v2) { | 
|---|
| 24 | return Compare.compare(*(void**)v1, *(void**)v2, Compare.client_data); | 
|---|
| 25 | } | 
|---|
| 26 |  | 
|---|
| 27 | void 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 |  | 
|---|
| 47 | int GB_string_comparator(const void *v0, const void *v1, void */*unused*/) { | 
|---|
| 48 | return strcmp((const char *)v0, (const char *)v1); | 
|---|
| 49 | } | 
|---|
| 50 |  | 
|---|