X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dict%2Fdopen.c;h=ecd742f5caaef65e25e316136fa074390ef2ac59;hb=83533000f9456dcab2fc171abafd84d6104d4087;hp=9883be30aed57348277c7b8125683860b530a6fd;hpb=3c5f6226f97612c0d6ac40591f600587c5ffa858;p=idzebra-moved-to-github.git diff --git a/dict/dopen.c b/dict/dopen.c index 9883be3..ecd742f 100644 --- a/dict/dopen.c +++ b/dict/dopen.c @@ -4,7 +4,13 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: dopen.c,v $ - * Revision 1.6 1999-02-02 14:50:20 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 @@ -34,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; @@ -43,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; @@ -71,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; +}