commit:     ec5966ac5c495d6b88aaec63b651adbc4497dd8b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 26 05:18:20 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Apr 26 07:02:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec5966ac

dev-python/translate-toolkit: Bump to 3.15.2

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 dev-python/translate-toolkit/Manifest              |   1 +
 .../translate-toolkit-3.15.2.ebuild                | 126 +++++++++++++++++++++
 2 files changed, 127 insertions(+)

diff --git a/dev-python/translate-toolkit/Manifest 
b/dev-python/translate-toolkit/Manifest
index 79479f6e710b..6643947ccabd 100644
--- a/dev-python/translate-toolkit/Manifest
+++ b/dev-python/translate-toolkit/Manifest
@@ -1 +1,2 @@
 DIST translate-3.15.1.gh.tar.gz 1169823 BLAKE2B 
f9db9be1c90c82000e5a35c9a1321a7a4de46f3efaddeaa57a418443203b04dc6d2c1ab9bd4d126c91fb86024d991682ed5e1acecb9e1aa6078ce140dcccba4e
 SHA512 
e9e2eb5995e69827d10dff31e506e23f3aeea08a7edcfa11a02c7e02fe6ece3612aaf4d3109fe27a71e224f52488cf77690c786c4af4781a018af715a7eff145
+DIST translate-3.15.2.gh.tar.gz 1170276 BLAKE2B 
512bb038bec132a4bcf483736350b215da838fd2b1eafdf1c552697326b032dcce87fa9709e7a7437d4fccb1edbcb4d381dd064db25354368f147d1c0c936295
 SHA512 
1c791be1ae7f3256b8631add4e65c1c8ce5c9f6aa163e3c52630b8cf14aeab0afd9179a49308713870d953eeb5e918bfcd6299a1ac34fa086afca39f07342b0d

diff --git a/dev-python/translate-toolkit/translate-toolkit-3.15.2.ebuild 
b/dev-python/translate-toolkit/translate-toolkit-3.15.2.ebuild
new file mode 100644
index 000000000000..8f55d174fb91
--- /dev/null
+++ b/dev-python/translate-toolkit/translate-toolkit-3.15.2.ebuild
@@ -0,0 +1,126 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_USE_PEP517=setuptools
+PYTHON_COMPAT=( python3_{10..12} )
+PYTHON_REQ_USE="sqlite"
+
+inherit distutils-r1
+
+MY_P=translate-${PV}
+DESCRIPTION="Toolkit to convert between many translation formats"
+HOMEPAGE="
+       https://github.com/translate/translate/
+       https://pypi.org/project/translate-toolkit/
+"
+SRC_URI="
+       https://github.com/translate/translate/archive/${PV}.tar.gz
+               -> ${MY_P}.gh.tar.gz
+"
+S="${WORKDIR}"/${MY_P}
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~arm64 ~x86"
+IUSE="+html +ical +ini +subtitles +yaml"
+
+RDEPEND="
+       app-text/iso-codes
+       >=dev-python/chardet-3.0.4[${PYTHON_USEDEP}]
+       dev-python/cheroot[${PYTHON_USEDEP}]
+       >=dev-python/levenshtein-0.12.0[${PYTHON_USEDEP}]
+       >=dev-python/lxml-4.3.1[${PYTHON_USEDEP}]
+       >=dev-python/mistletoe-1.1.0[${PYTHON_USEDEP}]
+       >=dev-python/pyparsing-3[${PYTHON_USEDEP}]
+       dev-python/ruamel-yaml[${PYTHON_USEDEP}]
+       >=dev-python/cwcwidth-0.1.9[${PYTHON_USEDEP}]
+       sys-devel/gettext
+       html? ( dev-python/utidylib[${PYTHON_USEDEP}] )
+       ical? ( dev-python/vobject[${PYTHON_USEDEP}] )
+       ini? ( >=dev-python/iniparse-0.5[${PYTHON_USEDEP}] )
+       subtitles? ( media-video/gaupol[${PYTHON_USEDEP}] )
+       yaml? ( dev-python/pyyaml[${PYTHON_USEDEP}] )
+"
+# Technically, the test suite also has undeclared dependency
+# on dev-python/snapshottest but all the tests using it are broken
+# anyway, so we skip them.
+BDEPEND="
+       test? (
+               dev-python/phply[${PYTHON_USEDEP}]
+       )
+"
+
+distutils_enable_tests pytest
+
+src_prepare() {
+       distutils-r1_src_prepare
+
+       # strip unnecessary pins
+       sed -i -e 's:,<[0-9.]*::' pyproject.toml || die
+}
+
+src_test() {
+       # unfortunately, this bad quality package doesn't support XDG_DATA_DIRS
+       # correctly, so we need to reassemble all data files in a single 
directory
+       local -x XDG_DATA_HOME=${T}/share
+       cp -r translate/share "${T}/" || die
+       cp -r "${ESYSROOT}"/usr/share/gaupol "${XDG_DATA_HOME}"/ || die
+
+       distutils-r1_src_test
+}
+
+python_test() {
+       local EPYTEST_DESELECT=(
+               # Fails with network-sandbox (and even with it off but w/ 
softer fail)
+               
'tests/xliff_conformance/test_xliff_conformance.py::test_open_office_to_xliff'
+               
'tests/xliff_conformance/test_xliff_conformance.py::test_po_to_xliff'
+               # all tests based on snapshottest are broken and I'm too tired
+               # to figure this out
+               tests/translate/tools/test_pocount.py::test_{cases,output}
+               tests/translate/tools/test_junitmsgfmt.py::test_output
+       )
+       local EPYTEST_IGNORE=(
+               # unpackaged fluent.*
+               tests/translate/storage/test_fluent.py
+               # changes directory and does not change it back, sigh
+               tests/odf_xliff/test_odf_xliff.py
+       )
+
+       if ! has_version "dev-python/iniparse[${PYTHON_USEDEP}]"; then
+               EPYTEST_IGNORE+=(
+                       translate/convert/test_ini2po.py
+                       translate/convert/test_po2ini.py
+               )
+       fi
+
+       if ! has_version "media-video/gaupol[${PYTHON_USEDEP}]"; then
+               EPYTEST_IGNORE+=(
+                       translate/storage/test_subtitles.py
+               )
+       fi
+
+       local -x PYTEST_DISABLE_PLUGIN_AUTOLOAD=1
+       epytest
+}
+
+python_install_all() {
+       distutils-r1_python_install_all
+
+       insinto /usr
+       doins -r translate/share
+
+       if ! use html; then
+               rm "${ED}"/usr/bin/{html2po,po2html} || die
+       fi
+       if ! use ical; then
+               rm "${ED}"/usr/bin/{ical2po,po2ical} || die
+       fi
+       if ! use ini; then
+               rm "${ED}"/usr/bin/{ini2po,po2ini} || die
+       fi
+       if ! use subtitles; then
+               rm "${ED}"/usr/bin/{sub2po,po2sub} || die
+       fi
+}

Reply via email to