mirror of https://github.com/python/cpython
71 lines
2.0 KiB
Bash
Executable File
71 lines
2.0 KiB
Bash
Executable File
#! /bin/sh
|
|
#
|
|
# linkcc 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 the Python shared library properly; if we haven't
|
|
# already built the export list, we'll need to link twice (argh...) so we
|
|
# can eliminate some unwatnted global symbols from the system glue/init
|
|
# objects.
|
|
#
|
|
# This is called by the Modules/Makefile as part of $(LINKCC):
|
|
#
|
|
# $(LINKCC) $(LDFLAGS) $(LINKFORSHARED) $(MAINOBJ) \
|
|
# -L.. -lpython$(VERSION) $(MODLIBS) $(LIBS) $(SYSLIBS) -o python $(LDLAST)
|
|
#
|
|
# In 1.5.1 this changed to:
|
|
#
|
|
# $(LINKCC) $(LDFLAGS) $(LINKFORSHARED) $(MAINOBJ) \
|
|
# $(LIBRARY) $(MODLIBS) $(LIBS) $(SYSLIBS) -o python $(LDLAST)
|
|
#
|
|
# For BeOS we should set $(LINKCC) to this in configure (similar to the
|
|
# AIX situation):
|
|
#
|
|
# $(srcdir)../BeOS/linkcc $(LIBRARY) $(PURIFY) $(CC) $(OPT)
|
|
#
|
|
# -L.. -lpython$(VERSION) will automagically pick up the shared library.
|
|
#
|
|
# As of Python 1.5.2, this isn't strictly necessary, but it makes me
|
|
# feel safer. It makes sure we've got all the BeOS-specific libraries,
|
|
# and it creates the "lib" symlink that we'll need for chance of running
|
|
# "make test" successfully.
|
|
|
|
LIBRARY="$1"; shift
|
|
|
|
# What we want to end up with.
|
|
DYNAMIC=${LIBRARY%.a}.so
|
|
LINK_DYNAMIC="-l$(basename ${DYNAMIC%.so} | sed -e s,lib,,)"
|
|
|
|
# Grab the rest of the args and build them into the command used to
|
|
# link the python binary. Make sure we link against the shared lib
|
|
# and not the static lib.
|
|
LINK_CMD=""
|
|
while [ "$#" != "0" ] ; do
|
|
case "$1" in
|
|
$LIBRARY)
|
|
LINK_CMD="$LINK_CMD -L.. $LINK_DYNAMIC"
|
|
shift
|
|
;;
|
|
|
|
*)
|
|
LINK_CMD="$LINK_CMD $1"
|
|
shift
|
|
;;
|
|
esac
|
|
done
|
|
|
|
# The shared libraries and glue objects we need to link against; this is
|
|
# a little overkill, but it'll be OK.
|
|
LIBS="-lbe -lnet -lroot"
|
|
|
|
# We'll need this or the python binary won't load libpython.so... handy
|
|
# for testing.
|
|
( cd .. ; ln -sf `pwd` lib )
|
|
|
|
# Now build the python binary.
|
|
echo "Link command: $LINK_CMD"
|
|
$LINK_CMD
|