36 additional tests for B
[p5sagit/p5-mst-13.2.git] / ext / GDBM_File / typemap
index a6b0e5f..8c7cb45 100644 (file)
@@ -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);