diff options
| author | Rasmus Lerdorf <rasmus@php.net> | 2000-01-04 02:45:42 +0000 | 
|---|---|---|
| committer | Rasmus Lerdorf <rasmus@php.net> | 2000-01-04 02:45:42 +0000 | 
| commit | a2f46f8e684de37e5fb0f5d597970d2277c426d1 (patch) | |
| tree | 75f877bcabf3efe3afd5e3295ee82fd84881d6f1 | |
| parent | ed3c962b39d54a99a1fd0cfc3da47618b710215d (diff) | |
| download | php-git-a2f46f8e684de37e5fb0f5d597970d2277c426d1.tar.gz | |
# Grr
| -rw-r--r-- | ltconfig | 16 | ||||
| -rw-r--r-- | ltmain.sh | 91 | 
2 files changed, 98 insertions, 9 deletions
| @@ -1188,8 +1188,8 @@ EOF    netbsd*)      if $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then -      archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' -      archive_expsym_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' +      archive_cmds='$CC -shared $compile_rpath $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' +      archive_expsym_cmds='$CC -shared $compile_rpath $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'      else        archive_cmds='$LD -Bshareable $libobjs $deplibs $linkopts -o $lib'        # can we support soname and/or expsyms with a.out? -oliva @@ -1210,8 +1210,8 @@ EOF  EOF      elif $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then -      archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' -      archive_expsym_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' +      archive_cmds='$CC -shared $compile_rpath $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' +      archive_expsym_cmds='$CC -shared $compile_rpath $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'      else        ld_shlibs=no      fi @@ -1226,8 +1226,8 @@ EOF    *)      if $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then -      archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' -      archive_expsym_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' +      archive_cmds='$CC -shared $compile_rpath $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' +      archive_expsym_cmds='$CC -shared $compile_rpath $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'      else        ld_shlibs=no      fi @@ -1428,9 +1428,9 @@ else      no_undefined_flag=' -z text'      # $CC -shared without GNU ld will not create a library from C++      # object files and a static libstdc++, better avoid it by now -    archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linkopts' +    archive_cmds='$LD $compile_rpath -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linkopts'      archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ -		$LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linkopts~$rm $lib.exp' +		$LD $compile_rpath -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linkopts~$rm $lib.exp'      hardcode_libdir_flag_spec='-R$libdir'      hardcode_shlibpath_var=no      case "$host_os" in @@ -1162,7 +1162,7 @@ compiler."        *.o | *.obj | *.a | *.lib)  	# A standard object. -	objs="$objs $arg" +	libobjs="$libobjs $arg"  	;;        *.lo) @@ -1796,6 +1796,94 @@ compiler."  	esac        fi +      if test -n "$rpath$xrpath"; then +	# If the user specified any rpath flags, then add them. +	for libdir in $rpath $xrpath; do +	  # This is the magic to use -rpath. +	  case "$compile_rpath " in +	  *" $libdir "*) ;; +	  *) compile_rpath="$compile_rpath $libdir" ;; +	  esac +	  case "$finalize_rpath " in +	  *" $libdir "*) ;; +	  *) finalize_rpath="$finalize_rpath $libdir" ;; +	  esac +	done +      fi + +      # Now hardcode the library paths +      rpath= +      hardcode_libdirs= +      for libdir in $compile_rpath; do +	if test -n "$hardcode_libdir_flag_spec"; then +	  if test -n "$hardcode_libdir_separator"; then +	    if test -z "$hardcode_libdirs"; then +	      hardcode_libdirs="$libdir" +	    else +	      # Just accumulate the unique libdirs. +	      case "$hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator" in +	      *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) +		;; +	      *) +		hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" +		;; +	      esac +	    fi +	  else +	    eval flag=\"$hardcode_libdir_flag_spec\" +	    rpath="$rpath $flag" +	  fi +	elif test -n "$runpath_var"; then +	  case "$perm_rpath " in +	  *" $libdir "*) ;; +	  *) perm_rpath="$perm_rpath $libdir" ;; +	  esac +	fi +      done +      # Substitute the hardcoded libdirs into the rpath. +      if test -n "$hardcode_libdir_separator" && +	 test -n "$hardcode_libdirs"; then +	libdir="$hardcode_libdirs" +	eval rpath=\" $hardcode_libdir_flag_spec\" +      fi +      compile_rpath="$rpath" + +      rpath= +      hardcode_libdirs= +      for libdir in $finalize_rpath; do +	if test -n "$hardcode_libdir_flag_spec"; then +	  if test -n "$hardcode_libdir_separator"; then +	    if test -z "$hardcode_libdirs"; then +	      hardcode_libdirs="$libdir" +	    else +	      # Just accumulate the unique libdirs. +	      case "$hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator" in +	      *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) +		;; +	      *) +		hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" +		;; +	      esac +	    fi +	  else +	    eval flag=\"$hardcode_libdir_flag_spec\" +	    rpath="$rpath $flag" +	  fi +	elif test -n "$runpath_var"; then +	  case "$finalize_perm_rpath " in +	  *" $libdir "*) ;; +	  *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;; +	  esac +	fi +      done +      # Substitute the hardcoded libdirs into the rpath. +      if test -n "$hardcode_libdir_separator" && +	 test -n "$hardcode_libdirs"; then +	libdir="$hardcode_libdirs" +	eval rpath=\" $hardcode_libdir_flag_spec\" +      fi +      finalize_rpath="$rpath" +        # Create the output directory, or remove our outputs if we need to.        if test -d $output_objdir; then  	$show "${rm}r $output_objdir/$outputname $output_objdir/$libname.* $output_objdir/${libname}${release}.*" @@ -1955,6 +2043,7 @@ EOF  		    done  	      done  	      if test -n "$a_deplib" ; then +		newdeplibs="$newdeplibs $a_deplib"  		droppeddeps=yes  		echo  		echo "*** Warning: This library needs some functionality provided by $a_deplib." | 
