X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=rset%2Frset.c;h=d6e20412c3c998495bd0aa1f9a3f7f5869607fc5;hb=062978fe7432da086bd0cb468149d88d1b6414cf;hp=667bd1d98de2471d1891d5217f3e7e17a3c5438f;hpb=affd7e4168d70b94e015b777748b7eca1cd00ec0;p=idzebra-moved-to-github.git diff --git a/rset/rset.c b/rset/rset.c index 667bd1d..d6e2041 100644 --- a/rset/rset.c +++ b/rset/rset.c @@ -1,34 +1,61 @@ /* - * Copyright (C) 1994, Index Data I/S + * Copyright (C) 1994-1995, Index Data I/S * All rights reserved. * Sebastian Hammer, Adam Dickmeiss * * $Log: rset.c,v $ - * Revision 1.1 1994-11-04 13:21:28 quinn + * Revision 1.8 1995-12-11 09:15:23 adam + * New set types: sand/sor/snot - ranked versions of and/or/not in + * ranked/semi-ranked result sets. + * Note: the snot not finished yet. + * New rset member: flag. + * Bug fix: r_delete in rsrel.c did free bad memory block. + * + * Revision 1.7 1995/10/12 12:41:56 adam + * Private info (buf) moved from struct rset_control to struct rset. + * Bug fixes in relevance. + * + * Revision 1.6 1995/09/08 14:52:41 adam + * Work on relevance feedback. + * + * Revision 1.5 1995/09/07 13:58:43 adam + * New parameter: result-set file descriptor (RSFD) to support multiple + * positions within the same result-set. + * Boolean operators: and, or, not implemented. + * + * Revision 1.4 1995/09/06 16:11:56 adam + * More work on boolean sets. + * + * Revision 1.3 1995/09/04 15:20:39 adam + * More work on temp sets. is_open member removed. + * + * Revision 1.2 1995/09/04 12:33:56 adam + * Various cleanup. YAZ util used instead. + * + * Revision 1.1 1994/11/04 13:21:28 quinn * Working. * */ -/* TODO: mem management */ - -#include +#include +#include #include RSET rset_create(const rset_control *sel, void *parms) { - RSET new; + RSET rnew; - new = xmalloc(sizeof(*new)); /* make dynamic alloc scheme */ - if (!(new->control = (*sel->f_create)(sel, parms))) - return 0; - return new; + logf (LOG_DEBUG, "rs_create(%s)", sel->desc); + rnew = xmalloc(sizeof(*rnew)); + rnew->control = sel; + rnew->flags = 0; + rnew->buf = (*sel->f_create)(sel, parms, &rnew->flags); + return rnew; } -void rset_delete(RSET rs) +void rset_delete (RSET rs) { - if (rs->is_open) - rset_close(rs); - (*rs->control->f_delete)(rs->control); + (*rs->control->f_delete)(rs); xfree(rs); }