summaryrefslogtreecommitdiff
path: root/eclass
Commit message (Collapse)AuthorAgeFilesLines
* distutils-r1.eclass: Add IUSE=debug w/ DISTUTILS_EXT+_OPTIONALMichał Górny2023-05-051-1/+4
| | | | | | | Fix DISTUTILS_EXT to add IUSE=debug even if DISTUTILS_OPTIONAL is used. This was the intended behavior, as documented in the Python Guide. Signed-off-by: Michał Górny <mgorny@gentoo.org>
* llvm.org.eclass: Enable manpages for 16.0.3Michał Górny2023-05-031-1/+1
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* distutils-r1.eclass: ensure meson-python uses a stable build directoryEli Schwartz2023-05-021-0/+3
| | | | | | | | | | | | | | When not passing an explicit build directory, meson-python configures meson into a build directory that is rooted in a tempdir with a random suffix. This results in unstable paths, which currently disappear after meson-python completes (either with success or failure). It doesn't handle incremental or resumed builds, and it's very difficult to debug -- for example by inspecting the logfile that meson itself prints out when the configure stage fails. Bug: https://bugs.gentoo.org/905396 Signed-off-by: Eli Schwartz <eschwartz93@gmail.com> Signed-off-by: Sam James <sam@gentoo.org>
* llvm.org.eclass: Add 17.0.0_pre20230502 snapshotMichał Górny2023-05-021-0/+3
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* python-utils-r1.eclass: Disable python3_9Michał Górny2023-05-011-5/+3
| | | | | Signed-off-by: Michał Górny <mgorny@gentoo.org> Signed-off-by: Sam James <sam@gentoo.org>
* eclass/tests/python-utils-r1.sh: Stop testing python3_9Michał Górny2023-05-011-7/+1
| | | | | Signed-off-by: Michał Górny <mgorny@gentoo.org> Signed-off-by: Sam James <sam@gentoo.org>
* toolchain.eclass: record EGIT_VERSION correctly in gcc --version for live ↵Sam James2023-04-271-0/+5
| | | | | | | | | | | | ebuilds Without this, gcc --version ends up only showing the commit resulting from applying our patches on top. With this fixed, gcc --version shows both the upstream commit & the commit hash after applying patches. Signed-off-by: Sam James <sam@gentoo.org>
* toolchain.eclass: don't enable openmp by default for >= 13Sam James2023-04-261-1/+8
| | | | | | | This should be set in profiles going forward, not in toolchain.eclass. Bug: https://bugs.gentoo.org/890999 Signed-off-by: Sam James <sam@gentoo.org>
* bash-completion-r1.eclass: mark get_bashcompdir, get_bashhelpersdir as ↵Sam James2023-04-251-1/+3
| | | | | | @INCLUDES_EPREFIX Signed-off-by: Sam James <sam@gentoo.org>
* distutils-r1.eclass: Fix support for >=meson-python-0.13.0Michał Górny2023-04-241-17/+34
| | | | | Closes: https://bugs.gentoo.org/904677 Signed-off-by: Michał Górny <mgorny@gentoo.org>
* acct-group.eclass: alpha, ia64, s390, m68k lack stable keywordsSam James2023-04-231-1/+1
| | | | | | We dropped them to ~arch a while ago. Signed-off-by: Sam James <sam@gentoo.org>
* acct-user.eclass: alpha, ia64, s390, m68k lack stable keywordsSam James2023-04-231-1/+1
| | | | | | We dropped them to ~arch a while ago. Signed-off-by: Sam James <sam@gentoo.org>
* acct-user.eclass: add ~arm64-macos to KEYWORDSSam James2023-04-231-1/+1
| | | | | Bug: https://bugs.gentoo.org/904474 Signed-off-by: Sam James <sam@gentoo.org>
* acct-group.eclass: add ~arm64-macos to KEYWORDSSam James2023-04-231-1/+1
| | | | | Bug: https://bugs.gentoo.org/904474 Signed-off-by: Sam James <sam@gentoo.org>
* distutils-r1.eclass: Detect missing DISTUTILS_EXTMichał Górny2023-04-221-0/+10
| | | | | | | | | Detect when Python packages install extensions and warn about missing DISTUTILS_EXT appropriately. Signed-off-by: Michał Górny <mgorny@gentoo.org> Closes: https://github.com/gentoo/gentoo/pull/30650 Signed-off-by: Michał Górny <mgorny@gentoo.org>
* distutils-r1.eclass: Issue build_ext only w/ DISTUTILS_EXTMichał Górny2023-04-221-6/+11
| | | | | | | | Issue the explicit `build_ext` command call only if `DISTUTILS_EXT` is set. This should avoid a few false positives where the command was called due to irrelevant .c files being present in the source tree. Signed-off-by: Michał Górny <mgorny@gentoo.org>
* distutils-r1.eclass: Support IUSE=debug for DISTUTILS_EXTMichał Górny2023-04-221-0/+7
| | | | | | | Add IUSE=debug when DISTUTILS_EXT is set, and use it to control assertions via appending -DNDEBUG or -UNDEBUG to CPPFLAGS. Signed-off-by: Michał Górny <mgorny@gentoo.org>
* distutils-r1.eclass: Add PYTHON_DEPS to DEPEND when DISTUTILS_EXTMichał Górny2023-04-221-0/+9
| | | | | | | | | | | Add `${PYTHON_DEPS}` to `DEPEND` (i.e. `SYSROOT` dependencies) when building extensions. This is necessary to support cross-compilations correctly. Originally proposed by Raul E Rangel <rrangel@chromium.org>. Closes: https://github.com/gentoo/gentoo/pull/30469 Signed-off-by: Michał Górny <mgorny@gentoo.org>
* distutils-r1.eclass: Add DISTUTILS_EXT control variableMichał Górny2023-04-221-0/+7
| | | | | | | Add a control variable that should be set in ebuilds that build C, Cython, Rust extensions, etc. Signed-off-by: Michał Górny <mgorny@gentoo.org>
* llvm.org.eclass: Add 17.0.0_pre20230421 snapshotMichał Górny2023-04-211-0/+3
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* eclass/tests: partially fix toolchain.eclass testsSam James2023-04-211-20/+21
| | | | | | | | | | - Use the same hack as in crossdev for now wrt EAPI. - Fix up the version tests. We still need to investigate the issues with -march downgrading though. Bug: https://bugs.gentoo.org/859157 Signed-off-by: Sam James <sam@gentoo.org>
* llvm.org.eclass: Enable pregenerated manpages for 16.0.2Michał Górny2023-04-191-1/+1
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* toolchain.eclass: wire up modula-2 frontend support for GCC 13; disable Rust ↵Sam James2023-04-181-1/+8
| | | | | | | | | | | | for 13 - Wire up modula-2 frontend support for GCC 13 as USE=modula2 - Drop Rust for GCC 13, upstream are going to make it fatal for configure for 13.1, but may revisit for 13.2 (not sure how likely that is, though, it depends on how much ends up backported). Rust will be available for GCC 14 though. We will revisit if changes occur, of course. Signed-off-by: Sam James <sam@gentoo.org>
* eclass/elisp.eclass: add elisp_src_testMaciej Barć2023-04-181-1/+15
| | | | | Closes: https://bugs.gentoo.org/898492 Signed-off-by: Maciej Barć <xgqt@gentoo.org>
* eclass/elisp-common.eclass: add elisp-enable-tests and elisp-testMaciej Barć2023-04-181-0/+200
| | | | | Bug: https://bugs.gentoo.org/898492 Signed-off-by: Maciej Barć <xgqt@gentoo.org>
* go-module.eclass: refine go-module_src_unpack eclassdocSam James2023-04-171-4/+5
| | | | | | | Rephrase to make clear that go-module_src_unpack itself isn't actually deprecated, just one of its modes of operation (the one with EGO_SUM). Signed-off-by: Sam James <sam@gentoo.org>
* postgres.eclass: add EAPI 8Sam James2023-04-171-2/+2
| | | | | Closes: https://bugs.gentoo.org/836781 Signed-off-by: Sam James <sam@gentoo.org>
* postgres.eclass: document PG_SLOT, PG_CONFIGSam James2023-04-171-0/+11
| | | | | | | These variables are exported by pkg_setup and are intended for use by ebuilds, as the docs for postgres_pkg_setup say. Signed-off-by: Sam James <sam@gentoo.org>
* postgres.eclass: die if no matching postgresql impl foundSam James2023-04-171-1/+5
| | | | | | | | | | This matches what we do in other eclasses like for python and ruby. It leads to a nicer error if e.g. manually using ebuild(1) rather than emerge(1) and deps aren't satisfied, or forgot to set POSTGRES_TARGETS locally, etc. Signed-off-by: Sam James <sam@gentoo.org>
* llvm.org.eclass: Add 17.0.0_pre20230414 snapshotMichał Górny2023-04-141-0/+3
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* toolchain.eclass: pass improved checking for USE=debug for pre-releases tooSam James2023-04-131-8/+14
| | | | | | Followup to 85db50a7c626a1844c8eb2d03051c8c5d320c205. Signed-off-by: Sam James <sam@gentoo.org>
* toolchain.eclass: enhance USE=debug for more checkingSam James2023-04-131-1/+4
| | | | | | | | | | | We now do --enable-checking=yes,extra,rtl after discussion in #gcc for USE=debug. If rtl is too slow, we can do just yes,etra. We've actually found yet another bug with our general change for snapshots to start using checking, too: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=109506. Signed-off-by: Sam James <sam@gentoo.org>
* qt5-build.eclass: Fix order of patchsets including depending sedAndreas Sturmlechner2023-04-131-11/+13
| | | | | | | - downstream patches are based on top of KDE's patchset - downstream patch affects qmake bootstrapping modifications Signed-off-by: Andreas Sturmlechner <asturm@gentoo.org>
* qt5-build.eclass: Set _QT5_GENTOOPATCHSET_REV=4 for >=Qt5Base-5.15.9Andreas Sturmlechner2023-04-131-3/+3
| | | | Signed-off-by: Andreas Sturmlechner <asturm@gentoo.org>
* llvm.org.eclass: Remove old snapshot hashesMichał Górny2023-04-111-6/+0
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* toolchain.eclass: use upstream default checking for pre/non-released compilersSam James2023-04-101-3/+6
| | | | | | | | | | | | | | Note that this only affects actually-non-released compilers like GCC 13 at this point in time and *not* snapshots from the stable branches. Upstream default to more checking (asserts/runtime integrity checks) when 'gcc/DEV-PHASE' contains 'experimental'. Copy that and defer to the configure.ac default when it does. The practical upshot of this is that we go from --enable-checking=release for GCC 13 to --enable-checking=yes,extra. Signed-off-by: Sam James <sam@gentoo.org>
* ruby-ng.eclass: error out earlier if RUBY is unsetSam James2023-04-101-0/+7
| | | | | | | | | | | | | | | | This might prevent an ebuild installing no files, but the main aim here is to give a better error message earlier on rather than the classic "Unable to generate gemspec file". The output looks like: ``` * Failed to determine a path for ${RUBY} for USE=ruby_targets_ruby31: * ruby_implementation_command returned an empty RUBY for ruby31 * ERROR: dev-ruby/mercenary-0.4.0-r1::gentoo failed (setup phase): * Could not find RUBY for ruby31. Is dev-lang/ruby:3.1 installed? ``` Signed-off-by: Sam James <sam@gentoo.org>
* ruby-fakegem.eclass: include ${PF} in global-scope eqawarnSam James2023-04-081-1/+1
| | | | | | | | This makes it a lot easier to narrow down the culprit given it warns in global scope. (Apparently ${EBUILD} isn't defined in PMS.) Signed-off-by: Sam James <sam@gentoo.org>
* ruby-single.eclass: depend on virtual/rubygems[ruby_targets_rubyNN(-)] for ↵Sam James2023-04-081-3/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | each impl Noticed when looking at bug 771744 which seems hard to trigger deliberately - the webkit-gtk ebuild already tries to check the chosen Ruby has rubygems available. Anyway, when looking at that, I noticed it's possible for Portage to queue the following, even if it's not what's happening in this case: - dev-lang/ruby:2.7 is already installed - virtual/rubygems[ruby_targets_ruby27] is already installed (PDEPEND of ruby) and then, in a fresh emerge: - dev-lang/ruby:3.0 is installed - app-misc/foo (with only USE_RUBY="ruby30") using ruby-single.eclass is queued and fails because the installed Ruby isn't fully usable yet, because the eclass only guarantees dev-lang/ruby:3.0 and virtual/rubygems is installed, not necessarily rubygems for that interpreter. - virtual/rubygems[ruby_targets_ruby30] is built (PDEPEND of ruby) This isn't a substitute for a ruby-any.eclass and/or a pkg_setup which helps enforcement, but that's another thing to handle. Followup to d078ec2a151d16b7ed045f1889bb5b97c4b9e6af ("Add virtual/rubygems to dependencies[...]"). Bug: https://bugs.gentoo.org/771744 Signed-off-by: Sam James <sam@gentoo.org>
* ecm.eclass: Add Qt 5.15.9 to ECM_QTHELP Portage bug workaroundAndreas Sturmlechner2023-04-081-6/+15
| | | | Signed-off-by: Andreas Sturmlechner <asturm@gentoo.org>
* preserve-libs.eclass: add EAPI 8Sam James2023-04-071-3/+3
| | | | | | Trivial changes. Signed-off-by: Sam James <sam@gentoo.org>
* unpacker.eclass: Don't assume the default tar is stdinArsen Arsenović2023-04-061-1/+1
| | | | | | | | | | | | | Despite common misconception, the default GNU tar tarfile is not stdin. On some systems, this can cause tar to fail to extract relevant files. See '(tar)file tutorial' for a description of how the default is picked. Closes: https://bugs.gentoo.org/903631 Closes: https://bugs.gentoo.org/903914 Closes: https://bugs.gentoo.org/903919 Signed-off-by: Arsen Arsenović <arsen@gentoo.org>
* llvm.org.eclass: Enable prebuilt manpages for 16.0.1Michał Górny2023-04-051-1/+1
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* distutils-r1.eclass: Remove < dep on dev-python/setuptoolsMichał Górny2023-04-051-7/+1
| | | | Signed-off-by: Michał Górny <mgorny@gentoo.org>
* qmail.eclass: Patch make-makelib.sh only if it is presentPetr Vaněk2023-04-041-1/+6
| | | | | | | | | | | | | | | Some packages use qmail_set_cc function but they don't contain make-makelib.sh script. However, recent addition of || die to the sed patching this file is newly triggering build failure. This commit addresses the problem by checking if the script is available. Closes: https://bugs.gentoo.org/902009 Closes: https://bugs.gentoo.org/902019 Fixes: fd4e88c55e34 ("qmail.eclass: remove EAPI 6") Closes: https://github.com/gentoo/gentoo/pull/30456 Closes: https://github.com/gentoo/gentoo/pull/30205 Signed-off-by: Petr Vaněk <arkamar@atlas.cz> Signed-off-by: Florian Schmaus <flow@gentoo.org>
* sgml-catalog-r1.eclass: Strip ROOT when generating catalogRaul E Rangel2023-04-041-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | When cross compiling by setting the ROOT variable, the eclass was writing the full EROOT path into the catalog file. This results in an invalid path at runtime. i.e., $ cat /build/amd64-host/etc/sgml/catalog CATALOG "/build/amd64-host/etc/sgml/sgml-docbook.cat" CATALOG "/build/amd64-host/etc/sgml/sgml-ent.cat" CATALOG "/build/amd64-host/etc/sgml/xml-docbook-4.1.2.cat" Instead we should be stripping off the ROOT so we get a valid path: $ cat /build/amd64-host/etc/sgml/catalog CATALOG "/etc/sgml/sgml-docbook.cat" CATALOG "/etc/sgml/sgml-ent.cat" CATALOG "/etc/sgml/xml-docbook-4.1.2.cat" We don't strip EROOT because we want to keep the prefix if it's present. Closes: https://bugs.gentoo.org/903747 Signed-off-by: Raul E Rangel <rrangel@chromium.org> Closes: https://github.com/gentoo/gentoo/pull/30462 Signed-off-by: Michał Górny <mgorny@gentoo.org>
* gnome.org.eclass: Handle GNOME's .alpha/.beta/.rc versioningMatt Turner2023-04-011-2/+2
| | | | | | | | | | | | Tested by removing SRC_URI and S overrides in evince-44_rc.ebuild and glib-networking-2.76_beta.ebuild and confirming that we fetch the same distfile and build from the same source directory. Also confirmed that (alpha|beta|rc).<num> works by making a glib-networking-2.76_beta1.ebuild and seeing that we attempt to fetch glib-networking-2.76.beta.1.tar.xz. Signed-off-by: Matt Turner <mattst88@gentoo.org>
* gnome.org.eclass: Add GNOME_ORG_PV variableMatt Turner2023-04-011-0/+7
| | | | | | | Provides the package version in the format used upstream by GNOME projects. Signed-off-by: Matt Turner <mattst88@gentoo.org>
* gnome.org.eclass: Rename GNOME_ORG_PVP -> GNOME_ORG_RELEASEMatt Turner2023-04-011-4/+4
| | | | | | I don't think PVP stood for anything. Signed-off-by: Matt Turner <mattst88@gentoo.org>
* ruby-ng.eclass: improve error when no valid Ruby in USE_RUBYSam James2023-03-311-1/+6
| | | | | | | | This means we don't get confusing *DEPEND/REQUIRED_USE errors about it being unparseable and instead just get a straightforward die message indicating the problem. Signed-off-by: Sam James <sam@gentoo.org>