9 static void *get_next(const void *a
)
11 return ((const struct line
*)a
)->next
;
14 static void set_next(void *a
, void *b
)
16 ((struct line
*)a
)->next
= b
;
19 static int compare_strings(const void *a
, const void *b
)
21 const struct line
*x
= a
, *y
= b
;
22 return strcmp(x
->text
, y
->text
);
25 int main(int argc
, char **argv
)
27 struct line
*line
, *p
= NULL
, *lines
= NULL
;
28 struct strbuf sb
= STRBUF_INIT
;
31 if (strbuf_getwholeline(&sb
, stdin
, '\n'))
33 line
= xmalloc(sizeof(struct line
));
34 line
->text
= strbuf_detach(&sb
, NULL
);
45 lines
= llist_mergesort(lines
, get_next
, set_next
, compare_strings
);
48 printf("%s", lines
->text
);