Workaround RT #57144, caused by Perl_call_sv()'s bug
Fuji, Goro [Fri, 7 May 2010 05:25:08 +0000 (14:25 +0900)]
t/900_mouse_bugs/009_RT57144.t
xs-src/MouseUtil.xs

index d2660aa..ede5e1d 100644 (file)
@@ -35,11 +35,7 @@ package main;
 use strict;
 use warnings;
 
-pass 'The problem remains ...';
-
-if(0) {
-    my $hoge = Hoge->new;
-    is $hoge->msg, "HOGE";
-}
+my $hoge = Hoge->new;
+is $hoge->msg, "HOGE";
 
 done_testing;
index 5b01e40..e562748 100644 (file)
@@ -123,12 +123,13 @@ mouse_throw_error(SV* const metaobject, SV* const data /* not used */, const cha
 /* workaround RT #69939 */
 I32
 mouse_call_sv_safe(pTHX_ SV* const sv, I32 const flags) {
+    const PERL_CONTEXT* const cx = &cxstack[cxstack_ix];
     assert( (flags & G_EVAL) == 0 );
-
-    if(!PL_in_eval) {
+    //warn("%d 0x%x 0x%x", (int)cx->cx_type, (int)cx->cx_type, (int)PL_in_eval);
+    if(!(cx->cx_type & (CXt_EVAL|CXp_TRYBLOCK))) {
         I32 count;
-        SAVESPTR(ERRSV);
-        ERRSV = sv_newmortal();
+        //SAVESPTR(ERRSV);
+        //ERRSV = sv_newmortal();
 
         count = Perl_call_sv(aTHX_ sv, flags | G_EVAL);