X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/bbe295173d400a37454e487a3ff8fc99153c5aa1..295241d4043c55a41259b4846464e1668b2f6a5f:/packages/python/build.sh diff --git a/packages/python/build.sh b/packages/python/build.sh index 52943562..09f9728d 100644 --- a/packages/python/build.sh +++ b/packages/python/build.sh @@ -1,16 +1,12 @@ -TERMUX_PKG_HOMEPAGE=http://python.org/ +TERMUX_PKG_HOMEPAGE=https://python.org/ 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, libsqlite, gdbm, ncurses-ui-libs, libcrypt, liblzma" TERMUX_PKG_HOSTBUILD=true -_MAJOR_VERSION=3.5 -TERMUX_PKG_VERSION=${_MAJOR_VERSION}.2 -TERMUX_PKG_BUILD_REVISION=6 -TERMUX_PKG_SRCURL=http://www.python.org/ftp/python/${TERMUX_PKG_VERSION}/Python-${TERMUX_PKG_VERSION}.tar.xz +_MAJOR_VERSION=3.6 +TERMUX_PKG_VERSION=${_MAJOR_VERSION}.1 +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]" @@ -22,61 +18,68 @@ 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 --with-system-ffi --without-ensurepip" +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --build=$TERMUX_BUILD_TUPLE --with-system-ffi --without-ensurepip" # 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" # Do not assume getaddrinfo is buggy when cross compiling: TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_buggy_getaddrinfo=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/idle*" +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 +" termux_step_host_build () { - # We need a host-built Parser/pgen binary, copied into cross-compile build in termux_step_post_configure() below + # We need native Parser/pgen binary, copied into cross-compile + # build in termux_step_post_configure(). $TERMUX_PKG_SRCDIR/configure - make Parser/pgen - # We need a python$_MAJOR_VERSION binary to be picked up by configure check: make - rm -f python$_MAJOR_VERSION # Remove symlink if already exists to get a newer timestamp - ln -s python python$_MAJOR_VERSION + # 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 + touch -d "next hour" $TERMUX_PKG_BUILDDIR/Parser/pgen + touch -d "next hour" $TERMUX_PKG_BUILDDIR/Programs/_freeze_importlib } 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 + (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. # Copied back in termux_step_post_massage() after the python-dev package has been built. mv $TERMUX_PREFIX/include/python${_MAJOR_VERSION}m/pyconfig.h $TERMUX_PKG_TMPDIR/pyconfig.h - - # This makefile is used by pip to compile C code, and thinks that ${TERMUX_HOST_PLATFORM}-gcc - # and other prefixed tools should be used, but we want unprefixed ones. - # Also Remove the specs flag since that is default in the gcc Termux package: - perl -p -i -e "s|${TERMUX_HOST_PLATFORM}-||g,s|${_SPECSFLAG}||g" $TERMUX_PREFIX/lib/python${_MAJOR_VERSION}/config-${_MAJOR_VERSION}m/Makefile } 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 + termux_error_exit "Python module library $module not built" fi done