projects
/
idzebra-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix problem with generic proximity handling.
[idzebra-moved-to-github.git]
/
rset
/
rsprox.c
diff --git
a/rset/rsprox.c
b/rset/rsprox.c
index
8c7a545
..
896854e
100644
(file)
--- a/
rset/rsprox.c
+++ b/
rset/rsprox.c
@@
-221,11
+221,14
@@
static int r_forward(RSFD rfd, void *buf, TERMID *term, const void *untilbuf)
seqno[n++] = (*kctrl->getseq)(p->buf[0]);
while ((p->more[0] = rset_read (p->rfd[0],
seqno[n++] = (*kctrl->getseq)(p->buf[0]);
while ((p->more[0] = rset_read (p->rfd[0],
- p->buf[0], &p->terms[0])) >= -1 &&
- p->more[0] <= -1)
+ p->buf[0], &p->terms[0])))
+ {
+ cmp = (*kctrl->cmp)(p->buf[0], p->buf[1]);
+ if (cmp <= - rfd->rset->scope || cmp >= rfd->rset->scope)
+ break;
if (n < 500)
seqno[n++] = (*kctrl->getseq)(p->buf[0]);
if (n < 500)
seqno[n++] = (*kctrl->getseq)(p->buf[0]);
-
+ }
for (i = 0; i<n; i++)
{
zint diff = (*kctrl->getseq)(p->buf[1]) - seqno[i];
for (i = 0; i<n; i++)
{
zint diff = (*kctrl->getseq)(p->buf[1]) - seqno[i];
@@
-333,6
+336,7
@@
static void r_get_terms(RSET ct, TERMID *terms, int maxterms, int *curterm)
/*
* Local variables:
* c-basic-offset: 4
/*
* Local variables:
* c-basic-offset: 4
+ * c-file-style: "Stroustrup"
* indent-tabs-mode: nil
* End:
* vim: shiftwidth=4 tabstop=8 expandtab
* indent-tabs-mode: nil
* End:
* vim: shiftwidth=4 tabstop=8 expandtab