mirror of https://github.com/openssl/openssl.git
				
				
				
			
		
			
				
	
	
		
			126 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Perl
		
	
	
	
| #! {- $config{HASHBANGPERL} -}
 | |
| 
 | |
| use strict;
 | |
| use warnings;
 | |
| 
 | |
| use File::Basename;
 | |
| use File::Spec::Functions;
 | |
| 
 | |
| BEGIN {
 | |
|     # This method corresponds exactly to 'use OpenSSL::Util',
 | |
|     # but allows us to use a platform specific file spec.
 | |
|     require {-
 | |
|          use Cwd qw(abs_path);
 | |
| 
 | |
|          "'" . abs_path(catfile($config{sourcedir},
 | |
|                                 'util', 'perl', 'OpenSSL', 'Util.pm')) . "'";
 | |
|          -};
 | |
|     OpenSSL::Util->import();
 | |
| }
 | |
| 
 | |
| my $there = canonpath(catdir(dirname($0), updir()));
 | |
| my $std_engines = catdir($there, 'engines');
 | |
| my $std_providers = catdir($there, 'providers');
 | |
| my $std_openssl_conf = catdir($there, 'apps/openssl.cnf');
 | |
| my $unix_shlib_wrap = catfile($there, 'util/shlib_wrap.sh');
 | |
| my $std_openssl_conf_include;
 | |
| 
 | |
| if ($ARGV[0] eq '-fips') {
 | |
|     $std_openssl_conf = {-
 | |
|          use Cwd qw(abs_path);
 | |
| 
 | |
|          "'" . abs_path(catfile($config{sourcedir}, 'test/fips-and-base.cnf')) . "'";
 | |
|          -};
 | |
|     shift;
 | |
| 
 | |
|     $std_openssl_conf_include = catdir($there, 'providers');
 | |
| }
 | |
| 
 | |
| if ($ARGV[0] eq '-jitter') {
 | |
|     $std_openssl_conf = {-
 | |
|          use Cwd qw(abs_path);
 | |
| 
 | |
|          "'" . abs_path(catfile($config{sourcedir}, 'test/default-and-jitter.cnf')) . "'";
 | |
|          -};
 | |
|     shift;
 | |
| 
 | |
|     $std_openssl_conf_include = catdir($there, 'providers');
 | |
| }
 | |
| 
 | |
| 
 | |
| local $ENV{OPENSSL_CONF_INCLUDE} = $std_openssl_conf_include
 | |
|     if defined $std_openssl_conf_include
 | |
|        &&($ENV{OPENSSL_CONF_INCLUDE} // '') eq ''
 | |
|        && -d $std_openssl_conf_include;
 | |
| local $ENV{OPENSSL_ENGINES} = $std_engines
 | |
|     if ($ENV{OPENSSL_ENGINES} // '') eq '' && -d $std_engines;
 | |
| local $ENV{OPENSSL_MODULES} = $std_providers
 | |
|     if ($ENV{OPENSSL_MODULES} // '') eq '' && -d $std_providers;
 | |
| local $ENV{OPENSSL_CONF} = $std_openssl_conf
 | |
|     if ($ENV{OPENSSL_CONF} // '') eq '' && -f $std_openssl_conf;
 | |
| {-
 | |
|      # For VMS, we define logical names to get the libraries properly
 | |
|      # defined.
 | |
|      use File::Spec::Functions qw(rel2abs);
 | |
| 
 | |
|      if ($^O eq "VMS") {
 | |
|          my $bldtop = rel2abs($config{builddir});
 | |
|          my %names =
 | |
|              map { platform->sharedname($_) => $bldtop.platform->sharedlib($_) }
 | |
|              grep { !$unified_info{attributes}->{libraries}->{$_}->{noinst} }
 | |
|              @{$unified_info{libraries}};
 | |
| 
 | |
|          foreach (sort keys %names) {
 | |
|              $OUT .= "local \$ENV\{'$_'\} = '$names{$_}';\n";
 | |
|          }
 | |
|      }
 | |
| -}
 | |
| my $use_system = 0;
 | |
| my @cmd;
 | |
| 
 | |
| if ($^O eq 'VMS') {
 | |
|     # VMS needs the command to be appropriately quotified
 | |
|     @cmd = fixup_cmd(@ARGV);
 | |
| } elsif (-x $unix_shlib_wrap) {
 | |
|     @cmd = ( $unix_shlib_wrap, @ARGV );
 | |
| } else {
 | |
|     # Hope for the best
 | |
|     @cmd = ( @ARGV );
 | |
| }
 | |
| 
 | |
| # The exec() statement on MSWin32 doesn't seem to give back the exit code
 | |
| # from the call, so we resort to using system() instead.
 | |
| my $waitcode = system @cmd;
 | |
| 
 | |
| # According to documentation, -1 means that system() couldn't run the command,
 | |
| # otherwise, the value is similar to the Unix wait() status value
 | |
| # (exitcode << 8 | signalcode)
 | |
| die "wrap.pl: Failed to execute '", join(' ', @cmd), "': $!\n"
 | |
|     if $waitcode == -1;
 | |
| 
 | |
| # When the subprocess aborted on a signal, we simply raise the same signal.
 | |
| kill(($? & 255) => $$) if ($? & 255) != 0;
 | |
| 
 | |
| # If that didn't stop this script, mimic what Unix shells do, by
 | |
| # converting the signal code to an exit code by setting the high bit.
 | |
| # This only happens on Unix flavored operating systems, the others don't
 | |
| # have this sort of signaling to date, and simply leave the low byte zero.
 | |
| exit(($? & 255) | 128) if ($? & 255) != 0;
 | |
| 
 | |
| # When not a signal, just shift down the subprocess exit code and use that.
 | |
| my $exitcode = $? >> 8;
 | |
| 
 | |
| # For VMS, perl recommendations is to emulate what the C library exit() does
 | |
| # for all non-zero exit codes, except we set the error severity rather than
 | |
| # success.
 | |
| # Ref: https://perldoc.perl.org/perlport#exit
 | |
| #      https://perldoc.perl.org/perlvms#$?
 | |
| if ($^O eq 'VMS' && $exitcode != 0) {
 | |
|     $exitcode =
 | |
|         0x35a000                # C facility code
 | |
|         + ($exitcode * 8)       # shift up to make space for the 3 severity bits
 | |
|         + 2                     # Severity: E(rror)
 | |
|         + 0x10000000;           # bit 28 set => the shell stays silent
 | |
| }
 | |
| exit($exitcode);
 |