X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Freclists.h;h=bc02f107e26939aae795e1e924e8c578caf5842c;hb=e6d6362b750ae25591ee5a40e135878fd590e13e;hp=61a25ec70be27fbc47523e8db46290ece0d16052;hpb=8ca1269eac32c1ddc19d16dc4f74e9a1e3e0b8f9;p=pazpar2-moved-to-github.git diff --git a/src/reclists.h b/src/reclists.h index 61a25ec..bc02f10 100644 --- a/src/reclists.h +++ b/src/reclists.h @@ -1,21 +1,29 @@ -#ifndef RECLISTS_H -#define RECLISTS_H +/* This file is part of Pazpar2. + Copyright (C) 2006-2010 Index Data -#include "config.h" +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 +Software Foundation; either version 2, or (at your option) any later +version. -struct reclist -{ - struct reclist_bucket **hashtable; - int hashtable_size; - int hashmask; +Pazpar2 is distributed in the hope that it will be useful, but WITHOUT ANY +WARRANTY; without even the implied warranty of MERCHANTABILITY or +FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +for more details. - struct record_cluster **flatlist; - int flatlist_size; - int num_records; - int pointer; +You should have received a copy of the GNU General Public License +along with this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA - NMEM nmem; -}; +*/ + +#ifndef RECLISTS_H +#define RECLISTS_H + +#include "pazpar2_config.h" +#include "record.h" + +struct reclist; // This is a recipe for sorting. First node in list has highest priority struct reclist_sortparms @@ -26,20 +34,30 @@ struct reclist_sortparms struct reclist_sortparms *next; }; -struct reclist *reclist_create(NMEM, int numrecs); -struct record_cluster *reclist_insert(struct reclist *tl, 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 /* * Local variables: * c-basic-offset: 4 + * c-file-style: "Stroustrup" * indent-tabs-mode: nil * End: * vim: shiftwidth=4 tabstop=8 expandtab */ +