Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
PATCH: read-write gdbm elements
- X-seq: zsh-workers 25320
- From: Clint Adams <clint@xxxxxxx>
- To: zsh-workers@xxxxxxxxxx
- Subject: PATCH: read-write gdbm elements
- Date: Mon, 21 Jul 2008 01:44:12 +0000
- In-reply-to: <20080721005152.GA21796@xxxxxxxx>
- Mail-followup-to: zsh-workers@xxxxxxxxxx
- Mailing-list: contact zsh-workers-help@xxxxxxxxxx; run by ezmlm
- References: <20080721001634.GA20601@xxxxxxxx> <20080721005152.GA21796@xxxxxxxx>
ztie -d db/gdbm -f /tmp/newfile.db hokeypokey
hokeypokey[horse]=buggy
hokeypokey[apple]=pie
print -l -- ${hokeypokey}
print ${hokeypokey[horse]}
print ${hokeypokey[apple]}
diff --git a/Src/Modules/db_gdbm.c b/Src/Modules/db_gdbm.c
index f0915e0..d8f6724 100644
--- a/Src/Modules/db_gdbm.c
+++ b/Src/Modules/db_gdbm.c
@@ -39,7 +39,7 @@
#include <gdbm.h>
-static const struct gsu_hash gdbm_gsu =
+static const struct gsu_scalar gdbm_gsu =
{ gdbmgetfn, gdbmsetfn, gdbmunsetfn };
static struct builtin bintab[] = {
@@ -105,26 +105,47 @@ bin_zuntie(char *nam, char **args, Options ops, UNUSED(int func))
return 0;
}
-
/**/
static char *
gdbmgetfn(Param pm)
{
-return;
+ datum key, content;
+ int ret;
+
+ key.dptr = pm->node.nam;
+ key.dsize = strlen(key.dptr) + 1;
+
+ ret = gdbm_exists(dbf, key);
+ if(ret) {
+ content = gdbm_fetch(dbf, key);
+ } else {
+ content.dptr = dupstring("");
+ }
+
+ return content.dptr;
}
/**/
static void
-gdbmsetfn(Param pm, char **key)
+gdbmsetfn(Param pm, char **val)
{
-return;
+ datum key, content;
+ int ret;
+
+
+ key.dptr = pm->node.nam;
+ key.dsize = strlen(key.dptr) + 1;
+ content.dptr = val;
+ content.dsize = strlen(content.dptr) + 1;
+
+ ret = gdbm_store(dbf, key, content, GDBM_REPLACE);
}
/**/
static void
gdbmunsetfn(Param pm, int um)
{
-return;
+
}
/**/
@@ -143,17 +164,8 @@ getgdbmnode(UNUSED(HashTable ht), const char *name)
pm = (Param) hcalloc(sizeof(struct param));
pm->node.nam = nameu;
pm->node.flags = PM_SCALAR;
+ pm->gsu.s = &gdbm_gsu;
- ret = gdbm_exists(dbf, key);
- if(!ret) {
- pm->u.str = dupstring("");
- pm->node.flags |= PM_UNSET;
- } else {
- content = gdbm_fetch(dbf, key);
-
- pm->u.str = content.dptr;
- pm->gsu.s = &nullsetscalar_gsu;
- }
return &pm->node;
}
Messages sorted by:
Reverse Date,
Date,
Thread,
Author