X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dict%2Flookupec.c;h=975e8347ebf771b856875764e09dc300815233db;hb=e5ebc859654d84aa9098142b34015648d8e333de;hp=212dbc8b0ff7dbb01fea535a3eb5bd441f5e5aea;hpb=3c5f6226f97612c0d6ac40591f600587c5ffa858;p=idzebra-moved-to-github.git diff --git a/dict/lookupec.c b/dict/lookupec.c index 212dbc8..975e834 100644 --- a/dict/lookupec.c +++ b/dict/lookupec.c @@ -4,7 +4,13 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: lookupec.c,v $ - * Revision 1.7 1999-02-02 14:50:26 adam + * Revision 1.9 1999-05-26 07:49:13 adam + * C++ compilation. + * + * Revision 1.8 1999/05/15 14:36:37 adam + * Updated dictionary. Implemented "compression" of dictionary. + * + * Revision 1.7 1999/02/02 14:50:26 adam * Updated WIN32 code specific sections. Changed header. * * Revision 1.6 1996/02/02 13:43:51 adam @@ -60,7 +66,7 @@ int dict_look_ec (Dict dict, Dict_ptr ptr, MatchInfo *mi, MatchWord *ri_base, dict_bf_readp (dict->dbf, ptr, &p); lo = 0; hi = DICT_nodir(p)-1; - indxp = (short*) ((char*) p+DICT_pagesize(dict)-sizeof(short)); + indxp = (short*) ((char*) p+DICT_bsize(p)-sizeof(short)); while (lo <= hi) { if (indxp[-lo] > 0) @@ -131,7 +137,7 @@ int dict_look_ec (Dict dict, Dict_ptr ptr, MatchInfo *mi, MatchWord *ri_base, userfunc, range, prefix); dict_bf_readp (dict->dbf, ptr, &p); indxp = (short*) ((char*) p + - DICT_pagesize(dict)-sizeof(short)); + DICT_bsize(p)-sizeof(short)); } } } @@ -146,9 +152,9 @@ static MatchInfo *prepare_match (Dict_char *pattern) MatchWord *s; MatchInfo *mi; - mi = xmalloc (sizeof(*mi)); + mi = (MatchInfo *) xmalloc (sizeof(*mi)); mi->m = dict_strlen (pattern); - mi->s = s = xmalloc (sizeof(*s)*256); /* 256 !!! */ + mi->s = s = (MatchWord *) xmalloc (sizeof(*s)*256); /* 256 !!! */ for (i=0; i<256; i++) s[i] = 0; for (i=0; pattern[i]; i++) @@ -164,17 +170,18 @@ int dict_lookup_ec (Dict dict, char *pattern, int range, int i; Dict_char prefix[2048]; - if (dict->head.last == 1) + if (!dict->head.root) return 0; mi = prepare_match ((Dict_char*) pattern); - ri = xmalloc ((dict_strlen((Dict_char*) pattern)+range+2) - * (range+1)*sizeof(*ri)); + ri = (MatchWord *) xmalloc ((dict_strlen((Dict_char*) pattern)+range+2) + * (range+1)*sizeof(*ri)); for (i=0; i<=range; i++) ri[i] = (2<head.root, mi, ri, 0, userfunc, + range, prefix); xfree (ri); return i; }