tdb2: unify tdb1_traverse into tdb_traverse
[ccan] / ccan / jmap / jmap.c
1 /* Licensed under LGPLv2.1+ - see LICENSE file for details */
2 #include <ccan/jmap/jmap.h>
3 #include <ccan/build_assert/build_assert.h>
4 #include <stdlib.h>
5 #include <string.h>
6
7 struct jmap *jmap_new(void)
8 {
9         struct jmap *map;
10
11         /* Judy uses unsigned long for Word_t, we use unsigned long. */
12         BUILD_ASSERT(sizeof(Word_t) == sizeof(unsigned long));
13         /* We also put pointers into Judy, in jmap_types.h */
14         BUILD_ASSERT(sizeof(Word_t) >= sizeof(void *));
15
16         map = malloc(sizeof(*map));
17         if (map) {
18                 map->judy = NULL;
19                 memset(&map->err, 0, sizeof(map->err));
20                 map->errstr = NULL;
21                 map->num_accesses = 0;
22                 map->acc_value = NULL;
23                 map->acc_index = 0;
24                 map->funcname = NULL;
25         }
26         return map;
27 }
28
29 const char *jmap_error_(struct jmap *map)
30 {
31         char *str;
32         free((char *)map->errstr);
33         map->errstr = str = malloc(100);
34         if (!map->errstr)
35                 return "out of memory";
36
37         sprintf(str,
38                 "JU_ERRNO_* == %d, ID == %d\n",
39                 JU_ERRNO(&map->err), JU_ERRID(&map->err));
40         return str;
41 }
42
43 void jmap_free(const struct jmap *map)
44 {
45         free((char *)map->errstr);
46         JudyLFreeArray((PPvoid_t)&map->judy, PJE0);
47         free((void *)map);
48 }