preload-hacks: Some patches to make it work.
[termux-packages] / packages / python2 / build.sh
index 311710c..40ee238 100644 (file)
@@ -8,9 +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}.12
-TERMUX_PKG_BUILD_REVISION=1
-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=3
+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]"
@@ -22,15 +23,16 @@ TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_ftime=no"
 TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_faccessat=no"
 # The gethostbyname_r function does not exist on device libc:
 TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_gethostbyname_r=no"
-TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --build=$TERMUX_HOST_TUPLE --disable-ipv6 --with-system-ffi --without-ensurepip"
+# Do not assume getaddrinfo is buggy when cross compiling:
+TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_buggy_getaddrinfo=no"
+# Fix https://github.com/termux/termux-packages/issues/2236:
+TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_little_endian_double=yes"
+TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --build=$TERMUX_BUILD_TUPLE --with-system-ffi --without-ensurepip"
 TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --enable-unicode=ucs4"
 
 # Let 2to3 be in the python3 package:
 TERMUX_PKG_RM_AFTER_INSTALL="bin/2to3"
 
-# NOTE: termux_step_host_build may not be called if host build is cached.
-export TERMUX_ORIG_PATH=$PATH
-export PATH=$TERMUX_PKG_HOSTBUILD_DIR:$PATH
 termux_step_host_build () {
        # We need a host-built Parser/pgen binary, copied into cross-compile build in termux_step_post_configure() below
        $TERMUX_PKG_SRCDIR/configure
@@ -43,7 +45,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 () {
@@ -52,15 +68,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
@@ -68,8 +90,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