5 static void fw(char *p, size_t a, size_t b, FILE *f)
18 static int kdcmp (const void *a, const void *b)
20 return (strcmp( (*(const struct kd **)a)->key,
21 (*(const struct kd **)b)->key));
24 int main(int argc, char **argv)
26 if (argc < 2) exit(1);
32 size_t keylen, datalen;
33 struct kd *kdlist, **kdarray;
36 if (dbw.Open(argv[1], "R"))
42 printf("Dumping %s:\n", argv[1]);
45 for (key=dbw.FetchFirstKeyVal(keylen, data, datalen);
46 key; key=dbw.FetchNextKeyVal(keylen, data, datalen))
48 struct kd *k=(struct kd *)malloc(sizeof(struct kd));
55 if ((k->key=(char *)malloc(keylen+1)) == 0 ||
56 (k->data=(char *)malloc(datalen+1)) == 0)
61 memcpy(k->key, key, keylen);
63 memcpy(k->data, data, datalen);
71 if ((kdarray=(struct kd **)
72 malloc( (kdcnt+1)*sizeof(struct kd *))) == 0)
80 kdarray[kdcnt++]=kdlist;
85 qsort( kdarray, kdcnt, sizeof(kdarray[0]), &kdcmp);
87 for (kdcnt=0; kdarray[kdcnt]; kdcnt++)
90 fw(kdarray[kdcnt]->key, strlen(kdarray[kdcnt]->key),
93 fw(kdarray[kdcnt]->data, strlen(kdarray[kdcnt]->data),
96 free(kdarray[kdcnt]->key);
97 free(kdarray[kdcnt]->data);
103 } else if (argc < 4 && argv[2][0] == '-')
107 if (dbw.Open(argv[1], "W"))
113 printf("Deleting %s from %s:\n", argv[2], argv[1]);
114 if (dbw.Delete(argv[2]+1, strlen(argv[2]+1)))
115 fprintf(stderr, "Not found.\n");
122 if (dbw.Open(argv[1], "R"))
129 char *val=dbw.Fetch(argv[2], strlen(argv[2]), len, 0);
133 fprintf(stderr, "%s: not found.\n", argv[2]);
136 printf("Fetching %s from %s: ", argv[2], argv[1]);
137 fw(val, len, 1, stdout);
146 if (dbw.Open(argv[1], "C"))
152 printf("Storing %s/%s into %s:\n", argv[2], argv[3], argv[1]);
153 if (dbw.Store(argv[2], strlen(argv[2]),
154 argv[3], strlen(argv[3]), "R"))