X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=ext%2FGDBM_File%2Ftypemap;h=8c7cb45b462353afb00564f93116972f9aed79eb;hb=01b509b0993b5dd659665407a96cb80ea8da0cab;hp=a6b0e5faa869133697a21857703745fa72d7d8d4;hpb=a0d0e21ea6ea90a22318550944fe6cb09ae10cda;p=p5sagit%2Fp5-mst-13.2.git diff --git a/ext/GDBM_File/typemap b/ext/GDBM_File/typemap index a6b0e5f..8c7cb45 100644 --- a/ext/GDBM_File/typemap +++ b/ext/GDBM_File/typemap @@ -2,8 +2,9 @@ #################################### DBM SECTION # -datum T_DATUM -gdatum T_GDATUM +datum_key T_DATUM_K +datum_key_copy T_DATUM_K +datum_value T_DATUM_V NDBM_File T_PTROBJ GDBM_File T_PTROBJ SDBM_File T_PTROBJ @@ -13,13 +14,38 @@ DBZ_File T_PTROBJ FATALFUNC T_OPAQUEPTR INPUT -T_DATUM - $var.dptr = SvPV($arg, na); - $var.dsize = (int)na; -T_GDATUM - UNIMPLEMENTED +T_DATUM_K + DBM_ckFilter($arg, filter_store_key, \"filter_store_key\"); + $var.dptr = SvPVbyte($arg, PL_na); + $var.dsize = (int)PL_na; +T_DATUM_K_C + { + SV * tmpSV; + if (db->filter_store_key) { + tmpSV = sv_2mortal(newSVsv($arg)); + DBM_ckFilter(tmpSV, filter_store_key, \"filter_store_key\"); + } + else + tmpSV = $arg; + $var.dptr = SvPVbyte(tmpSV, PL_na); + $var.dsize = (int)PL_na; + } +T_DATUM_V + DBM_ckFilter($arg, filter_store_value, \"filter_store_value\"); + if (SvOK($arg)) { + $var.dptr = SvPVbyte($arg, PL_na); + $var.dsize = (int)PL_na; + } + else { + $var.dptr = \"\"; + $var.dsize = 0; + } OUTPUT -T_DATUM - sv_setpvn($arg, $var.dptr, $var.dsize); -T_GDATUM - sv_usepvn($arg, $var.dptr, $var.dsize); +T_DATUM_K + output_datum(aTHX_ $arg, $var.dptr, $var.dsize); + DBM_ckFilter($arg, filter_fetch_key,\"filter_fetch_key\"); +T_DATUM_V + output_datum(aTHX_ $arg, $var.dptr, $var.dsize); + DBM_ckFilter($arg, filter_fetch_value,\"filter_fetch_value\"); +T_PTROBJ + sv_setref_pv($arg, dbtype, (void*)$var);