summaryrefslogtreecommitdiff
path: root/src/stdlib/qsort.c
diff options
context:
space:
mode:
authorJakob Kaivo <jkk@ung.org>2024-01-31 16:40:42 -0500
committerJakob Kaivo <jkk@ung.org>2024-01-31 16:40:42 -0500
commitd792c9d2797a5160e23827abdc71bfe500009cd3 (patch)
treee3bcc43c92e69869be755fe8cbaf623aa1981cbc /src/stdlib/qsort.c
parent1a22e9f3c62fb248725874b64b8953392c004bca (diff)
add UB checks for search/sort
Diffstat (limited to 'src/stdlib/qsort.c')
-rw-r--r--src/stdlib/qsort.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/stdlib/qsort.c b/src/stdlib/qsort.c
index 42764817..346dba88 100644
--- a/src/stdlib/qsort.c
+++ b/src/stdlib/qsort.c
@@ -24,6 +24,7 @@ static void __qsort(char *base, size_t size, size_t lo, size_t hi, int (*compar)
}
for (j = lo; j < hi; j++) {
+ /* TODO: ensure compar() doesn't modify things */
if (compar(base + (size * j), base + (size * hi)) < 0) {
__swap(base, size, i, j);
i++;
@@ -38,6 +39,7 @@ static void __qsort(char *base, size_t size, size_t lo, size_t hi, int (*compar)
void qsort(void * base, size_t nmemb, size_t size, int (*compar)(const void *, const void *))
{
SIGNAL_SAFE(0);
+ ASSERT_NONNULL(base);
__qsort(base, size, 0, nmemb - 1, compar);
}