X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl_exp.SH;h=ef79876fce705df8971b99801d94d59717419dbb;hb=ba51d756f9ffaa3939ada6861397f27ce3967220;hp=49e8119591acefb35c0e0f68ffd19e33a9156ff6;hpb=5f05dabc4054964aa3b10f44f8468547f051cdf8;p=p5sagit%2Fp5-mst-13.2.git diff --git a/perl_exp.SH b/perl_exp.SH index 49e8119..ef79876 100755 --- a/perl_exp.SH +++ b/perl_exp.SH @@ -1,19 +1,37 @@ #!/bin/sh - +# # Written: Nov 1994 Wayne Scott (wscott@ichips.intel.com) - +# # Create the export list for perl. # Needed by AIX to do dynamic linking. - -# NOTE: If you're using 'old_embed.pl', don't use this script! -# Use 'old_perl_exp.SH' instead. - +# # This simple program relys on 'global.sym' being up to date # with all of the global symbols that a dynamicly link library # might want to access. +# +# Most symbols have a Perl_ prefix because that's what embed.h sticks +# in front of them. Variations depend on binary compatibility with +# Perl 5.003. +# -# All symbols have a Perl_ prefix because that's what embed.h -# sticks in front of them. +case $CONFIG in +'') + if test -f config.sh; then TOP=.; + elif test -f ../config.sh; then TOP=..; + elif test -f ../../config.sh; then TOP=../..; + elif test -f ../../../config.sh; then TOP=../../..; + elif test -f ../../../../config.sh; then TOP=../../../..; + else + echo "Can't find config.sh."; exit 1 + fi + . $TOP/config.sh + ;; +esac +: This forces SH files to create target in same directory as SH file. +: This is so that make depend always knows where to find SH derivatives. +case "$0" in +*/*) cd `expr X$0 : 'X\(.*\)/'` ;; +esac echo "Extracting perl.exp" @@ -25,22 +43,25 @@ y*) global=/tmp/exp$$g interp=/tmp/exp$$i compat3=/tmp/exp$$c - trap 'rm -f $global $interp $compat3' 0 - trap 'exit 1' 1 2 3 13 15 grep '^[A-Za-z]' global.sym | sort >$global grep '^[A-Za-z]' interp.sym | sort >$interp grep '^[A-Za-z]' compat3.sym | sort >$compat3 - comm -23 $global $compat3 | sed 's/^/Perl_/p' >> perl.exp + comm -23 $global $compat3 | sed 's/^/Perl_/' >> perl.exp + comm -12 $interp $compat3 | sed 's/^/Perl_/' >> perl.exp comm -12 $global $compat3 >> perl.exp - comm -12 $interp $compat3 | sed 's/^/Perl_/p' >> perl.exp comm -23 $interp $compat3 >> perl.exp + rm -f $global $interp $compat3 ;; *) sed -n '/^[A-Za-z]/ s/^/Perl_/p' global.sym interp.sym >> perl.exp ;; esac -# extra globals not included above. +# +# Extra globals not included above (including a few that might +# not actually be defined, but there's no harm in that). +# + cat <> perl.exp perl_init_i18nl10n perl_init_i18nl14n @@ -63,5 +84,15 @@ perl_call_argv perl_call_pv perl_call_method perl_call_sv -perl_requirepv +perl_eval_pv +perl_eval_sv +perl_require_pv +Mymalloc +Mycalloc +Myremalloc +Myfree +Perl_malloc +Perl_calloc +Perl_realloc +Perl_free END