X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/0a1ce09534f66988a3d3dca7d3703b49ed066d02..5e927b658d3f3a2176af1090b92fe7f5aa400912:/packages/python/build.sh diff --git a/packages/python/build.sh b/packages/python/build.sh index 7c397a2a..02e12f6e 100644 --- a/packages/python/build.sh +++ b/packages/python/build.sh @@ -1,12 +1,10 @@ TERMUX_PKG_HOMEPAGE=https://python.org/ TERMUX_PKG_DESCRIPTION="Python 3 programming language intended to enable clear programs" TERMUX_PKG_DEPENDS="libandroid-support, ncurses, readline, libffi, openssl, libutil, libbz2, libsqlite, gdbm, ncurses-ui-libs, libcrypt, liblzma" -TERMUX_PKG_HOSTBUILD=true - _MAJOR_VERSION=3.6 -TERMUX_PKG_VERSION=${_MAJOR_VERSION}.1 +TERMUX_PKG_VERSION=${_MAJOR_VERSION}.5 +TERMUX_PKG_SHA256=f434053ba1b5c8a5cc597e966ead3c5143012af827fd3f0697d21450bb8d87a6 TERMUX_PKG_SRCURL=https://www.python.org/ftp/python/${TERMUX_PKG_VERSION}/Python-${TERMUX_PKG_VERSION}.tar.xz -TERMUX_PKG_SHA256=a01810ddfcec216bcdb357a84bfaafdfaa0ca42bbdaa4cb7ff74f5a9961e4041 # 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]" @@ -25,49 +23,32 @@ TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_linkat=no" TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_posix_semaphores_enabled=no" # Do not assume getaddrinfo is buggy when cross compiling: TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_buggy_getaddrinfo=no" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --enable-loadable-sqlite-extensions" TERMUX_PKG_RM_AFTER_INSTALL=" bin/python${_MAJOR_VERSION}m bin/idle* lib/python${_MAJOR_VERSION}/idlelib lib/python${_MAJOR_VERSION}/test lib/python${_MAJOR_VERSION}/tkinter lib/python${_MAJOR_VERSION}/turtledemo +lib/python${_MAJOR_VERSION}/ctypes/test +lib/python${_MAJOR_VERSION}/distutils/tests +lib/python${_MAJOR_VERSION}/sqlite3/test +lib/python${_MAJOR_VERSION}/unittest/test " -termux_step_host_build () { - # We need native Parser/pgen binary, copied into cross-compile - # build in termux_step_post_configure(). - $TERMUX_PKG_SRCDIR/configure - make - # We also need a python$_MAJOR_VERSION binary to be picked up - # by configure check. - ln -f -s python python$_MAJOR_VERSION -} - 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_configure () { - cp $TERMUX_PKG_HOSTBUILD_DIR/Parser/pgen $TERMUX_PKG_BUILDDIR/Parser/pgen - cp $TERMUX_PKG_HOSTBUILD_DIR/Programs/_freeze_importlib $TERMUX_PKG_BUILDDIR/Programs/_freeze_importlib - $TERMUX_TOUCH -d "next hour" $TERMUX_PKG_BUILDDIR/Parser/pgen - $TERMUX_TOUCH -d "next hour" $TERMUX_PKG_BUILDDIR/Programs/_freeze_importlib + if [ $TERMUX_ARCH = x86_64 ]; then LDFLAGS+=64; fi } termux_step_post_make_install () { (cd $TERMUX_PREFIX/bin && rm -f python && ln -s python3 python) (cd $TERMUX_PREFIX/share/man/man1 && rm -f python.1 && ln -s python3.1 python.1) - # Restore path which termux_step_host_build messed with - export PATH=$TERMUX_ORIG_PATH # Save away pyconfig.h so that the python-dev subpackage does not take it. # It is required by ensurepip so bundled with the main python package. @@ -94,7 +75,8 @@ termux_step_post_massage () { termux_step_create_debscripts () { ## POST INSTALL: - echo 'echo "Setting up pip..."' > postinst + echo "#!$TERMUX_PREFIX/bin/sh" > postinst + echo 'echo "Setting up pip..."' >> postinst # Fix historical mistake which removed bin/pip 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/pip -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 @@ -102,8 +84,9 @@ termux_step_create_debscripts () { echo "$TERMUX_PREFIX/bin/python -m ensurepip --upgrade --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 "pip freeze 2> /dev/null | xargs pip uninstall -y > /dev/null 2> /dev/null" >> prerm # Cleanup __pycache__ folders: