X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=rset%2Frsbool.c;h=673e75b63953dad78d481b9a2c2007834fd3622a;hb=3ef0c861c68e520a9a1cb0fa523251a2d3d739ee;hp=371e912202f795647ac689521298780006afd875;hpb=27742a4ea82e9b3494c166203b06d1d7c48da923;p=idzebra-moved-to-github.git 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);