X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/204d1f9a7fc5a616162bc9168a5661db03174754..315a0ef6f9a04618adf5bd30adbd8cbfebd3ffd2:/packages/python/build.sh diff --git a/packages/python/build.sh b/packages/python/build.sh index 9f84dda3..e2e9e414 100644 --- a/packages/python/build.sh +++ b/packages/python/build.sh @@ -1,25 +1,32 @@ TERMUX_PKG_HOMEPAGE=http://python.org/ -TERMUX_PKG_DESCRIPTION="Programming language intended to enable clear programs on both a small and large scale" -# lib/python3.4/lib-dynload/_ctypes.cpython-34m.so links to ffi -# openssl for ensurepip -TERMUX_PKG_DEPENDS="libandroid-support, ncurses, readline, libffi, openssl" +TERMUX_PKG_DESCRIPTION="Python 3 programming language intended to enable clear programs" +# lib/python3.4/lib-dynload/_ctypes.cpython-34m.so links to ffi. +# openssl for ensurepip. +# libbz2 for the bz2 module. +# ncurses-ui-libs for the curses.panel module. +TERMUX_PKG_DEPENDS="libandroid-support, ncurses, readline, libffi, openssl, libutil, libbz2, liblzma, libsqlite, gdbm, ncurses-ui-libs, libcrypt" TERMUX_PKG_HOSTBUILD=true -_MAJOR_VERSION=3.4 -TERMUX_PKG_VERSION=${_MAJOR_VERSION}.3 -TERMUX_PKG_BUILD_REVISION=4 +_MAJOR_VERSION=3.5 +TERMUX_PKG_VERSION=${_MAJOR_VERSION}.2 TERMUX_PKG_SRCURL=http://www.python.org/ftp/python/${TERMUX_PKG_VERSION}/Python-${TERMUX_PKG_VERSION}.tar.xz # 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]" # when executing e.g. "from time import time, strftime, localtime; print(strftime(str('%Y-%m-%d %H:%M'), localtime()))" -TERMUX_PKG_EXTRA_CONFIGURE_ARGS="ac_cv_file__dev_ptmx=yes ac_cv_file__dev_ptc=no ac_cv_func_fstatvfs=yes ac_cv_func_statvfs=yes ac_cv_header_sys_statvfs_h=yes ac_cv_func_wcsftime=no" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS="ac_cv_file__dev_ptmx=yes ac_cv_file__dev_ptc=no ac_cv_func_wcsftime=no" # Avoid trying to include which does not exist on android-21: TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_ftime=no" # Avoid trying to use AT_EACCESS which is not defined: 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" -TERMUX_PKG_RM_AFTER_INSTALL="lib/python${_MAJOR_VERSION}/test lib/python${_MAJOR_VERSION}/tkinter lib/python${_MAJOR_VERSION}/turtledemo lib/python${_MAJOR_VERSION}/idlelib bin/python${_MAJOR_VERSION}m bin/python*-config bin/idle* bin/pyvenv*" +# Hard links does not work on Android 6: +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_linkat=no" +# Posix semaphores are not supported on Android: +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_posix_semaphores_enabled=no" +TERMUX_PKG_RM_AFTER_INSTALL="lib/python${_MAJOR_VERSION}/test lib/python${_MAJOR_VERSION}/tkinter lib/python${_MAJOR_VERSION}/turtledemo lib/python${_MAJOR_VERSION}/idlelib bin/python${_MAJOR_VERSION}m bin/python*-config bin/idle*" # Python does not use CPPFLAGS when building modules, so add this to CFLAGS as well (needed when building _cursesmodule): # export CFLAGS="$CFLAGS -isystem $TERMUX_PREFIX/include/libandroid-support" @@ -39,6 +46,9 @@ termux_step_host_build () { 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 } termux_step_post_make_install () { @@ -59,8 +69,17 @@ termux_step_post_make_install () { } termux_step_post_massage () { + # Verify that desired modules have been included: + for module in _ssl _bz2 zlib _curses _sqlite3 _lzma; do + if [ ! -f lib/python${_MAJOR_VERSION}/lib-dynload/${module}.*.so ]; then + echo "ERROR: Python module library $module not built" + exit 1 + fi + done + # Restore pyconfig.h saved away in termux_step_post_make_install() above: mkdir -p $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX/include/python${_MAJOR_VERSION}m/ + cp $TERMUX_PKG_TMPDIR/pyconfig.h $TERMUX_PREFIX/include/python${_MAJOR_VERSION}m/ mv $TERMUX_PKG_TMPDIR/pyconfig.h $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX/include/python${_MAJOR_VERSION}m/ cd $TERMUX_PKG_MASSAGEDIR @@ -69,15 +88,16 @@ termux_step_post_massage () { termux_step_create_debscripts () { ## POST INSTALL: - echo "$TERMUX_PREFIX/bin/python -m ensurepip --default-pip > /dev/null" > postinst + echo 'echo "Setting up pip..."' > postinst + echo "$TERMUX_PREFIX/bin/python -m ensurepip --upgrade --default-pip" >> postinst # Try to update pip, failing silently on e.g. network errors: - echo "$TERMUX_PREFIX/bin/pip install --upgrade pip > /dev/null 2> /dev/null" >> postinst + # echo "$TERMUX_PREFIX/bin/pip install --upgrade pip > /dev/null 2> /dev/null" >> postinst echo "exit 0" >> postinst ## PRE RM: echo "pip freeze 2> /dev/null | xargs pip uninstall -y > /dev/null 2> /dev/null" > prerm # Cleanup __pycache__ folders - echo "rm -rf $TERMUX_PREFIX/lib/python3.4/" >> prerm + echo "find $TERMUX_PREFIX/lib/python${_MAJOR_VERSION} -depth -name __pycache__ -exec rm -rf {} \;" >> prerm echo "rm -f $TERMUX_PREFIX/bin/pip $TERMUX_PREFIX/bin/pip3*" >> prerm echo "exit 0" >> prerm