X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dict%2Fdopen.c;h=ecd742f5caaef65e25e316136fa074390ef2ac59;hb=2b33b395b50c562323ea2b0251f9b798cf5241d2;hp=8418239a5c71bdbe0e3e734546d7dafc8c573cf7;hpb=1be0464201292e60fc8dcd3b922d9c4c4ac52d41;p=idzebra-moved-to-github.git diff --git a/dict/dopen.c b/dict/dopen.c index 8418239..ecd742f 100644 --- a/dict/dopen.c +++ b/dict/dopen.c @@ -1,17 +1,35 @@ /* - * 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.3 1994-09-01 17:49:37 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. + * + * 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. * */ #include #include +#ifndef WIN32 #include +#endif #include #include @@ -22,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; @@ -31,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; @@ -54,14 +75,20 @@ static void common_init (Dict_BFile bf, int block_size, int cache) } -Dict_BFile dict_bf_open (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 (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); return dbf; } + +void dict_bf_compact (Dict_BFile dbf) +{ + dbf->compact_flag = 1; +}