SDL
2.0
|
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.