X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Freclists.h;h=bc02f107e26939aae795e1e924e8c578caf5842c;hb=3f79fd8c6a86f2376e9f3a2485f81ebd5c37bb82;hp=51653b1eee62d32aab513f0413ee556a0436a1a2;hpb=9267d02c3601122f74bdf3a9d21f30080a4a1a9a;p=pazpar2-moved-to-github.git diff --git a/src/reclists.h b/src/reclists.h index 51653b1..bc02f10 100644 --- a/src/reclists.h +++ b/src/reclists.h @@ -1,5 +1,5 @@ /* This file is part of Pazpar2. - Copyright (C) 2006-2009 Index Data + Copyright (C) 2006-2010 Index Data Pazpar2 is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free @@ -23,19 +23,7 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #include "pazpar2_config.h" #include "record.h" -struct reclist -{ - struct reclist_bucket **hashtable; - int hashtable_size; - int hashmask; - - struct record_cluster **flatlist; - int flatlist_size; - int num_records; - int pointer; - - NMEM nmem; -}; +struct reclist; // This is a recipe for sorting. First node in list has highest priority struct reclist_sortparms @@ -46,31 +34,21 @@ struct reclist_sortparms struct reclist_sortparms *next; }; -struct reclist_sortparms * -reclist_sortparms_insert_field_id(NMEM nmem, - struct reclist_sortparms **sortparms, - int field_id , - enum conf_sortkey_type type, - int increasing); - - -struct reclist_sortparms * -reclist_sortparms_insert(NMEM nmem, - struct reclist_sortparms **sortparms, - struct conf_service * service, - const char * name, - int increasing); - - -struct reclist *reclist_create(NMEM, int numrecs); -struct record_cluster *reclist_insert( struct reclist *tl, - struct conf_service *service, - struct record *record, - char *merge_key, int *total); +struct reclist *reclist_create(NMEM); +void reclist_destroy(struct reclist *l); +struct record_cluster *reclist_insert(struct reclist *tl, + struct conf_service *service, + struct record *record, + const char *merge_key, int *total); void reclist_sort(struct reclist *l, struct reclist_sortparms *parms); struct record_cluster *reclist_read_record(struct reclist *l); -void reclist_rewind(struct reclist *l); -struct reclist_sortparms *reclist_parse_sortparms(NMEM nmem, const char *parms); +void reclist_enter(struct reclist *l); +void reclist_leave(struct reclist *l); +struct reclist_sortparms *reclist_parse_sortparms(NMEM nmem, const char *parms, + struct conf_service *service); + +int reclist_get_num_records(struct reclist *l); +struct record_cluster *reclist_get_cluster(struct reclist *l, int i); #endif