diff options
author | Paul Marquess <paul.marquess@btinternet.com> | 2002-08-21 12:40:49 +0100 |
---|---|---|
committer | hv <hv@crypt.org> | 2002-08-22 10:46:19 +0000 |
commit | 6a31061a02dec2e4339d611e71c8a3daf8c83f4a (patch) | |
tree | 27d4275ae21c6c7916186e4bd68a41cbfdd2f034 /ext/GDBM_File | |
parent | 3a131abc79a92fd4e158b68f3a4bf7df5b8edc88 (diff) | |
download | perl-6a31061a02dec2e4339d611e71c8a3daf8c83f4a.tar.gz |
Fix DBM filters
From: "Paul Marquess" <Paul.Marquess@btinternet.com>
Message-ID: <AIEAJICLCBDNAAOLLOKLAEHCFEAA.Paul.Marquess@btinternet.com>
p4raw-id: //depot/perl@17750
Diffstat (limited to 'ext/GDBM_File')
-rw-r--r-- | ext/GDBM_File/GDBM_File.xs | 47 | ||||
-rwxr-xr-x | ext/GDBM_File/gdbm.t | 45 | ||||
-rw-r--r-- | ext/GDBM_File/typemap | 10 |
3 files changed, 53 insertions, 49 deletions
diff --git a/ext/GDBM_File/GDBM_File.xs b/ext/GDBM_File/GDBM_File.xs index 5684a968e0..22350fd692 100644 --- a/ext/GDBM_File/GDBM_File.xs +++ b/ext/GDBM_File/GDBM_File.xs @@ -19,26 +19,6 @@ typedef datum datum_key ; typedef datum datum_value ; typedef datum datum_key_copy; -#define ckFilter(arg,type,name) \ - if (db->type) { \ - SV * save_defsv ; \ - /* printf("filtering %s\n", name) ;*/ \ - if (db->filtering) \ - croak("recursion detected in %s", name) ; \ - db->filtering = TRUE ; \ - save_defsv = newSVsv(DEFSV) ; \ - sv_setsv(DEFSV, arg) ; \ - PUSHMARK(sp) ; \ - (void) perl_call_sv(db->type, G_DISCARD|G_NOARGS); \ - sv_setsv(arg, DEFSV) ; \ - sv_setsv(DEFSV, save_defsv) ; \ - SvREFCNT_dec(save_defsv) ; \ - db->filtering = FALSE ; \ - /*printf("end of filtering %s\n", name) ;*/ \ - } - - - #define GDBM_BLOCKSIZE 0 /* gdbm defaults to stat blocksize */ typedef void (*FATALFUNC)(); @@ -183,32 +163,13 @@ gdbm_setopt (db, optflag, optval, optlen) int optlen -#define setFilter(type) \ - { \ - if (db->type) \ - RETVAL = sv_mortalcopy(db->type) ; \ - ST(0) = RETVAL ; \ - if (db->type && (code == &PL_sv_undef)) { \ - SvREFCNT_dec(db->type) ; \ - db->type = NULL ; \ - } \ - else if (code) { \ - if (db->type) \ - sv_setsv(db->type, code) ; \ - else \ - db->type = newSVsv(code) ; \ - } \ - } - - - SV * filter_fetch_key(db, code) GDBM_File db SV * code SV * RETVAL = &PL_sv_undef ; CODE: - setFilter(filter_fetch_key) ; + DBM_setFilter(db->filter_fetch_key, code) ; SV * filter_store_key(db, code) @@ -216,7 +177,7 @@ filter_store_key(db, code) SV * code SV * RETVAL = &PL_sv_undef ; CODE: - setFilter(filter_store_key) ; + DBM_setFilter(db->filter_store_key, code) ; SV * filter_fetch_value(db, code) @@ -224,7 +185,7 @@ filter_fetch_value(db, code) SV * code SV * RETVAL = &PL_sv_undef ; CODE: - setFilter(filter_fetch_value) ; + DBM_setFilter(db->filter_fetch_value, code) ; SV * filter_store_value(db, code) @@ -232,5 +193,5 @@ filter_store_value(db, code) SV * code SV * RETVAL = &PL_sv_undef ; CODE: - setFilter(filter_store_value) ; + DBM_setFilter(db->filter_store_value, code) ; diff --git a/ext/GDBM_File/gdbm.t b/ext/GDBM_File/gdbm.t index 7c268936f3..87e30d086b 100755 --- a/ext/GDBM_File/gdbm.t +++ b/ext/GDBM_File/gdbm.t @@ -18,7 +18,7 @@ use warnings; use GDBM_File; -print "1..74\n"; +print "1..80\n"; unlink <Op.dbmx*>; @@ -467,4 +467,47 @@ EOM unlink <Op.dbmx*>; } +{ + # Check that DBM Filter can cope with read-only $_ + + use warnings ; + use strict ; + my %h ; + unlink <Op.dbmx*>; + + ok(75, my $db = tie(%h, 'GDBM_File','Op.dbmx', &GDBM_WRCREAT, 0640)); + + $db->filter_fetch_key (sub { }) ; + $db->filter_store_key (sub { }) ; + $db->filter_fetch_value (sub { }) ; + $db->filter_store_value (sub { }) ; + + $_ = "original" ; + + $h{"fred"} = "joe" ; + ok(76, $h{"fred"} eq "joe"); + + eval { grep { $h{$_} } (1, 2, 3) }; + ok (77, ! $@); + + + # delete the filters + $db->filter_fetch_key (undef); + $db->filter_store_key (undef); + $db->filter_fetch_value (undef); + $db->filter_store_value (undef); + + $h{"fred"} = "joe" ; + + ok(78, $h{"fred"} eq "joe"); + + ok(79, $db->FIRSTKEY() eq "fred") ; + + eval { grep { $h{$_} } (1, 2, 3) }; + ok (80, ! $@); + + undef $db ; + untie %h; + unlink <Op.dbmx*>; +} exit ; diff --git a/ext/GDBM_File/typemap b/ext/GDBM_File/typemap index 8952938ccd..048f0dd11c 100644 --- a/ext/GDBM_File/typemap +++ b/ext/GDBM_File/typemap @@ -15,7 +15,7 @@ FATALFUNC T_OPAQUEPTR INPUT T_DATUM_K - ckFilter($arg, filter_store_key, \"filter_store_key\"); + DBM_ckFilter($arg, filter_store_key, \"filter_store_key\"); $var.dptr = SvPV($arg, PL_na); $var.dsize = (int)PL_na; T_DATUM_K_C @@ -23,7 +23,7 @@ T_DATUM_K_C SV * tmpSV; if (db->filter_store_key) { tmpSV = sv_2mortal(newSVsv($arg)); - ckFilter(tmpSV, filter_store_key, \"filter_store_key\"); + DBM_ckFilter(tmpSV, filter_store_key, \"filter_store_key\"); } else tmpSV = $arg; @@ -31,7 +31,7 @@ T_DATUM_K_C $var.dsize = (int)PL_na; } T_DATUM_V - ckFilter($arg, filter_store_value, \"filter_store_value\"); + DBM_ckFilter($arg, filter_store_value, \"filter_store_value\"); if (SvOK($arg)) { $var.dptr = SvPV($arg, PL_na); $var.dsize = (int)PL_na; @@ -43,9 +43,9 @@ T_DATUM_V OUTPUT T_DATUM_K output_datum(aTHX_ $arg, $var.dptr, $var.dsize); - ckFilter($arg, filter_fetch_key,\"filter_fetch_key\"); + DBM_ckFilter($arg, filter_fetch_key,\"filter_fetch_key\"); T_DATUM_V output_datum(aTHX_ $arg, $var.dptr, $var.dsize); - ckFilter($arg, filter_fetch_value,\"filter_fetch_value\"); + DBM_ckFilter($arg, filter_fetch_value,\"filter_fetch_value\"); T_PTROBJ sv_setref_pv($arg, dbtype, (void*)$var); |