X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=rset%2Frsbool.c;h=f34a61f15876466d16dd90a5082aaf46c0d80ff3;hb=dbad401e961e478286a6427841921c2f19a6f69b;hp=e2bec06ef7b287352b751b7e1307d439bf7ee60c;hpb=a322231bcd4bfed2886c571aa91da5f73cad62a9;p=idzebra-moved-to-github.git diff --git a/rset/rsbool.c b/rset/rsbool.c index e2bec06..f34a61f 100644 --- a/rset/rsbool.c +++ b/rset/rsbool.c @@ -4,7 +4,13 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: rsbool.c,v $ - * Revision 1.3 1995-09-07 13:58:43 adam + * Revision 1.5 1995-09-08 14:52:41 adam + * Work on relevance feedback. + * + * Revision 1.4 1995/09/08 08:54:04 adam + * More efficient and operation. + * + * Revision 1.3 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. @@ -106,7 +112,6 @@ static rset_control *r_create (const struct rset_control *sel, void *parms) rset_bool_parms *bool_parms = parms; struct rset_bool_info *info; - logf (LOG_DEBUG, "rsbool_create(%s)", sel->desc); newct = xmalloc(sizeof(*newct)); memcpy (newct, sel, sizeof(*sel)); newct->buf = xmalloc (sizeof(struct rset_bool_info)); @@ -194,16 +199,11 @@ static int r_read_and (RSFD rfd, void *buf) struct rset_bool_rfd *p = rfd; struct rset_bool_info *info = p->info; - while (p->more_l || p->more_r) + while (p->more_l && p->more_r) { int cmp; - if (p->more_l && p->more_r) - cmp = (*info->cmp)(p->buf_l, p->buf_r); - else if (p->more_r) - cmp = 2; - else - cmp = -2; + cmp = (*info->cmp)(p->buf_l, p->buf_r); if (!cmp) { memcpy (buf, p->buf_l, info->key_size);