X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fzsets.c;h=8810246c71c8d7b2af230871bbc2cf343748d901;hb=95a5868bb03e3445b1e234a969358b6eaa74a49c;hp=19a6cf8958c3d9fe5146daa6274418bb350372a7;hpb=3731bdaf94aeba2550fc553aebe34831c203dc36;p=idzebra-moved-to-github.git diff --git a/index/zsets.c b/index/zsets.c index 19a6cf8..8810246 100644 --- a/index/zsets.c +++ b/index/zsets.c @@ -1,4 +1,4 @@ -/* $Id: zsets.c,v 1.126 2007-11-30 12:19:09 adam Exp $ +/* $Id: zsets.c,v 1.128 2007-12-03 11:49:11 adam Exp $ Copyright (C) 1995-2007 Index Data ApS @@ -1307,7 +1307,13 @@ static ZEBRA_RES zebra_recid_to_sysno(ZebraHandle zh, int sysnos_offset = 0; int i; - if (zh->reg->isamb) + if (!zh->reg->isamb) + { + if (sysnos_offset < *no_sysnos) + *sysnos = recid; + sysnos_offset++; + } + else { for (i = 0; res == ZEBRA_OK && i < num_bases; i++) { @@ -1397,6 +1403,32 @@ ZEBRA_RES zebra_result_recid_to_sysno(ZebraHandle zh, return zebra_recid_to_sysno(zh, basenames, num_bases, recid, sysnos, no_sysnos); } + +void zebra_count_set(ZebraHandle zh, RSET rset, zint *count, + zint approx_limit) +{ + zint psysno = 0; + struct it_key key; + RSFD rfd; + + yaz_log(YLOG_DEBUG, "count_set"); + + rset->hits_limit = approx_limit; + + *count = 0; + rfd = rset_open(rset, RSETF_READ); + while (rset_read(rfd, &key,0 /* never mind terms */)) + { + if (key.mem[0] != psysno) + { + psysno = key.mem[0]; + if (rfd->counted_items >= rset->hits_limit) + break; + } + } + rset_close(rfd); + *count = rset->hits_count; +} /*