X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=dict%2Fopen.c;h=39c3a828abe385a2e96641749764d0a602ba4939;hb=3eb26862c3e82f9332c75c9c560f1044f80bc778;hp=e20f2f56d70d85e50208704ba5797ee1870575c7;hpb=b879b04a092d5b00cc866cf16f755e55053d2e89;p=idzebra-moved-to-github.git diff --git a/dict/open.c b/dict/open.c index e20f2f5..39c3a82 100644 --- a/dict/open.c +++ b/dict/open.c @@ -4,7 +4,18 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: open.c,v $ - * Revision 1.7 1995-09-04 12:33:32 adam + * Revision 1.10 1996-05-24 14:46:04 adam + * Added dict_grep_cmap function to define user-mapping in grep lookups. + * + * Revision 1.9 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.8 1995/12/07 11:48:56 adam + * Insert operation obeys DICT_type = 1 (slack in page). + * Function dict_open exists if page size or magic aren't right. + * + * Revision 1.7 1995/09/04 12:33:32 adam * Various cleanup. YAZ util used instead. * * Revision 1.6 1994/10/05 12:16:52 adam @@ -45,13 +56,14 @@ Dict dict_open (const char *name, int cache, int rw) sprintf (resource_str, "dict.%s.pagesize", name); + dict->grep_cmap = NULL; page_size = atoi (res_get_def (common_resource, resource_str, DICT_DEFAULT_PAGESIZE)); - if (page_size < 1024) + if (page_size < 2048) { - logf (LOG_WARN, "Resource %s was too small. Set to 1024", + logf (LOG_WARN, "Resource %s was too small. Set to 2048", resource_str); - page_size = 1024; + page_size = 2048; } dict->dbf = dict_bf_open (name, page_size, cache, rw); dict->rw = rw; @@ -85,17 +97,13 @@ Dict dict_open (const char *name, int cache, int rw) if (strcmp (dh->magic_str, DICT_MAGIC)) { logf (LOG_WARN, "Bad magic of `%s'", name); - dict_bf_close (dict->dbf); - xfree (dict); - return NULL; + exit (1); } if (dh->page_size != page_size) { logf (LOG_WARN, "Resource %s is %d and pagesize of `%s' is %d", resource_str, page_size, name, dh->page_size); - dict_bf_close (dict->dbf); - xfree (dict); - return NULL; + exit (1); } memcpy (&dict->head, dh, sizeof(*dh)); } @@ -104,10 +112,10 @@ Dict dict_open (const char *name, int cache, int rw) int dict_strcmp (const Dict_char *s1, const Dict_char *s2) { - return strcmp (s1, s2); + return strcmp ((const char *) s1, (const char *) s2); } int dict_strlen (const Dict_char *s) { - return strlen(s); + return strlen((const char *) s); }