X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/b2a8800c2c12f251d2b3e27a205b3a64cabbade0..6a3364bfc1f3f6021931b347f4ccdb987d5ab178:/packages/python2/build.sh diff --git a/packages/python2/build.sh b/packages/python2/build.sh index ad70374b..3e9df76d 100644 --- a/packages/python2/build.sh +++ b/packages/python2/build.sh @@ -8,9 +8,9 @@ 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}.13 +TERMUX_PKG_SRCURL=https://www.python.org/ftp/python/${TERMUX_PKG_VERSION}/Python-${TERMUX_PKG_VERSION}.tar.xz +TERMUX_PKG_SHA256=35d543986882f78261f97787fd3e06274bfa6df29fac9b4a94f73930ff98f731 # 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,7 +22,9 @@ 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" +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: @@ -47,6 +49,13 @@ 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" } termux_step_post_make_install () { @@ -55,10 +64,15 @@ 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 () {