X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/2b0e9dc9e252b0931beb32431d6c25ef8eb38cd3..1ff10e5c361fab8faf2b107dd206f75d4be3dbbd:/packages/python2/build.sh diff --git a/packages/python2/build.sh b/packages/python2/build.sh index 267f374a..5c2c9b27 100644 --- a/packages/python2/build.sh +++ b/packages/python2/build.sh @@ -8,8 +8,10 @@ TERMUX_PKG_DEPENDS="libandroid-support, ncurses, readline, libffi, openssl, libu TERMUX_PKG_HOSTBUILD=true _MAJOR_VERSION=2.7 -TERMUX_PKG_VERSION=${_MAJOR_VERSION}.13 -TERMUX_PKG_SRCURL=http://www.python.org/ftp/python/${TERMUX_PKG_VERSION}/Python-${TERMUX_PKG_VERSION}.tar.xz +TERMUX_PKG_VERSION=${_MAJOR_VERSION}.14 +TERMUX_PKG_REVISION=2 +TERMUX_PKG_SRCURL=https://www.python.org/ftp/python/${TERMUX_PKG_VERSION}/Python-${TERMUX_PKG_VERSION}.tar.xz +TERMUX_PKG_SHA256=71ffb26e09e78650e424929b2b457b9c912ac216576e6bd9e7d204ed03296a66 # The flag --with(out)-pymalloc (disable/enable specialized mallocs) is enabled by default and causes m suffix versions of python. # Set ac_cv_func_wcsftime=no to avoid errors such as "character U+ca0025 is not in range [U+0000; U+10ffff]" @@ -41,13 +43,21 @@ termux_step_host_build () { termux_step_post_configure () { cp $TERMUX_PKG_HOSTBUILD_DIR/Parser/pgen $TERMUX_PKG_BUILDDIR/Parser/pgen - $TERMUX_TOUCH -d "next hour" $TERMUX_PKG_BUILDDIR/Parser/pgen + touch -d "next hour" $TERMUX_PKG_BUILDDIR/Parser/pgen } termux_step_pre_configure() { # Put the host-built python in path: export TERMUX_ORIG_PATH=$PATH export PATH=$TERMUX_PKG_HOSTBUILD_DIR:$PATH + + # Needed when building with clang, as setup.py only probes + # gcc for include paths when finding headers for determining + # if extension modules should be built (specifically, the + # zlib extension module is not built without this): + CPPFLAGS+=" -I$TERMUX_STANDALONE_TOOLCHAIN/sysroot/usr/include" + LDFLAGS+=" -L$TERMUX_STANDALONE_TOOLCHAIN/sysroot/usr/lib" + if [ $TERMUX_ARCH = x86_64 ]; then LDFLAGS+=64; fi } termux_step_post_make_install () { @@ -56,15 +66,21 @@ termux_step_post_make_install () { rm $TERMUX_PREFIX/bin/python # Restore path which termux_step_host_build messed with export PATH=$TERMUX_ORIG_PATH +} - # Used by pip to compile C code, remove the spec file flag - # since it's built in for the on-device gcc: - perl -p -i -e "s|${_SPECSFLAG}||g" $TERMUX_PREFIX/lib/python${_MAJOR_VERSION}/{config/Makefile,_sysconfigdata.py} +termux_step_post_massage () { + # Verify that desired modules have been included: + for module in _ssl bz2 zlib _curses _sqlite3; do + if [ ! -f lib/python${_MAJOR_VERSION}/lib-dynload/${module}.so ]; then + termux_error_exit "Python module library $module not built" + fi + done } termux_step_create_debscripts () { ## POST INSTALL: - echo "echo 'Setting up pip2...'" > postinst + echo "#!$TERMUX_PREFIX/bin/sh" > postinst + echo "echo 'Setting up pip2...'" >> postinst # Fix historical mistake which removed bin/pip2 but left site-packages/pip-*.dist-info, # which causes ensurepip to avoid installing pip due to already existing pip install: echo "if [ ! -f $TERMUX_PREFIX/bin/pip2 -a -d $TERMUX_PREFIX/lib/python${_MAJOR_VERSION}/site-packages/pip-*.dist-info ]; then rm -Rf $TERMUX_PREFIX/lib/python${_MAJOR_VERSION}/site-packages/pip-*.dist-info ; fi" >> postinst @@ -72,8 +88,9 @@ termux_step_create_debscripts () { echo "$TERMUX_PREFIX/bin/python2 -m ensurepip --upgrade --no-default-pip" >> postinst ## PRE RM: - # Avoid running on update: - echo 'if [ $1 != "remove" ]; then exit 0; fi' > prerm + # Avoid running on update + echo "#!$TERMUX_PREFIX/bin/sh" > prerm: + echo 'if [ $1 != "remove" ]; then exit 0; fi' >> prerm # Uninstall everything installed through pip: echo "pip2 freeze 2> /dev/null | xargs pip2 uninstall -y > /dev/null 2> /dev/null" >> prerm # Cleanup __pycache__ folders