Use log_mask_str now.
[idzebra-moved-to-github.git] / dict / open.c
index 8068454..e5319b3 100644 (file)
@@ -4,7 +4,16 @@
  * Sebastian Hammer, Adam Dickmeiss
  *
  * $Log: open.c,v $
- * Revision 1.2  1994-08-17 13:32:20  adam
+ * Revision 1.5  1994-09-01 17:49:39  adam
+ * Removed stupid line. Work on insertion in dictionary. Not finished yet.
+ *
+ * Revision 1.4  1994/09/01  17:44:10  adam
+ * depend include change.
+ *
+ * Revision 1.3  1994/08/18  12:40:58  adam
+ * Some development of dictionary. Not finished at all!
+ *
+ * Revision 1.2  1994/08/17  13:32:20  adam
  * Use cache in dict - not in bfile.
  *
  * Revision 1.1  1994/08/16  16:26:49  adam
@@ -12,7 +21,6 @@
  *
  */
 
-
 #include <stdlib.h>
 #include <string.h>
 #include <stdio.h>
@@ -28,10 +36,12 @@ Dict dict_open (const char *name, int cache, int rw)
     dict = xmalloc (sizeof(*dict));
 
     dict->dbf = dict_bf_open (name, DICT_PAGESIZE, cache, rw);
+    dict->rw = rw;
 
     if(!dict->dbf)
     {
-        free (dict);
+        log (LOG_LOG, "cannot open `%s'", name);
+        xfree (dict);
         return NULL;
     }
     if (dict_bf_readp (dict->dbf, 0, &head_buf) <= 0)
@@ -54,16 +64,18 @@ Dict dict_open (const char *name, int cache, int rw)
     else /* header was there, check magic and page size */
     {
         dh = (struct Dict_head *) head_buf;
-        if (!strcmp (dh->magic_str, DICT_MAGIC))
+        if (strcmp (dh->magic_str, DICT_MAGIC))
         {
+            log (LOG_LOG, "bad magic of `%s'", name);
             dict_bf_close (dict->dbf);
-            free (dict);
+            xfree (dict);
             return NULL;
         }
         if (dh->page_size != DICT_PAGESIZE)
         {
+            log (LOG_LOG, "page size mismatch of `%s'", name);
             dict_bf_close (dict->dbf);
-            free (dict);
+            xfree (dict);
             return NULL;
         }
         memcpy (&dict->head, dh, sizeof(*dh));
@@ -78,5 +90,5 @@ int dict_strcmp (const Dict_char *s1, const Dict_char *s2)
 
 int dict_strlen (const Dict_char *s)
 {
-    return strlen(s)+1;
+    return strlen(s);
 }