X-Git-Url: http://sru.miketaylor.org.uk/?a=blobdiff_plain;f=rset%2Frsbool.c;h=ba61fc627db6fe75b05da2aaed0c393264af8d12;hb=0245f556af399689056b7810ed0e3de93021ad4a;hp=a20c452e4250ed64c241316ca65a90427759874f;hpb=9d7f0678da8e15bfc9b04a21aad15656b8cc65f2;p=idzebra-moved-to-github.git diff --git a/rset/rsbool.c b/rset/rsbool.c index a20c452..ba61fc6 100644 --- a/rset/rsbool.c +++ b/rset/rsbool.c @@ -4,7 +4,17 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: rsbool.c,v $ - * Revision 1.4 1995-09-08 08:54:04 adam + * Revision 1.7 1995-10-10 14:00:03 adam + * Function rset_open changed its wflag parameter to general flags. + * + * Revision 1.6 1995/10/06 14:38:05 adam + * New result set method: r_score. + * Local no (sysno) and score is transferred to retrieveCtrl. + * + * 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 @@ -27,7 +37,7 @@ #include static rset_control *r_create(const struct rset_control *sel, void *parms); -static RSFD r_open (rset_control *ct, int wflag); +static RSFD r_open (rset_control *ct, int flag); static void r_close (RSFD rfd); static void r_delete (rset_control *ct); static void r_rewind (RSFD rfd); @@ -36,6 +46,7 @@ static int r_read_and (RSFD rfd, void *buf); static int r_read_or (RSFD rfd, void *buf); static int r_read_not (RSFD rfd, void *buf); static int r_write (RSFD rfd, const void *buf); +static int r_score (RSFD rfd, int *score); static const rset_control control_and = { @@ -48,7 +59,8 @@ static const rset_control control_and = r_rewind, r_count, r_read_and, - r_write + r_write, + r_score }; static const rset_control control_or = @@ -62,7 +74,8 @@ static const rset_control control_or = r_rewind, r_count, r_read_or, - r_write + r_write, + r_score }; static const rset_control control_not = @@ -76,7 +89,8 @@ static const rset_control control_not = r_rewind, r_count, r_read_not, - r_write + r_write, + r_score }; @@ -109,7 +123,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)); @@ -122,12 +135,12 @@ static rset_control *r_create (const struct rset_control *sel, void *parms) return newct; } -static RSFD r_open (rset_control *ct, int wflag) +static RSFD r_open (rset_control *ct, int flag) { struct rset_bool_info *info = ct->buf; struct rset_bool_rfd *rfd; - if (wflag) + if (flag & RSETF_WRITE) { logf (LOG_FATAL, "bool set type is read-only"); return NULL; @@ -138,8 +151,8 @@ static RSFD r_open (rset_control *ct, int wflag) rfd->buf_l = xmalloc (info->key_size); rfd->buf_r = xmalloc (info->key_size); - rfd->rfd_l = rset_open (info->rset_l, wflag); - rfd->rfd_r = rset_open (info->rset_r, wflag); + rfd->rfd_l = rset_open (info->rset_l, flag); + rfd->rfd_r = rset_open (info->rset_r, flag); rfd->more_l = rset_read (info->rset_l, rfd->rfd_l, rfd->buf_l); rfd->more_r = rset_read (info->rset_r, rfd->rfd_r, rfd->buf_r); rfd->info = info; @@ -318,3 +331,10 @@ static int r_write (RSFD rfd, const void *buf) logf (LOG_FATAL, "bool set type is read-only"); return -1; } + +static int r_score (RSFD rfd, int *score) +{ + *score = -1; + return -1; +} +