chiark / gitweb /
Switch to GPL v3
[disorder] / lib / tracksort.c
1 /*
2  * This file is part of DisOrder
3  * Copyright (C) 2008 Richard Kettlewell
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation, either version 3 of the License, or
8  * (at your option) any later version.
9  * 
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  * 
15  * You should have received a copy of the GNU General Public License
16  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
17  */
18 #include "common.h"
19
20 #include "trackname.h"
21 #include "mem.h"
22
23 /** @brief Compare two @ref entry objects */
24 static int tracksort_compare(const void *a, const void *b) {
25   const struct tracksort_data *ea = a, *eb = b;
26
27   return compare_tracks(ea->sort, eb->sort,
28                         ea->display, eb->display,
29                         ea->track, eb->track);
30 }
31
32 struct tracksort_data *tracksort_init(int ntracks,
33                                       char **tracks,
34                                       const char *type) {
35   struct tracksort_data *td = xcalloc(ntracks, sizeof *td);
36   for(int n = 0; n < ntracks; ++n) {
37     td[n].track = tracks[n];
38     td[n].sort = trackname_transform(type, tracks[n], "sort");
39     td[n].display = trackname_transform(type, tracks[n], "display");
40   }
41   qsort(td, ntracks, sizeof *td, tracksort_compare);
42   return td;
43 }
44
45 /*
46 Local Variables:
47 c-basic-offset:2
48 comment-column:40
49 fill-column:79
50 indent-tabs-mode:nil
51 End:
52 */