X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dict%2Fdopen.c;h=ecd742f5caaef65e25e316136fa074390ef2ac59;hb=e5ebc859654d84aa9098142b34015648d8e333de;hp=1f1fda3d1a65633a483d74def133507765c518c1;hpb=b9093505b17a074e79137ed64595c8269f77d330;p=idzebra-moved-to-github.git diff --git a/dict/dopen.c b/dict/dopen.c index 1f1fda3..ecd742f 100644 --- a/dict/dopen.c +++ b/dict/dopen.c @@ -1,10 +1,19 @@ /* - * Copyright (C) 1994, Index Data I/S + * Copyright (C) 1994-1999, Index Data * All rights reserved. * Sebastian Hammer, Adam Dickmeiss * * $Log: dopen.c,v $ - * Revision 1.5 1997-09-17 12:19:07 adam + * Revision 1.8 1999-05-26 07:49:12 adam + * C++ compilation. + * + * Revision 1.7 1999/05/15 14:36:37 adam + * Updated dictionary. Implemented "compression" of dictionary. + * + * Revision 1.6 1999/02/02 14:50:20 adam + * Updated WIN32 code specific sections. Changed header. + * + * 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. * @@ -18,7 +27,7 @@ #include #include -#ifndef WINDOWS +#ifndef WIN32 #include #endif #include @@ -31,6 +40,7 @@ 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; @@ -40,12 +50,14 @@ static void common_init (Dict_BFile bf, int block_size, int 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; @@ -68,10 +80,15 @@ Dict_BFile dict_bf_open (BFiles bfs, const char *name, int block_size, { Dict_BFile dbf; - dbf = xmalloc (sizeof(*dbf)); + 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); return dbf; } + +void dict_bf_compact (Dict_BFile dbf) +{ + dbf->compact_flag = 1; +}