9 # include <rpcsvc/dbm.h>
13 #ifndef HAS_DBMINIT_PROTO
14 int dbminit(char* filename);
16 datum fetch(datum key);
17 int store(datum key, datum dat);
18 int delete(datum key);
20 datum nextkey(datum key);
23 #ifdef DBM_BUG_DUPLICATE_FREE
25 * DBM on at least Ultrix and HPUX call dbmclose() from dbminit(),
26 * resulting in duplicate free() because dbmclose() does *not*
27 * check if it has already been called for this DBM.
28 * If some malloc/free calls have been done between dbmclose() and
29 * the next dbminit(), the memory might be used for something else when
31 * Verified to work on ultrix4.3. Probably will work on HP/UX.
32 * Set DBM_BUG_DUPLICATE_FREE in the extension hint file.
34 /* Close the previous dbm, and fail to open a new dbm */
35 #define dbmclose() ((void) dbminit("/non/exist/ent"))
51 typedef ODBM_File_type * ODBM_File ;
52 typedef datum datum_key ;
53 typedef datum datum_key_copy ;
54 typedef datum datum_value ;
56 #define odbm_FETCH(db,key) fetch(key)
57 #define odbm_STORE(db,key,value,flags) store(key,value)
58 #define odbm_DELETE(db,key) delete(key)
59 #define odbm_FIRSTKEY(db) firstkey()
60 #define odbm_NEXTKEY(db,key) nextkey(key)
62 #define MY_CXT_KEY "ODBM_File::_guts" XS_VERSION
70 #define dbmrefcnt (MY_CXT.x_dbmrefcnt)
76 MODULE = ODBM_File PACKAGE = ODBM_File PREFIX = odbm_
84 odbm_TIEHASH(dbtype, filename, flags, mode)
96 croak("Old dbm can only open one database");
97 Newx(tmpbuf, strlen(filename) + 5, char);
99 sprintf(tmpbuf,"%s.dir",filename);
100 if (stat(tmpbuf, &PL_statbuf) < 0) {
101 if (flags & O_CREAT) {
102 if (mode < 0 || close(creat(tmpbuf,mode)) < 0)
103 croak("ODBM_File: Can't create %s", filename);
104 sprintf(tmpbuf,"%s.pag",filename);
105 if (close(creat(tmpbuf,mode)) < 0)
106 croak("ODBM_File: Can't create %s", filename);
109 croak("ODBM_FILE: Can't open %s", filename);
111 dbp = (void*)(dbminit(filename) >= 0 ? &dbmrefcnt : 0);
112 RETVAL = (ODBM_File)safecalloc(1, sizeof(ODBM_File_type));
114 ST(0) = sv_mortalcopy(&PL_sv_undef);
115 sv_setptrobj(ST(0), RETVAL, dbtype);
129 SvREFCNT_dec(db->filter[i]);
139 odbm_STORE(db, key, value, flags = DBM_REPLACE)
146 if (RETVAL < 0 && errno == EPERM)
147 croak("No write permission to odbm file");
148 croak("odbm store returned %d, errno %d, key \"%s\"",
149 RETVAL,errno,key.dptr);
162 odbm_NEXTKEY(db, key)
167 #define setFilter(type) \
170 RETVAL = sv_mortalcopy(db->type) ; \
172 if (db->type && (code == &PL_sv_undef)) { \
173 SvREFCNT_dec(db->type) ; \
174 db->type = Nullsv ; \
178 sv_setsv(db->type, code) ; \
180 db->type = newSVsv(code) ; \
187 filter_fetch_key(db, code)
190 SV * RETVAL = &PL_sv_undef ;
192 ODBM_File::filter_fetch_key = fetch_key
193 ODBM_File::filter_store_key = store_key
194 ODBM_File::filter_fetch_value = fetch_value
195 ODBM_File::filter_store_value = store_value
197 DBM_setFilter(db->filter[ix], code);