Merge branch 'rs/qsort-s'
A few codepaths had to rely on a global variable when sorting elements of an array because sort(3) API does not allow extra data to be passed to the comparison function. Use qsort_s() when natively available, and a fallback implementation of it when not, to eliminate the need, which is a prerequisite for making the codepath reentrant. * rs/qsort-s: ref-filter: use QSORT_S in ref_array_sort() string-list: use QSORT_S in string_list_sort() perf: add basic sort performance test add QSORT_S compat: add qsort_s()
This commit is contained in:
@ -1594,8 +1594,7 @@ static int cmp_ref_sorting(struct ref_sorting *s, struct ref_array_item *a, stru
|
||||
return (s->reverse) ? -cmp : cmp;
|
||||
}
|
||||
|
||||
static struct ref_sorting *ref_sorting;
|
||||
static int compare_refs(const void *a_, const void *b_)
|
||||
static int compare_refs(const void *a_, const void *b_, void *ref_sorting)
|
||||
{
|
||||
struct ref_array_item *a = *((struct ref_array_item **)a_);
|
||||
struct ref_array_item *b = *((struct ref_array_item **)b_);
|
||||
@ -1611,8 +1610,7 @@ static int compare_refs(const void *a_, const void *b_)
|
||||
|
||||
void ref_array_sort(struct ref_sorting *sorting, struct ref_array *array)
|
||||
{
|
||||
ref_sorting = sorting;
|
||||
QSORT(array->items, array->nr, compare_refs);
|
||||
QSORT_S(array->items, array->nr, compare_refs, sorting);
|
||||
}
|
||||
|
||||
static void append_literal(const char *cp, const char *ep, struct ref_formatting_state *state)
|
||||
|
Reference in New Issue
Block a user