diff --git a/packages/python-tldp/build.sh b/packages/python-tldp/build.sh new file mode 100644 index 000000000..22891644d --- /dev/null +++ b/packages/python-tldp/build.sh @@ -0,0 +1,57 @@ +TERMUX_PKG_HOMEPAGE=https://github.com/tLDP/python-tldp +TERMUX_PKG_DESCRIPTION="Tools for publishing from TLDP sources" +TERMUX_PKG_LICENSE="MIT" +TERMUX_PKG_MAINTAINER="@termux" +TERMUX_PKG_VERSION=0.7.5 +TERMUX_PKG_SRCURL=https://github.com/tLDP/python-tldp/archive/refs/tags/tldp-${TERMUX_PKG_VERSION}.tar.gz +TERMUX_PKG_SHA256=bae313095b877b4272ddccaabd70efcbc526e2c1036f63fb665ec7ce10c94cde +TERMUX_PKG_DEPENDS="python" +_PKG_PYTHON_DEPENDS="networkx nose" +TERMUX_PKG_PLATFORM_INDEPENDENT=true +TERMUX_PKG_BUILD_IN_SRC=true + +_PYTHON_VERSION=$(. $TERMUX_SCRIPTDIR/packages/python/build.sh; echo $_MAJOR_VERSION) + +TERMUX_PKG_RM_AFTER_INSTALL=" +bin/nosetests* +lib/python${_PYTHON_VERSION}/site-packages/__pycache__ +lib/python${_PYTHON_VERSION}/site-packages/easy-install.pth +lib/python${_PYTHON_VERSION}/site-packages/site.py +" + +termux_step_pre_configure() { + termux_setup_python_crossenv + pushd $TERMUX_PYTHON_CROSSENV_SRCDIR + _CROSSENV_PREFIX=$TERMUX_PKG_BUILDDIR/python-crossenv-prefix + python${_PYTHON_VERSION} -m crossenv \ + $TERMUX_PREFIX/bin/python${_PYTHON_VERSION} \ + ${_CROSSENV_PREFIX} + popd + . ${_CROSSENV_PREFIX}/bin/activate +} + +termux_step_make_install() { + python setup.py install --force + + export PYTHONPATH=$TERMUX_PREFIX/lib/python${_PYTHON_VERSION}/site-packages + python setup.py install --force --prefix $TERMUX_PREFIX + + pushd $PYTHONPATH + _TLDP_EGGDIR= + for f in tldp-${TERMUX_PKG_VERSION}-py${_PYTHON_VERSION}.egg; do + if [ -d "$f" ]; then + _TLDP_EGGDIR="$f" + break + fi + done + test -n "${_TLDP_EGGDIR}" + popd +} + +termux_step_create_debscripts() { + cat <<- EOF > ./postinst + #!$TERMUX_PREFIX/bin/sh + echo "Installing dependencies through pip..." + pip3 install ${_PKG_PYTHON_DEPENDS} + EOF +} diff --git a/packages/python-tldp/setup.py.patch b/packages/python-tldp/setup.py.patch new file mode 100644 index 000000000..3d56af2e0 --- /dev/null +++ b/packages/python-tldp/setup.py.patch @@ -0,0 +1,11 @@ +--- a/setup.py ++++ b/setup.py +@@ -27,7 +27,7 @@ + 'extras/css': glob.glob('extras/css/*.css'), + 'extras/dsssl': glob.glob('extras/dsssl/*.dsl'), + }, +- data_files=[('/etc/ldptool', ['etc/ldptool.ini']), ], ++ data_files=[('@TERMUX_PREFIX@/etc/ldptool', ['etc/ldptool.ini']), ], + entry_points={ + 'console_scripts': ['ldptool = tldp.driver:main', ], + }, diff --git a/packages/python-tldp/tldp-config.py.patch b/packages/python-tldp/tldp-config.py.patch new file mode 100644 index 000000000..51a2eeec5 --- /dev/null +++ b/packages/python-tldp/tldp-config.py.patch @@ -0,0 +1,11 @@ +--- a/tldp/config.py ++++ b/tldp/config.py +@@ -17,7 +17,7 @@ + + logger = logging.getLogger(__name__) + +-DEFAULT_CONFIGFILE = '/etc/ldptool/ldptool.ini' ++DEFAULT_CONFIGFILE = '@TERMUX_PREFIX@/etc/ldptool/ldptool.ini' + + + class DirectoriesExist(argparse._AppendAction): diff --git a/packages/python-tldp/tldp-ldpcollection.py.patch b/packages/python-tldp/tldp-ldpcollection.py.patch new file mode 100644 index 000000000..0eea33d91 --- /dev/null +++ b/packages/python-tldp/tldp-ldpcollection.py.patch @@ -0,0 +1,11 @@ +--- a/tldp/ldpcollection.py ++++ b/tldp/ldpcollection.py +@@ -6,7 +6,7 @@ + import collections + + +-class LDPDocumentCollection(collections.MutableMapping): ++class LDPDocumentCollection(collections.abc.MutableMapping): + '''a dict-like container for DocumentCollection objects + + Intended to be subclassed.