X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dict%2Flookup.c;h=f22054276b3a0f3957f2f1da04563fcbd05dd526;hb=664413d3aab4207a0f895caa87c4a57b022e5998;hp=01f5ac4a5c9d1d3312676409ffe9f4fe935d0189;hpb=b31a8654c5b7a597dd4a351f452ac91e5ef60798;p=idzebra-moved-to-github.git diff --git a/dict/lookup.c b/dict/lookup.c index 01f5ac4..f220542 100644 --- a/dict/lookup.c +++ b/dict/lookup.c @@ -1,43 +1,36 @@ -/* - * Copyright (C) 1994, Index Data I/S - * All rights reserved. - * Sebastian Hammer, Adam Dickmeiss - * - * $Log: lookup.c,v $ - * Revision 1.7 1996-02-02 13:43:51 adam - * The public functions simply use char instead of Dict_char to represent - * search strings. Dict_char is used internally only. - * - * Revision 1.6 1995/12/11 09:04:50 adam - * Bug fix: the lookup/scan/lookgrep didn't handle empty dictionary. - * - * Revision 1.5 1995/09/04 09:09:15 adam - * String arg in lookup is const. - * - * Revision 1.4 1994/10/05 12:16:51 adam - * Pagesize is a resource now. - * - * Revision 1.3 1994/09/26 10:17:25 adam - * Minor changes. - * - * 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.13 2005-01-15 19:38:23 adam Exp $ + Copyright (C) 1995-2005 + 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 #include #include -#include +#include "dict-p.h" -static char *dict_look (Dict dict, const 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; @@ -47,7 +40,7 @@ static char *dict_look (Dict dict, const Dict_char *str) dict_bf_readp (dict->dbf, ptr, &p); mid = 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) { mid = (lo+hi)/2; @@ -91,8 +84,7 @@ static char *dict_look (Dict dict, const Dict_char *str) dict_bf_readp (dict->dbf, ptr, &p); mid = 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)); continue; } } @@ -107,9 +99,7 @@ static char *dict_look (Dict dict, const Dict_char *str) char *dict_lookup (Dict dict, const char *p) { - if (dict->head.last <= 1) + if (!dict->head.root) return NULL; - return dict_look (dict, (const Dict_char *) p); + return dict_look (dict, (const Dict_char *) p, dict->head.root); } - -