From: Adam Dickmeiss Date: Mon, 20 Feb 2006 12:41:42 +0000 (+0000) Subject: Fixed bug #472: dumpdict is broken. X-Git-Tag: before.bug.529~228 X-Git-Url: http://sru.miketaylor.org.uk/cgi-bin?a=commitdiff_plain;h=4d7345f0e28b1e56658c26a31ffaee95dcf502c0;p=idzebra-moved-to-github.git Fixed bug #472: dumpdict is broken. --- diff --git a/index/invstat.c b/index/invstat.c index bd8037d..76b99a3 100644 --- a/index/invstat.c +++ b/index/invstat.c @@ -1,4 +1,4 @@ -/* $Id: invstat.c,v 1.46 2005-04-13 13:03:47 adam Exp $ +/* $Id: invstat.c,v 1.47 2006-02-20 12:41:42 adam Exp $ Copyright (C) 1995-2005 Index Data ApS @@ -45,27 +45,25 @@ struct inv_stat_info { #define SINGLETON_TYPE 8 /* the type to use for singletons that */ /* have no block and no block type */ -static void print_dict_item (ZebraMaps zm, const char *s, zint count, +static void print_dict_item (ZebraHandle zh, const char *s, zint count, int firstsys, int firstseq, int lastsys, int lastseq ) { - int reg_type = s[1]; - char keybuf[IT_MAX_WORD+1]; - char *to = keybuf; - const char *from = s + 2; - - while (*from) + char dst[IT_MAX_WORD+1]; + int ord; + int len = key_SU_decode(&ord, (const unsigned char *) s); + int index_type; + const char *db = 0; + + if (!zh) + *dst = '\0'; + else { - const char *res = zebra_maps_output (zm, reg_type, &from); - if (!res) - *to++ = *from++; - else - while (*res) - *to++ = *res++; + zebraExplain_lookup_ord (zh->reg->zei, ord, &index_type, &db, 0, 0); + + zebra_term_untrans(zh, index_type, dst, s + len); } - *to = '\0'; - /* yaz_log (YLOG_LOG, "%s", keybuf); */ - printf("%10" ZINT_FORMAT0 " %s %d.%d - %d.%d\n", count, keybuf, - firstsys,firstseq, lastsys,lastseq); + printf("%02d:%10" ZINT_FORMAT0 " %s %d.%d - %d.%d\n", ord, count, dst, + firstsys, firstseq, lastsys, lastseq); } static int inv_stat_handle (char *name, const char *info, int pos, @@ -146,8 +144,8 @@ static int inv_stat_handle (char *name, const char *info, int pos, i++; ++(stat_info->isam_occurrences[i]); if (stat_info->dumpwords) - print_dict_item(stat_info->zh->reg->zebra_maps, name, occur, - firstsys,firstseq, lastsys, lastseq); + print_dict_item(stat_info->zh, name, occur, + firstsys, firstseq, lastsys, lastseq); return 0; } diff --git a/index/zinfo.c b/index/zinfo.c index 740f7f0..b474306 100644 --- a/index/zinfo.c +++ b/index/zinfo.c @@ -1,4 +1,4 @@ -/* $Id: zinfo.c,v 1.54 2006-02-09 08:31:02 adam Exp $ +/* $Id: zinfo.c,v 1.55 2006-02-20 12:41:42 adam Exp $ Copyright (C) 1995-2005 Index Data ApS @@ -1450,8 +1450,12 @@ int zebraExplain_lookup_ord (ZebraExplainInfo zei, int ord, struct zebDatabaseInfoB *zdb; for (zdb = zei->databaseInfo; zdb; zdb = zdb->next) { - struct zebSUInfoB *zsui = zdb->attributeDetails->SUInfo; - for ( ;zsui; zsui = zsui->next) + struct zebSUInfoB *zsui; + + if (zdb->attributeDetails->readFlag) + zebraExplain_readAttributeDetails (zei, zdb->attributeDetails); + + for (zsui = zdb->attributeDetails->SUInfo; zsui; zsui = zsui->next) if (zsui->info.ordinal == ord) { if (db)