commit:     727099d263d3bbea2fce6fe06e8d5b64fd177768
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 19 16:49:18 2022 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 19 18:37:02 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=727099d2

dev-util/scons: Use PEP517 build

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

 dev-util/scons/metadata.xml          |   1 +
 dev-util/scons/scons-4.4.0-r1.ebuild | 134 +++++++++++++++++++++++++++++++++++
 2 files changed, 135 insertions(+)

diff --git a/dev-util/scons/metadata.xml b/dev-util/scons/metadata.xml
index 15c2437dbee4..aacbf74f7fb9 100644
--- a/dev-util/scons/metadata.xml
+++ b/dev-util/scons/metadata.xml
@@ -14,6 +14,7 @@
   </longdescription>
   <upstream>
     <remote-id type="github">SCons/scons</remote-id>
+    <remote-id type="pypi">SCons</remote-id>
     <remote-id type="sourceforge">scons</remote-id>
   </upstream>
 </pkgmetadata>

diff --git a/dev-util/scons/scons-4.4.0-r1.ebuild 
b/dev-util/scons/scons-4.4.0-r1.ebuild
new file mode 100644
index 000000000000..a6021628266f
--- /dev/null
+++ b/dev-util/scons/scons-4.4.0-r1.ebuild
@@ -0,0 +1,134 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_USE_PEP517=setuptools
+PYTHON_COMPAT=( python3_{8..11} )
+PYTHON_REQ_USE="threads(+)"
+
+inherit distutils-r1 multiprocessing
+
+MY_P="SCons-${PV}"
+DESCRIPTION="Extensible Python-based build utility"
+HOMEPAGE="
+       https://www.scons.org/
+       https://github.com/SCons/scons/
+       https://pypi.org/project/SCons/
+"
+SRC_URI="
+       
https://downloads.sourceforge.net/project/${PN}/${PN}/${PV}/${MY_P}.tar.gz
+       doc? (
+               https://www.scons.org/doc/${PV}/PDF/${PN}-user.pdf
+                       -> ${P}-user.pdf
+               https://www.scons.org/doc/${PV}/HTML/${PN}-user.html
+                       -> ${P}-user.html
+       )
+       test? (
+               https://github.com/SCons/scons/archive/${PV}.tar.gz
+                       -> ${P}.gh.tar.gz
+       )
+"
+S="${WORKDIR}/${P}/src"
+
+LICENSE="MIT"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 
~riscv ~s390 ~sparc ~x86 ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos 
~x64-macos ~sparc-solaris ~x64-solaris ~x86-solaris"
+IUSE="doc test"
+RESTRICT="!test? ( test )"
+
+BDEPEND="
+       test? (
+               dev-libs/libxml2[${PYTHON_USEDEP}]
+               dev-python/lxml[${PYTHON_USEDEP}]
+       )
+"
+
+PATCHES=(
+       # support env passthrough for Gentoo ebuilds
+       "${FILESDIR}"/scons-4.1.0-env-passthrough.patch
+       # respect CC, CXX, C*FLAGS, LDFLAGS by default
+       "${FILESDIR}"/scons-4.2.0-respect-cc-etc.patch
+)
+
+src_unpack() {
+       # use the git directory structure, but put pregenerated release
+       # inside src/ subdirectory to make our life easier
+       if use test; then
+               unpack "${P}.gh.tar.gz"
+       else
+               mkdir -p "${P}"/src || die
+       fi
+
+       tar -C "${P}"/src --strip-components=1 -xzf "${DISTDIR}/${MY_P}.tar.gz" 
|| die
+}
+
+src_prepare() {
+       # apply patches relatively to top directory
+       cd "${WORKDIR}/${P}" || die
+       distutils-r1_src_prepare
+
+       if use test; then
+               local remove_tests=(
+                       # TODO: does not respect PATH?
+                       test/Clang
+                       # broken
+                       test/DVIPDF/DVIPDFFLAGS.py
+                       test/Java/swig-dependencies.py
+                       test/Java/multi-step.py
+                       test/TEX/newglossary.py
+                       test/TEX/variant_dir_newglossary.py
+                       # broken by commas in date, sic!
+                       test/option/option-v.py
+                       test/Interactive/version.py
+                       # warnings from new binutils?
+                       test/AS/as-live.py
+                       test/AS/nasm.py
+                       # hangs
+                       test/KeyboardInterrupt.py
+               )
+
+               if ! use amd64 && ! use x86 ; then
+                       # These tests are currently broken on arm and other 
non-amd64/x86 platforms
+                       # Work seems to be ongoing in e.g. 
https://github.com/SCons/scons/pull/4022 to
+                       # better plumb up the MSVC tests for alternative arches.
+                       # Try again after 4.2.0.
+                       # See also: 
https://pairlist4.pair.net/pipermail/scons-users/2020-November/008452.html
+                       # bug #757534
+                       remove_tests+=(
+                               test/MSVS/vs-7.0-scc-files.py
+                               test/MSVS/vs-7.0-scc-legacy-files.py
+                               test/MSVS/vs-7.1-scc-files.py
+                               test/MSVS/vs-7.1-scc-legacy-files.py
+                               test/MSVS/vs-scc-files.py
+                               test/MSVS/vs-scc-legacy-files.py
+                       )
+               fi
+
+               rm -r "${remove_tests[@]}" || die
+       fi
+}
+
+python_test() {
+       local -x COLUMNS=80
+       # set variable from escons() of scons-util.eclass to make 
env-passthrough patch work within test env
+       local -x GENTOO_SCONS_ENV_PASSTHROUGH=1
+       # unset some env variables to pass appropriate tests
+       unset AR AS ASFLAGS CC CXX CFLAGS CXXFLAGS CPPFLAGS LDFLAGS
+       cd "${WORKDIR}/${P}" || die
+       "${EPYTHON}" runtest.py -a --passed \
+               -j "$(makeopts_jobs "${MAKEOPTS}" "$(get_nproc)")"
+
+       # runtest.py script returns "0" if all tests are passed
+       # and returns "2" if there are any tests with "no result"
+       # (i.e. in case if some tools are not installed or it's Windows 
specific tests)
+       [[ ${?} == [02] ]] || die "Tests fail with ${EPYTHON}"
+}
+
+python_install_all() {
+       rm "${ED}"/usr/*.1 || die
+       distutils-r1_python_install_all
+
+       doman *.1
+       use doc && dodoc "${DISTDIR}/${P}"-user.{pdf,html}
+}

Reply via email to