diff options
author | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2001-02-16 03:24:50 +0000 |
---|---|---|
committer | Neil Schemenauer <nascheme@enme.ucalgary.ca> | 2001-02-16 03:24:50 +0000 |
commit | f0a87ee955dfbb99a3cfcf2fa835b460012b22a6 (patch) | |
tree | 9eeccbbacd94a9b88eb04fb9eba7e1fb6c8ec64c /Modules/ld_so_beos | |
parent | Moved BeOS/README to Misc/BeOS-NOTES. (diff) | |
download | cpython-f0a87ee955dfbb99a3cfcf2fa835b460012b22a6.tar.gz cpython-f0a87ee955dfbb99a3cfcf2fa835b460012b22a6.tar.bz2 cpython-f0a87ee955dfbb99a3cfcf2fa835b460012b22a6.zip |
Moved BeOS/ar-fake and BeOS/linkmodule to Modules/ar_beos and
Modules/ld_so_beos. Closes SF patch #103679.
Diffstat (limited to 'Modules/ld_so_beos')
-rwxr-xr-x | Modules/ld_so_beos | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/Modules/ld_so_beos b/Modules/ld_so_beos new file mode 100755 index 00000000000..ac20cd25ef3 --- /dev/null +++ b/Modules/ld_so_beos @@ -0,0 +1,79 @@ +#! /bin/sh +# +# linkmodule for Python +# Chris Herborth (chrish@qnx.com) +# +# This is covered by the same copyright/licensing terms as the rest of +# Python. +# +# Shell script to build shared library versions of the modules; since +# the change to the *ahem* "proper" import/export mechanism, this script +# is much simpler. It handles PowerPC and x86, too. +# +# This is called by the Modules/Makefile as $(LDSHARED): +# +# $(LDSHARED) foomodule.o -o foomodule$(SO) +# +# Could also be called as: +# +# $(LDSHARED) readline.o -L/boot/home/config/lib -lreadline -ltermcap \ +# -o readline$(SO) +# +# so we need to preserve the arguments, sort of. + +# Make sure we got reasonable arguments. +TARGET="" +ARGS="" +VERSION=2.0 + +while [ "$#" != "0" ]; do + case "$1" in + -o) TARGET="$2"; shift; shift;; + *) ARGS="$ARGS $1"; shift;; + esac +done + +if [ "$TARGET" = "" ] ; then + echo "Usage:" + echo + echo " $0 [args] -o foomodule.so [args] foomodule.o [args]" + echo + echo "Where:" + echo + echo " [args] normal compiler arguments" + exit 1 +fi + +# The shared libraries and glue objects we need to link against; these +# libs are overkill for most of the standard modules, but it makes life +# in this shell script easier. +LIBS="-L.. -lpython$VERSION -lbe -lnet -lroot" + +case $BE_HOST_CPU in + ppc) + # Boy, do we need a lot of crap... + GLUE_LOC=/boot/develop/lib/ppc + GLUE="${GLUE_LOC}/glue-noinit.a ${GLUE_LOC}/init_term_dyn.o" + case $(uname -r) in + 4.0*) CC="mwcc -xms -export pragma -nodup" ;; + *) CC="mwcc -shared -export pragma -nodup" ;; + esac + ;; + + x86) + # We don't need as much crap here... + GLUE="" + CC="gcc -nostart -Wl,-soname=${TARGET}" + ;; + + *) + # What the?!? + echo "$0 doesn't support $BE_HOST_CPU systems..." + echo "You're on your own... I'd be surprised if this works." + GLUE="" + CC="cc" + ;; +esac + +# Now link that shared lib... +$CC -o $TARGET $ARGS $GLUE $LIBS |