* Sebastian Hammer, Adam Dickmeiss
*
* $Log: zserver.c,v $
- * Revision 1.12 1995-10-06 13:52:06 adam
+ * Revision 1.14 1995-10-09 16:18:37 adam
+ * Function dict_lookup_grep got extra client data parameter.
+ *
+ * Revision 1.13 1995/10/06 14:38:00 adam
+ * New result set method: r_score.
+ * Local no (sysno) and score is transferred to retrieveCtrl.
+ *
+ * Revision 1.12 1995/10/06 13:52:06 adam
* Bug fixes. Handler may abort further scanning.
*
* Revision 1.11 1995/10/06 10:43:57 adam
return read (fd, buf, count);
}
-static int record_fetch (ZServerInfo *zi, int sysno, ODR stream,
+static int record_fetch (ZServerInfo *zi, int sysno, int score, ODR stream,
oid_value input_format, oid_value *output_format,
char **rec_bufp, int *rec_lenp)
{
logf (LOG_FATAL|LOG_ERRNO, "Retrieve: Open record file %s", fname);
exit (1);
}
+ logf (LOG_DEBUG, "retrieve localno=%d score=%d", sysno, score);
+ retrieveCtrl.localno = sysno;
+ retrieveCtrl.score = score;
retrieveCtrl.odr = stream;
retrieveCtrl.readf = record_read;
retrieveCtrl.input_format = retrieveCtrl.output_format = input_format;
logf (LOG_DEBUG, "Out of range. pos=%d", q->number);
return &r;
}
- r.errcode = record_fetch (&server_info, records[0].sysno, q->stream,
+ r.errcode = record_fetch (&server_info, records[0].sysno,
+ records[0].score, q->stream,
q->format, &r.format, &r.record, &r.len);
return &r;
}
bend_scanresult *bend_scan (void *handle, bend_scanrequest *q, int *num)
{
static bend_scanresult r;
+ int status;
odr_reset (server_info.odr);
server_info.errCode = 0;
r.num_entries = q->num_entries;
r.errcode = rpn_scan (&server_info, server_info.odr, q->term,
&r.term_position,
- &r.num_entries, &r.entries);
+ &r.num_entries, &r.entries, &status);
+ r.status = status;
return &r;
}