X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=t%2Flib%2FVPIT%2FTestHelpers.pm;h=b8623c536b65a652df5b5d01fdb6e980f95e6ee5;hb=0781a118e6641a87b17bb1a846c8f7d93d6bfa1c;hp=69424208854ff243a950e847f0ac921508733536;hpb=1958b3c51f5a5e55822bc1ce12487535a59e12f8;p=perl%2Fmodules%2FScope-Upper.git diff --git a/t/lib/VPIT/TestHelpers.pm b/t/lib/VPIT/TestHelpers.pm index 6942420..b8623c5 100644 --- a/t/lib/VPIT/TestHelpers.pm +++ b/t/lib/VPIT/TestHelpers.pm @@ -144,6 +144,10 @@ sub load_or_skip_all { sub run_perl { my $code = shift; + if ($code =~ /"/) { + die 'Double quotes in evaluated code are not portable'; + } + my ($SystemRoot, $PATH) = @ENV{qw}; my $ld_name = $Config::Config{ldlibpthname}; my $ldlibpth = $ENV{$ld_name}; @@ -153,7 +157,15 @@ sub run_perl { $ENV{SystemRoot} = $SystemRoot if $^O eq 'MSWin32' and defined $SystemRoot; $ENV{PATH} = $PATH if $^O eq 'cygwin' and defined $PATH; - system { $^X } $^X, '-T', map("-I$_", @INC), '-e', $code; + my $perl = $^X; + unless (-e $perl and -x $perl) { + $perl = $Config::Config{perlpath}; + unless (-e $perl and -x $perl) { + return undef; + } + } + + system { $perl } $perl, '-T', map("-I$_", @INC), '-e', $code; } sub init_threads {