blob: 644cff1f9640f4f3a146d7217a8deab34282ff53 [file] [log] [blame]
René Scharfe0db71e02012-04-01 00:10:11 +02001#ifndef MERGESORT_H
2#define MERGESORT_H
3
Junio C Hamano7365c952012-04-17 11:07:01 -07004/*
5 * Sort linked list in place.
6 * - get_next_fn() returns the next element given an element of a linked list.
7 * - set_next_fn() takes two elements A and B, and makes B the "next" element
8 * of A on the list.
9 * - compare_fn() takes two elements A and B, and returns negative, 0, positive
10 * as the same sign as "subtracting" B from A.
11 */
12void *llist_mergesort(void *list,
13 void *(*get_next_fn)(const void *),
14 void (*set_next_fn)(void *, void *),
15 int (*compare_fn)(const void *, const void *));
René Scharfe0db71e02012-04-01 00:10:11 +020016
17#endif