X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=dict%2Flookup.c;h=465479d38b556951cc718019a683fb084dc3a4af;hp=3673e24bc8bc882e9557cd61d37209348fba3923;hb=896c0427df9d8eff5de6a1735dcd992e067df844;hpb=0035afa7de3e06c18bf2f559649f34913114ab46 diff --git a/dict/lookup.c b/dict/lookup.c index 3673e24..465479d 100644 --- a/dict/lookup.c +++ b/dict/lookup.c @@ -1,16 +1,26 @@ -/* - * Copyright (C) 1994, Index Data I/S - * All rights reserved. - * Sebastian Hammer, Adam Dickmeiss - * - * $Log: lookup.c,v $ - * Revision 1.2 1994-09-16 15:39:14 adam - * Initial code of lookup - not tested yet. - * - * Revision 1.1 1994/08/16 16:26:48 adam - * Added dict. - * - */ +/* $Id: lookup.c,v 1.11 2002-08-02 19:26:55 adam Exp $ + Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002 + Index Data Aps + +This file is part of the Zebra server. + +Zebra is free software; you can redistribute it and/or modify it under +the terms of the GNU General Public License as published by the Free +Software Foundation; either version 2, or (at your option) any later +version. + +Zebra is distributed in the hope that it will be useful, but WITHOUT ANY +WARRANTY; without even the implied warranty of MERCHANTABILITY or +FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +for more details. + +You should have received a copy of the GNU General Public License +along with Zebra; see the file LICENSE.zebra. If not, write to the +Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA +02111-1307, USA. +*/ + + #include #include @@ -19,9 +29,8 @@ #include -static char *dict_look (Dict dict, Dict_char *str) +static char *dict_look (Dict dict, const Dict_char *str, Dict_ptr ptr) { - Dict_ptr ptr = 1; int mid, lo, hi; int cmp; void *p; @@ -31,7 +40,7 @@ static char *dict_look (Dict dict, Dict_char *str) dict_bf_readp (dict->dbf, ptr, &p); mid = lo = 0; hi = DICT_nodir(p)-1; - indxp = (short*) ((char*) p+DICT_PAGESIZE-sizeof(short)); + indxp = (short*) ((char*) p+DICT_bsize(p)-sizeof(short)); while (lo <= hi) { mid = (lo+hi)/2; @@ -43,7 +52,8 @@ static char *dict_look (Dict dict, Dict_char *str) info = (char*)p + indxp[-mid]; cmp = dict_strcmp((Dict_char*) info, str); if (!cmp) - return info+(dict_strlen (info)+1)*sizeof(Dict_char); + return info+(dict_strlen ((Dict_char*) info)+1) + *sizeof(Dict_char); } else { @@ -61,7 +71,11 @@ static char *dict_look (Dict dict, Dict_char *str) { memcpy (&subptr, info, sizeof(Dict_ptr)); if (*++str == DICT_EOS) - return info+sizeof(Dict_ptr)+sizeof(Dict_char); + { + if (info[sizeof(Dict_ptr)+sizeof(Dict_char)]) + return info+sizeof(Dict_ptr)+sizeof(Dict_char); + return NULL; + } else { if (subptr == 0) @@ -70,7 +84,7 @@ static char *dict_look (Dict dict, Dict_char *str) dict_bf_readp (dict->dbf, ptr, &p); mid = lo = 0; hi = DICT_nodir(p)-1; - indxp = (short*) ((char*) p+DICT_PAGESIZE-sizeof(short)); + indxp = (short*) ((char*) p+DICT_bsize(p)-sizeof(short)); continue; } } @@ -83,11 +97,9 @@ static char *dict_look (Dict dict, Dict_char *str) return NULL; } -char *dict_lookup (Dict dict, Dict_char *p) +char *dict_lookup (Dict dict, const char *p) { - if (dict->head.last == 1) + if (!dict->head.root) return NULL; - return dict_look (dict, p); + return dict_look (dict, (const Dict_char *) p, dict->head.root); } - -