X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=dict%2Fdopen.c;h=e95c59ab660401452a6a3f58d061502c6f5f0bb4;hp=1f1fda3d1a65633a483d74def133507765c518c1;hb=a5c8c78e8671af863fc61b2ad8b24f92f827f7b2;hpb=b9093505b17a074e79137ed64595c8269f77d330 diff --git a/dict/dopen.c b/dict/dopen.c index 1f1fda3..e95c59a 100644 --- a/dict/dopen.c +++ b/dict/dopen.c @@ -1,51 +1,60 @@ -/* - * Copyright (C) 1994, Index Data I/S - * All rights reserved. - * Sebastian Hammer, Adam Dickmeiss - * - * $Log: dopen.c,v $ - * Revision 1.5 1997-09-17 12:19:07 adam - * Zebra version corresponds to YAZ version 1.4. - * Changed Zebra server so that it doesn't depend on global common_resource. - * - * Revision 1.4 1997/09/09 13:38:01 adam - * Partial port to WIN95/NT. - * - * Revision 1.3 1994/09/01 17:49:37 adam - * Removed stupid line. Work on insertion in dictionary. Not finished yet. - * - */ +/* This file is part of the Zebra server. + Copyright (C) 1994-2011 Index Data + +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 this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + +*/ + + +#if HAVE_CONFIG_H +#include +#endif #include #include -#ifndef WINDOWS +#if HAVE_UNISTD_H #include #endif #include #include -#include +#include "dict-p.h" -static void common_init (Dict_BFile bf, int block_size, int cache) +static void common_init(Dict_BFile bf, int block_size, int cache) { int i; bf->block_size = block_size; + bf->compact_flag = 0; bf->cache = cache; bf->hash_size = 31; bf->hits = bf->misses = 0; /* Allocate all blocks in one chunk. */ - bf->all_data = xmalloc (block_size * cache); + bf->all_data = xmalloc(block_size * cache); /* Allocate and initialize hash array (as empty) */ - bf->hash_array = xmalloc(sizeof(*bf->hash_array) * bf->hash_size); + bf->hash_array = (struct Dict_file_block **) + xmalloc(sizeof(*bf->hash_array) * bf->hash_size); for (i=bf->hash_size; --i >= 0; ) bf->hash_array[i] = NULL; /* Allocate all block descriptors in one chunk */ - bf->all_blocks = xmalloc (sizeof(*bf->all_blocks) * cache); + bf->all_blocks = (struct Dict_file_block *) + xmalloc(sizeof(*bf->all_blocks) * cache); /* Initialize the free list */ bf->free_list = bf->all_blocks; @@ -63,15 +72,32 @@ static void common_init (Dict_BFile bf, int block_size, int cache) } -Dict_BFile dict_bf_open (BFiles bfs, const char *name, int block_size, - int cache, int rw) +Dict_BFile dict_bf_open(BFiles bfs, const char *name, int block_size, + int cache, int rw) { Dict_BFile dbf; - - dbf = xmalloc (sizeof(*dbf)); - dbf->bf = bf_open (bfs, name, block_size, rw); + + dbf = (Dict_BFile) xmalloc(sizeof(*dbf)); + dbf->bf = bf_open(bfs, name, block_size, rw); if (!dbf->bf) - return NULL; - common_init (dbf, block_size, cache); + { + xfree(dbf); + return 0; + } + common_init(dbf, block_size, cache); return dbf; } + +void dict_bf_compact(Dict_BFile dbf) +{ + dbf->compact_flag = 1; +} +/* + * Local variables: + * c-basic-offset: 4 + * c-file-style: "Stroustrup" + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +