commit:     f1832cdac19a0b8da2eb1f07371516168bd0af69
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 26 08:03:28 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov 26 08:20:38 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f1832cda

dev-python/pycparser: add 2.21

Signed-off-by: Sam James <sam <AT> gentoo.org>

 dev-python/pycparser/Manifest              |  1 +
 dev-python/pycparser/pycparser-2.21.ebuild | 74 ++++++++++++++++++++++++++++++
 2 files changed, 75 insertions(+)

diff --git a/dev-python/pycparser/Manifest b/dev-python/pycparser/Manifest
index 5ec1265d1176..c619d5054644 100644
--- a/dev-python/pycparser/Manifest
+++ b/dev-python/pycparser/Manifest
@@ -1 +1,2 @@
 DIST pycparser-2.20.tar.gz 161330 BLAKE2B 
9a114e4b73e6c3c495bd78c393957146ec425eb5b15d72266cbf424f15e8d2e2e6402ef36d60a9dff41b393aab80fe1356befd25549517f398e129836a76b037
 SHA512 
ff0853c9f981b43b4f2e879350715c07b02cf9dab223d4980d8fe0a3138c98041b5f848a9355ae4f1cb45e7f137c03a88843008e18d77af9250e0d9c55f5ca1b
+DIST pycparser-2.21.tar.gz 170877 BLAKE2B 
ae6bf42dfc552bf1e3bfb5430cdb0c15b5e011ec53cbd03e0e2507c08a1a78690cefce2de134bd984caccc5dbde90661cb4c18df5c289217967213aac4d52404
 SHA512 
e61fbdde484d1cf74d4b27bdde40cf2da4b7028ca8ecd37c83d77473dab707d457321aecaf97da3b114c1d58a4eb200290b76f9c958044b57e5fed949895b5f0

diff --git a/dev-python/pycparser/pycparser-2.21.ebuild 
b/dev-python/pycparser/pycparser-2.21.ebuild
new file mode 100644
index 000000000000..0f74443174f6
--- /dev/null
+++ b/dev-python/pycparser/pycparser-2.21.ebuild
@@ -0,0 +1,74 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# please keep this ebuild at EAPI 7 -- sys-apps/portage dep
+EAPI=7
+
+PYTHON_COMPAT=( python3_{7..10} pypy3 )
+
+inherit distutils-r1
+
+DESCRIPTION="C parser and AST generator written in Python"
+HOMEPAGE="https://github.com/eliben/pycparser";
+SRC_URI="mirror://pypi/${PN:0:1}/${PN}/${P}.tar.gz"
+
+LICENSE="BSD"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv 
~s390 ~sparc ~x86 ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos 
~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
+
+RDEPEND="dev-python/ply:=[${PYTHON_USEDEP}]"
+BDEPEND="${RDEPEND}
+       dev-python/setuptools[${PYTHON_USEDEP}]"
+
+python_prepare_all() {
+       # remove the original files to guarantee their regen
+       rm pycparser/{c_ast,lextab,yacctab}.py || die
+
+       # kill sys.path manipulations to force the tests to use built files
+       sed -i -e '/sys\.path/d' tests/*.py || die
+
+       # Ensure we can find tests in our directory
+       sed -i -e 's/from tests.test_util/from test_util/g' tests/test_*.py || 
die
+
+       ln -s "${S}"/examples tests/examples || die
+
+       rm tests/test_examples.py || die
+
+       distutils-r1_python_prepare_all
+}
+
+python_compile() {
+       distutils-r1_python_compile
+
+       # note: tables built by py3.5+ are incompatible with older versions
+       # because of 100 group limit of 're' module -- just generate them
+       # separately optimized for each target instead
+       pushd "${BUILD_DIR}"/lib/pycparser > /dev/null || die
+       "${PYTHON}" _build_tables.py || die
+       popd > /dev/null || die
+}
+
+python_test() {
+       # Skip tests if cpp is not in PATH
+       type -P cpp >/dev/null || return 0
+       # change workdir to avoid '.' import
+       cd tests || die
+
+       # Ensure that 'cpp' is called with the right arguments
+       # Tests don't seem to always pass the include they intend to use.
+       mkdir -p "${T}"/bin || die
+       cat > "${T}"/bin/cpp <<-EOF || die
+       #!${BROOT}/bin/bash
+       exec ${BROOT}/usr/bin/cpp -I${S}/utils/fake_libc_include/ \$@
+       EOF
+       chmod +x "${T}"/bin/cpp || die
+
+       PATH="${T}/bin:${PATH}" eunittest
+}
+
+python_install() {
+       distutils-r1_python_install
+
+       # setup.py generates {c_ast,lextab,yacctab}.py with bytecode disabled.
+       python_optimize
+}

Reply via email to