X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=index%2Fzsets.c;h=8e481327aca3b22d7338652b6ec273272091c8c7;hb=91056985a65db6893bb136a9f92402dadfed659a;hp=19a6cf8958c3d9fe5146daa6274418bb350372a7;hpb=3731bdaf94aeba2550fc553aebe34831c203dc36;p=idzebra-moved-to-github.git diff --git a/index/zsets.c b/index/zsets.c index 19a6cf8..8e48132 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.130 2007-12-19 14:11:36 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 || !zh->m_segment_indexing) + { + if (sysnos_offset < *no_sysnos) + *sysnos = recid; + sysnos_offset++; + } + else { for (i = 0; res == ZEBRA_OK && i < num_bases; i++) { @@ -1364,8 +1370,6 @@ static ZEBRA_RES zebra_recid_to_sysno(ZebraHandle zh, sysnos[sysnos_offset] = key_found.mem[key_found.len-1]; - yaz_log(YLOG_LOG, "Found " ZINT_FORMAT, - key_found.mem[key_found.len-1]); r = isamb_pp_read(pt, &key_found); sysnos_offset++; } @@ -1397,6 +1401,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; +} /*