|
SDL
2.0
|
Include dependency graph for SDL_qsort.c:Go to the source code of this file.
Data Structures | |
| struct | stack_entry |
Macros | |
| #define | assert(X) SDL_assert(X) |
| #define | malloc SDL_malloc |
| #define | free SDL_free |
| #define | memcpy SDL_memcpy |
| #define | memmove SDL_memmove |
| #define | qsort SDL_qsort |
| #define | WORD_BYTES sizeof(int) |
| #define | STACK_SIZE (8*sizeof(size_t)) |
| #define | TRUNC_nonaligned 12 |
| #define | TRUNC_aligned 12 |
| #define | TRUNC_words 12*WORD_BYTES /* nb different meaning */ |
| #define | PIVOT_THRESHOLD 40 |
| #define | pushLeft {stack[stacktop].first=ffirst;stack[stacktop++].last=last;} |
| #define | pushRight {stack[stacktop].first=first;stack[stacktop++].last=llast;} |
| #define | doLeft {first=ffirst;llast=last;continue;} |
| #define | doRight {ffirst=first;last=llast;continue;} |
| #define | pop |
| #define | Recurse(Trunc) |
| #define | Pivot(swapper, sz) |
| #define | Partition(swapper, sz) |
| #define | PreInsertion(swapper, limit, sz) |
| #define | Insertion(swapper) |
| #define | SWAP_nonaligned(a, b) |
| #define | SWAP_aligned(a, b) |
| #define | SWAP_words(a, b) |
Functions | |
| static char * | pivot_big (char *first, char *mid, char *last, size_t size, int compare(const void *, const void *)) |
| static void | qsort_nonaligned (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
| static void | qsort_aligned (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
| static void | qsort_words (void *base, size_t nmemb, int(*compare)(const void *, const void *)) |
| void | qsort (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
Variables | |
| static const char | _ID [] = "<qsort.c gjm 1.12 1998-03-19>" |
| #define assert | ( | X | ) | SDL_assert(X) |
Definition at line 70 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define doLeft {first=ffirst;llast=last;continue;} |
Definition at line 128 of file SDL_qsort.c.
| #define doRight {ffirst=first;last=llast;continue;} |
Definition at line 129 of file SDL_qsort.c.
| #define free SDL_free |
Definition at line 78 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define Insertion | ( | swapper | ) |
Definition at line 264 of file SDL_qsort.c.
Referenced by qsort_aligned(), and qsort_nonaligned().
| #define malloc SDL_malloc |
Definition at line 74 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define memcpy SDL_memcpy |
Definition at line 82 of file SDL_qsort.c.
Referenced by qsort_aligned(), and qsort_nonaligned().
| #define memmove SDL_memmove |
Definition at line 86 of file SDL_qsort.c.
Referenced by SDL_memmove().
| #define Partition | ( | swapper, | |
| sz | |||
| ) |
Definition at line 237 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define Pivot | ( | swapper, | |
| sz | |||
| ) |
Definition at line 213 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define PIVOT_THRESHOLD 40 |
Definition at line 119 of file SDL_qsort.c.
| #define pop |
Definition at line 130 of file SDL_qsort.c.
Referenced by CPU_haveCPUID(), SDL_SoftStretch(), and SDL_tolower().
| #define PreInsertion | ( | swapper, | |
| limit, | |||
| sz | |||
| ) |
Definition at line 255 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define pushLeft {stack[stacktop].first=ffirst;stack[stacktop++].last=last;} |
Definition at line 126 of file SDL_qsort.c.
Definition at line 127 of file SDL_qsort.c.
| #define qsort SDL_qsort |
Definition at line 90 of file SDL_qsort.c.
| #define Recurse | ( | Trunc | ) |
Definition at line 201 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
| #define STACK_SIZE (8*sizeof(size_t)) |
Definition at line 102 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
Definition at line 287 of file SDL_qsort.c.
Referenced by qsort_aligned().
Definition at line 282 of file SDL_qsort.c.
Referenced by qsort_nonaligned().
| #define TRUNC_aligned 12 |
Definition at line 112 of file SDL_qsort.c.
Referenced by qsort_aligned().
| #define TRUNC_nonaligned 12 |
Definition at line 111 of file SDL_qsort.c.
Referenced by qsort_nonaligned().
| #define TRUNC_words 12*WORD_BYTES /* nb different meaning */ |
Definition at line 113 of file SDL_qsort.c.
Referenced by qsort_words().
| #define WORD_BYTES sizeof(int) |
Definition at line 97 of file SDL_qsort.c.
Referenced by qsort(), and qsort_words().
|
static |
Definition at line 298 of file SDL_qsort.c.
References d.
Definition at line 465 of file SDL_qsort.c.
References qsort_aligned(), qsort_nonaligned(), qsort_words(), and WORD_BYTES.
|
static |
Definition at line 375 of file SDL_qsort.c.
References assert, free, Insertion, malloc, memcpy, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_aligned, and TRUNC_aligned.
Referenced by qsort().
|
static |
Definition at line 341 of file SDL_qsort.c.
References assert, free, Insertion, malloc, memcpy, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_nonaligned, and TRUNC_nonaligned.
Referenced by qsort().
|
static |
Definition at line 409 of file SDL_qsort.c.
References assert, free, malloc, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_words, TRUNC_words, and WORD_BYTES.
Referenced by qsort().
|
static |
Definition at line 92 of file SDL_qsort.c.