1 /* $Id: reclists.h,v 1.10 2007-04-25 13:09:17 marc Exp $
2 Copyright (c) 2006-2007, Index Data.
4 This file is part of Pazpar2.
6 Pazpar2 is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 2, or (at your option) any later
11 Pazpar2 is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with Pazpar2; see the file LICENSE. If not, write to the
18 Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
30 struct reclist_bucket **hashtable;
34 struct record_cluster **flatlist;
42 // This is a recipe for sorting. First node in list has highest priority
43 struct reclist_sortparms
46 enum conf_sortkey_type type;
48 struct reclist_sortparms *next;
51 struct reclist_sortparms *
52 reclist_sortparms_insert_field_id(NMEM nmem,
53 struct reclist_sortparms **sortparms,
55 enum conf_sortkey_type type,
59 struct reclist_sortparms *
60 reclist_sortparms_insert(NMEM nmem,
61 struct reclist_sortparms **sortparms,
62 struct conf_service * service,
67 struct reclist *reclist_create(NMEM, int numrecs);
68 struct record_cluster *reclist_insert( struct reclist *tl,
69 struct conf_service *service,
70 struct record *record,
71 const char *merge_key, int *total);
72 void reclist_sort(struct reclist *l, struct reclist_sortparms *parms);
73 struct record_cluster *reclist_read_record(struct reclist *l);
74 void reclist_rewind(struct reclist *l);
75 struct reclist_sortparms *reclist_parse_sortparms(NMEM nmem, const char *parms);
82 * indent-tabs-mode: nil
84 * vim: shiftwidth=4 tabstop=8 expandtab