X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Frankstatic.c;h=9abc7ec50c82454664b61556e0bbcf11a5ea044c;hb=620f52e2409924d81f740001b9de6077f933cb52;hp=a17055f7489d825a91ad5414b8166e11bdc14959;hpb=342c28e71fe5122d17d760a930107cab0266e9c6;p=idzebra-moved-to-github.git diff --git a/index/rankstatic.c b/index/rankstatic.c index a17055f..9abc7ec 100644 --- a/index/rankstatic.c +++ b/index/rankstatic.c @@ -1,4 +1,4 @@ -/* $Id: rankstatic.c,v 1.1 2005-08-19 09:21:34 adam Exp $ +/* $Id: rankstatic.c,v 1.3 2005-08-19 11:04:23 adam Exp $ Copyright (C) 1995-2005 Index Data ApS @@ -22,6 +22,7 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA #include #include +#include #ifdef WIN32 #include #endif @@ -115,14 +116,17 @@ static void add (void *set_handle, int seqno, TERMID term) * score should be between 0 and 1000. If score cannot be obtained * -1 should be returned. */ -static int calc (void *set_handle, zint sysno, zint staticrank) +static int calc (void *set_handle, zint sysno, zint staticrank, + int *stop_flag) { struct rank_set_info *si = (struct rank_set_info *) set_handle; if (!si->no_rank_entries) return -1; /* ranking not enabled for any terms */ - return staticrank+10; + /* if we set *stop_flag = 1, we stop processing (of result set list) */ + /* staticrank = 0 is highest, MAXINT lowest */ + return INT_MAX - staticrank; /* but score is reverse (logical) */ } /*