SDL
2.0
|
Go to the source code of this file.
Data Structures | |
struct | stack_entry |
Macros | |
#define | assert SDL_assert |
#define | malloc SDL_malloc |
#define | free SDL_free |
#define | memcpy SDL_memcpy |
#define | memmove SDL_memmove |
#define | qsortG 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 | qsortG (void *base, size_t nmemb, size_t size, int(*compare)(const void *, const void *)) |
#define assert SDL_assert |
Definition at line 43 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
#define doLeft {first=ffirst;llast=last;continue;} |
Definition at line 190 of file SDL_qsort.c.
#define doRight {ffirst=first;last=llast;continue;} |
Definition at line 191 of file SDL_qsort.c.
#define free SDL_free |
Definition at line 51 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
#define Insertion | ( | swapper | ) |
Definition at line 330 of file SDL_qsort.c.
Referenced by qsort_aligned(), and qsort_nonaligned().
#define malloc SDL_malloc |
Definition at line 47 of file SDL_qsort.c.
Referenced by SDL_BWin::DirectConnected(), glGetConfig(), main(), qsort_aligned(), qsort_nonaligned(), and qsort_words().
#define memcpy SDL_memcpy |
Definition at line 55 of file SDL_qsort.c.
Referenced by qsort_aligned(), and qsort_nonaligned().
#define memmove SDL_memmove |
Definition at line 59 of file SDL_qsort.c.
Referenced by SDL_memmove().
#define Partition | ( | swapper, | |
sz | |||
) |
Definition at line 301 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
#define Pivot | ( | swapper, | |
sz | |||
) |
Definition at line 277 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
#define PIVOT_THRESHOLD 40 |
Definition at line 185 of file SDL_qsort.c.
#define pop |
Definition at line 192 of file SDL_qsort.c.
Referenced by CPU_haveCPUID(), SDL_SoftStretch(), and SDL_tolower().
#define PreInsertion | ( | swapper, | |
limit, | |||
sz | |||
) |
Definition at line 321 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 188 of file SDL_qsort.c.
Definition at line 189 of file SDL_qsort.c.
#define qsortG SDL_qsort |
Definition at line 63 of file SDL_qsort.c.
#define Recurse | ( | Trunc | ) |
Definition at line 265 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
#define STACK_SIZE (8*sizeof(size_t)) |
Definition at line 168 of file SDL_qsort.c.
Referenced by qsort_aligned(), qsort_nonaligned(), and qsort_words().
Definition at line 353 of file SDL_qsort.c.
Referenced by qsort_aligned().
Definition at line 348 of file SDL_qsort.c.
Referenced by qsort_nonaligned().
#define TRUNC_aligned 12 |
Definition at line 178 of file SDL_qsort.c.
Referenced by qsort_aligned().
#define TRUNC_nonaligned 12 |
Definition at line 177 of file SDL_qsort.c.
Referenced by qsort_nonaligned().
#define TRUNC_words 12*WORD_BYTES /* nb different meaning */ |
Definition at line 179 of file SDL_qsort.c.
Referenced by qsort_words().
#define WORD_BYTES sizeof(int) |
Definition at line 163 of file SDL_qsort.c.
Referenced by qsort_words(), and qsortG().
|
static |
Definition at line 363 of file SDL_qsort.c.
References d.
|
static |
Definition at line 435 of file SDL_qsort.c.
References assert, free, Insertion, malloc, memcpy, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_aligned, and TRUNC_aligned.
Referenced by qsortG().
|
static |
Definition at line 404 of file SDL_qsort.c.
References assert, free, Insertion, malloc, memcpy, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_nonaligned, and TRUNC_nonaligned.
Referenced by qsortG().
|
static |
Definition at line 466 of file SDL_qsort.c.
References assert, free, malloc, Partition, Pivot, PreInsertion, Recurse, STACK_SIZE, SWAP_words, TRUNC_words, and WORD_BYTES.
Referenced by qsortG().
Definition at line 518 of file SDL_qsort.c.
References qsort_aligned(), qsort_nonaligned(), qsort_words(), and WORD_BYTES.