From: Adam Dickmeiss Date: Wed, 28 Jun 2006 09:40:17 +0000 (+0000) Subject: Fixed bug #619: @not searches results in bad memory reference. X-Git-Tag: ZEBRA.2.0.0~85 X-Git-Url: http://jsfdemo.indexdata.com/cgi-bin?a=commitdiff_plain;h=3ef0c861c68e520a9a1cb0fa523251a2d3d739ee;p=idzebra-moved-to-github.git Fixed bug #619: @not searches results in bad memory reference. --- diff --git a/rset/rsbool.c b/rset/rsbool.c index 371e912..673e75b 100644 --- a/rset/rsbool.c +++ b/rset/rsbool.c @@ -1,4 +1,4 @@ -/* $Id: rsbool.c,v 1.59 2006-06-06 21:01:30 adam Exp $ +/* $Id: rsbool.c,v 1.60 2006-06-28 09:40:17 adam Exp $ Copyright (C) 1995-2006 Index Data ApS @@ -176,14 +176,12 @@ static int r_read_not(RSFD rfd, void *buf, TERMID *term) struct rfd_private *p = (struct rfd_private *)rfd->priv; const struct rset_key_control *kctrl = rfd->rset->keycontrol; - while (p->more_l || p->more_r) + while (p->more_l) { int cmp; - if (p->more_l && p->more_r) + if (p->more_r) cmp = (*kctrl->cmp)(p->buf_l, p->buf_r); - else if (p->more_r) - cmp = rfd->rset->scope; else cmp = -rfd->rset->scope; @@ -197,8 +195,10 @@ static int r_read_not(RSFD rfd, void *buf, TERMID *term) return 1; } else if (cmp >= rfd->rset->scope) /* cmp >1 */ + { p->more_r = rset_forward( p->rfd_r, p->buf_r, - &p->term_r, p->buf_l); + &p->term_r, p->buf_l); + } else { /* cmp== -1, 0, or 1 */ memcpy (buf, p->buf_l, kctrl->key_size);