Blame util/shlib_wrap.sh.in

Packit c4476c
#!/bin/sh
Packit c4476c
{-
Packit c4476c
    use lib '.';
Packit c4476c
    use configdata;
Packit c4476c
Packit c4476c
    sub shlib {
Packit c4476c
        my $lib = shift;
Packit c4476c
        return "" if $disabled{shared};
Packit c4476c
        $lib = $unified_info{rename}->{$lib}
Packit c4476c
            if defined $unified_info{rename}->{$lib};
Packit c4476c
        $lib = $unified_info{sharednames}->{$lib}
Packit c4476c
            . ($target{shlib_variant} || "")
Packit c4476c
            . ($target{shared_extension} || ".so");
Packit c4476c
        $lib =~ s|\.\$\(SHLIB_VERSION_NUMBER\)
Packit c4476c
                 |.$config{shlib_version_number}|x;
Packit c4476c
        return $lib;
Packit c4476c
    }
Packit c4476c
    "";     # Make sure no left over string sneaks its way into the script
Packit c4476c
-}
Packit c4476c
# To test this OpenSSL version's applications against another version's
Packit c4476c
# shared libraries, simply set
Packit c4476c
#
Packit c4476c
#     OPENSSL_REGRESSION=/path/to/other/OpenSSL/build/tree
Packit c4476c
if [ -n "$OPENSSL_REGRESSION" ]; then
Packit c4476c
    shlibwrap="$OPENSSL_REGRESSION/util/shlib_wrap.sh"
Packit c4476c
    if [ -x "$shlibwrap" ]; then
Packit c4476c
        # We clear OPENSSL_REGRESSION to avoid a loop, should the shlib_wrap.sh
Packit c4476c
        # we exec also support that mechanism...
Packit c4476c
        OPENSSL_REGRESSION= exec "$shlibwrap" "$@"
Packit c4476c
    else
Packit c4476c
        if [ -f "$shlibwrap" ]; then
Packit c4476c
            echo "Not permitted to run $shlibwrap" >&2
Packit c4476c
        else
Packit c4476c
            echo "No $shlibwrap, perhaps OPENSSL_REGRESSION isn't properly set?" >&2
Packit c4476c
        fi
Packit c4476c
        exit 1
Packit c4476c
    fi
Packit c4476c
fi
Packit c4476c
Packit c4476c
[ $# -ne 0 ] || set -x		# debug mode without arguments:-)
Packit c4476c
Packit c4476c
THERE="`echo $0 | sed -e 's|[^/]*$||' 2>/dev/null`.."
Packit c4476c
[ -d "${THERE}" ] || exec "$@"	# should never happen...
Packit c4476c
Packit c4476c
LIBCRYPTOSO="${THERE}/{- shlib('libcrypto') -}"
Packit c4476c
LIBSSLSO="${THERE}/{- shlib('libssl') -}"
Packit c4476c
Packit c4476c
SYSNAME=`(uname -s) 2>/dev/null`;
Packit c4476c
case "$SYSNAME" in
Packit c4476c
SunOS|IRIX*)
Packit c4476c
	# SunOS and IRIX run-time linkers evaluate alternative
Packit c4476c
	# variables depending on target ABI...
Packit c4476c
	rld_var=LD_LIBRARY_PATH
Packit c4476c
	case "`(/usr/bin/file "$LIBCRYPTOSO") 2>/dev/null`" in
Packit c4476c
	*ELF\ 64*SPARC*|*ELF\ 64*AMD64*)
Packit c4476c
		[ -n "$LD_LIBRARY_PATH_64" ] && rld_var=LD_LIBRARY_PATH_64
Packit c4476c
		LD_PRELOAD_64="$LIBCRYPTOSO $LIBSSLSO"; export LD_PRELOAD_64
Packit c4476c
		preload_var=LD_PRELOAD_64
Packit c4476c
		;;
Packit c4476c
	*ELF\ 32*SPARC*|*ELF\ 32*80386*)
Packit c4476c
		# We only need to change LD_PRELOAD_32 and LD_LIBRARY_PATH_32
Packit c4476c
		# on a multi-arch system.  Otherwise, trust the fallbacks.
Packit c4476c
		if [ -f /lib/64/ld.so.1 ]; then
Packit c4476c
		    [ -n "$LD_LIBRARY_PATH_32" ] && rld_var=LD_LIBRARY_PATH_32
Packit c4476c
		    LD_PRELOAD_32="$LIBCRYPTOSO $LIBSSLSO"; export LD_PRELOAD_32
Packit c4476c
		    preload_var=LD_PRELOAD_32
Packit c4476c
		fi
Packit c4476c
		;;
Packit c4476c
	# Why are newly built .so's preloaded anyway? Because run-time
Packit c4476c
	# .so lookup path embedded into application takes precedence
Packit c4476c
	# over LD_LIBRARY_PATH and as result application ends up linking
Packit c4476c
	# to previously installed .so's. On IRIX instead of preloading
Packit c4476c
	# newly built .so's we trick run-time linker to fail to find
Packit c4476c
	# the installed .so by setting _RLD_ROOT variable.
Packit c4476c
	*ELF\ 32*MIPS*)
Packit c4476c
		#_RLD_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLD_LIST
Packit c4476c
		_RLD_ROOT=/no/such/dir; export _RLD_ROOT
Packit c4476c
		eval $rld_var=\"/usr/lib'${'$rld_var':+:$'$rld_var'}'\"
Packit c4476c
		preload_var=_RLD_LIST
Packit c4476c
		;;
Packit c4476c
	*ELF\ N32*MIPS*)
Packit c4476c
		[ -n "$LD_LIBRARYN32_PATH" ] && rld_var=LD_LIBRARYN32_PATH
Packit c4476c
		#_RLDN32_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLDN32_LIST
Packit c4476c
		_RLDN32_ROOT=/no/such/dir; export _RLDN32_ROOT
Packit c4476c
		eval $rld_var=\"/usr/lib32'${'$rld_var':+:$'$rld_var'}'\"
Packit c4476c
		preload_var=_RLDN32_LIST
Packit c4476c
		;;
Packit c4476c
	*ELF\ 64*MIPS*)
Packit c4476c
		[ -n "$LD_LIBRARY64_PATH"  ] && rld_var=LD_LIBRARY64_PATH
Packit c4476c
		#_RLD64_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLD64_LIST
Packit c4476c
		_RLD64_ROOT=/no/such/dir; export _RLD64_ROOT
Packit c4476c
		eval $rld_var=\"/usr/lib64'${'$rld_var':+:$'$rld_var'}'\"
Packit c4476c
		preload_var=_RLD64_LIST
Packit c4476c
		;;
Packit c4476c
	esac
Packit c4476c
	eval $rld_var=\"${THERE}'${'$rld_var':+:$'$rld_var'}'\"; export $rld_var
Packit c4476c
	unset rld_var
Packit c4476c
	;;
Packit c4476c
*)	LD_LIBRARY_PATH="${THERE}:$LD_LIBRARY_PATH"	# Linux, ELF HP-UX
Packit c4476c
	DYLD_LIBRARY_PATH="${THERE}:$DYLD_LIBRARY_PATH"	# MacOS X
Packit c4476c
	SHLIB_PATH="${THERE}:$SHLIB_PATH"		# legacy HP-UX
Packit c4476c
	LIBPATH="${THERE}:$LIBPATH"			# AIX, OS/2
Packit c4476c
	export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH
Packit c4476c
	# Even though $PATH is adjusted [for Windows sake], it doesn't
Packit c4476c
	# necessarily does the trick. Trouble is that with introduction
Packit c4476c
	# of SafeDllSearchMode in XP/2003 it's more appropriate to copy
Packit c4476c
	# .DLLs in vicinity of executable, which is done elsewhere...
Packit c4476c
	if [ "$OSTYPE" != msdosdjgpp ]; then
Packit c4476c
		PATH="${THERE}:$PATH"; export PATH
Packit c4476c
	fi
Packit c4476c
	;;
Packit c4476c
esac
Packit c4476c
Packit c4476c
{- output_off() unless grep (/-rpath\b/, @{$config{LDFLAGS}}); ""; -}
Packit c4476c
if [ -f "$LIBCRYPTOSO" -a -z "$preload_var" ]; then
Packit c4476c
	# Following three lines are major excuse for isolating them into
Packit c4476c
	# this wrapper script. Original reason for setting LD_PRELOAD
Packit c4476c
	# was to make it possible to pass 'make test' when user linked
Packit c4476c
	# with -rpath pointing to previous version installation. Wrapping
Packit c4476c
	# it into a script makes it possible to do so on multi-ABI
Packit c4476c
	# platforms.
Packit c4476c
	case "$SYSNAME" in
Packit c4476c
	*BSD)	LD_PRELOAD="$LIBCRYPTOSO:$LIBSSLSO" ;;	# *BSD
Packit c4476c
	*)	LD_PRELOAD="$LIBCRYPTOSO $LIBSSLSO" ;;	# SunOS, Linux, ELF HP-UX
Packit c4476c
	esac
Packit c4476c
	_RLD_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"	# Tru64, o32 IRIX
Packit c4476c
	DYLD_INSERT_LIBRARIES="$LIBCRYPTOSO:$LIBSSLSO"	# MacOS X
Packit c4476c
	export LD_PRELOAD _RLD_LIST DYLD_INSERT_LIBRARIES
Packit c4476c
fi
Packit c4476c
{- output_on() unless grep (/-rpath\b/, @{$config{LDFLAGS}}); ""; -}
Packit c4476c
Packit c4476c
cmd="$1"; [ -x "$cmd" ] || cmd="$cmd${EXE_EXT}"
Packit c4476c
shift
Packit c4476c
if [ $# -eq 0 ]; then
Packit c4476c
	exec "$cmd"	# old sh, such as Tru64 4.x, fails to expand empty "$@"
Packit c4476c
else
Packit c4476c
	exec "$cmd" "$@"
Packit c4476c
fi