Add the fruits of Larry Shatzer's version verifying script.
[p5sagit/p5-mst-13.2.git] / lib / ExtUtils / Embed.t
index 08c7cab..8f4380a 100644 (file)
@@ -17,17 +17,39 @@ print "1..9\n";
 my $cc = $Config{'cc'};
 my $cl  = ($^O eq 'MSWin32' && $cc eq 'cl');
 my $exe = 'embed_test' . $Config{'exe_ext'};
+my $obj = 'embed_test' . $Config{'obj_ext'} if $^O eq 'VMS';
 my $inc = File::Spec->catdir($INC[0],"..");
 my $lib = File::Spec->catdir($INC[0],"..");
 my @cmd;
-if ($cl) {
+my (@cmd2) if $^O eq 'VMS';
+
+if ($^O eq 'VMS') {
+    push(@cmd,$cc,"/Obj=$obj");
+    my (@incs) = ($inc);
+    my $crazy = ccopts();
+    if ($crazy =~ s#/inc[^=/]*=([\w\$\_\-\.\[\]\:]+)##i) {
+        push(@incs,$1);
+    }
+    if ($crazy =~ s/-I([a-zA-Z0-9\$\_\-\.\[\]\:]*)//) {
+        push(@incs,$1);
+    }
+    $crazy =~ s#/Obj[^=/]*=[\w\$\_\-\.\[\]\:]+##i;
+    push(@cmd,"/Include=(".join(',',@incs).")");
+    push(@cmd,$crazy);
+    push(@cmd,"embed_test.c");
+
+    push(@cmd2,$Config{'ld'}, $Config{'ldflags'}, "/exe=$exe"); 
+    push(@cmd2,"$obj,[-]perlshr.opt/opt,[-]perlshr_attr.opt/opt");
+
+} else {
+   if ($cl) {
     push(@cmd,$cc,"-Fe$exe");
-}
-else {
+   }
+   else {
     push(@cmd,$cc,'-o' => $exe);
-}
-push(@cmd,"-I$inc",ccopts(),'embed_test.c');
-if ($^O eq 'MSWin32') {
+   }
+   push(@cmd,"-I$inc",ccopts(),'embed_test.c');
+   if ($^O eq 'MSWin32') {
     $inc = File::Spec->catdir($inc,'win32');
     push(@cmd,"-I$inc");
     $inc = File::Spec->catdir($inc,'include');
@@ -38,22 +60,43 @@ if ($^O eq 'MSWin32') {
     else {
        push(@cmd,"-L$lib",File::Spec->catfile($lib,$Config{'libperl'}),$Config{'libc'});
     }
-}
-else {
+   }
+   else {
     push(@cmd,"-L$lib",'-lperl');
+   }
+   {
+    local $SIG{__WARN__} = sub {
+       warn $_[0] unless $_[0] =~ /No library found for -lperl/
+    };
+    push(@cmd,ldopts());
+   }
+
+   if ($^O eq 'aix') { # AIX needs an explicit symbol export list.
+    my ($perl_exp) = grep { -f } qw(perl.exp ../perl.exp);
+    die "where is perl.exp?\n" unless defined $perl_exp;
+    for (@cmd) {
+        s!-bE:(\S+)!-bE:$perl_exp!;
+    }
+   }
 }
-push(@cmd,ldopts());
-
-print "# @cmd"; # where is the newline coming from? ldopts()?
-print "not " if system(join(' ',@cmd));
-print "ok 1\n";
+my $status;
+my $display_cmd = "@cmd";
+chomp($display_cmd); # where is the newline coming from? ldopts()?
+print "# $display_cmd\n"; 
+$status = system(join(' ',@cmd));
+if ($^O eq 'VMS' && !$status) {
+  print "# @cmd2\n";
+  $status = system(join(' ',@cmd2)); 
+}
+print (($status? 'not ': '')."ok 1\n");
 
 my $embed_test = File::Spec->catfile(File::Spec->curdir, "embed_test");
+$embed_test = "run/nodebug $exe" if $^O eq 'VMS';
 
-print "not " if system($embed_test);
-print "ok 9\n";
-
+$status = system($embed_test);
+print (($status? 'not ':'')."ok 9\n");
 unlink($exe,"embed_test.c");
+unlink($obj,"embed_test.map","embed_test.lis") if $^O eq 'VMS'
 
 # gcc -g -I.. -L../ -o perl_test perl_test.c -lperl `../perl -I../lib -MExtUtils::Embed -I../ -e ccopts -e ldopts`