diff options
author | Sam James <sam@gentoo.org> | 2024-01-05 09:11:36 +0000 |
---|---|---|
committer | Sam James <sam@gentoo.org> | 2024-01-05 09:37:19 +0000 |
commit | aac64dad7bd5e8e6fcc4e63baff0f54807712280 (patch) | |
tree | 8af63eaaace5c634c09ddc4809c9f8d97b952151 /dev-util/ninja | |
parent | app-emacs/ninja-mode: new package split out from dev-util/ninja[emacs], add 1... (diff) | |
download | gentoo-aac64dad7bd5e8e6fcc4e63baff0f54807712280.tar.gz gentoo-aac64dad7bd5e8e6fcc4e63baff0f54807712280.tar.bz2 gentoo-aac64dad7bd5e8e6fcc4e63baff0f54807712280.zip |
dev-util/ninja: move Emacs files to app-emacs/ninja-mode
Bug: https://bugs.gentoo.org/921333
Signed-off-by: Sam James <sam@gentoo.org>
Diffstat (limited to 'dev-util/ninja')
-rw-r--r-- | dev-util/ninja/ninja-1.11.1-r4.ebuild | 118 | ||||
-rw-r--r-- | dev-util/ninja/ninja-9999.ebuild | 25 |
2 files changed, 124 insertions, 19 deletions
diff --git a/dev-util/ninja/ninja-1.11.1-r4.ebuild b/dev-util/ninja/ninja-1.11.1-r4.ebuild new file mode 100644 index 000000000000..e76fd4222cba --- /dev/null +++ b/dev-util/ninja/ninja-1.11.1-r4.ebuild @@ -0,0 +1,118 @@ +# Copyright 2012-2024 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +PYTHON_COMPAT=( python3_{10..12} ) + +inherit edo bash-completion-r1 flag-o-matic python-any-r1 toolchain-funcs + +if [[ ${PV} == 9999 ]]; then + EGIT_REPO_URI="https://github.com/ninja-build/ninja.git" + inherit git-r3 +else + SRC_URI="https://github.com/ninja-build/${PN}/archive/v${PV}.tar.gz -> ${P}.tar.gz" + KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos ~x64-macos ~x64-solaris" +fi + +DESCRIPTION="A small build system similar to make" +HOMEPAGE="https://ninja-build.org/" + +LICENSE="Apache-2.0" +SLOT="0" +IUSE="doc emacs test" +RESTRICT="!test? ( test )" + +BDEPEND=" + ${PYTHON_DEPS} + dev-util/re2c + doc? ( + app-text/asciidoc + app-doc/doxygen + dev-libs/libxslt + media-gfx/graphviz + ) + test? ( dev-cpp/gtest ) +" +PDEPEND=" + app-alternatives/ninja + emacs? ( app-emacs/ninja-mode ) +" + +PATCHES=( + "${FILESDIR}"/ninja-cflags.patch +) + +run_for_build() { + if tc-is-cross-compiler; then + local -x AR=$(tc-getBUILD_AR) + local -x CXX=$(tc-getBUILD_CXX) + local -x CFLAGS= + local -x CXXFLAGS=${BUILD_CXXFLAGS} + local -x LDFLAGS=${BUILD_LDFLAGS} + fi + echo "$@" >&2 + "$@" +} + +src_compile() { + tc-export AR CXX + + # configure.py appends CFLAGS to CXXFLAGS + unset CFLAGS + + append-lfs-flags + + run_for_build ${EPYTHON} configure.py --bootstrap --verbose || die + + if tc-is-cross-compiler; then + mv ninja ninja-build || die + ${EPYTHON} configure.py || die + ./ninja-build -v ninja || die + else + ln ninja ninja-build || die + fi + + if use doc; then + ./ninja-build -v doxygen manual || die + fi +} + +src_test() { + if ! tc-is-cross-compiler; then + # Bug 485772 + ulimit -n 2048 + edo ./ninja -v ninja_test + edo ./ninja_test + fi +} + +src_install() { + dodoc README.md CONTRIBUTING.md + + if use doc; then + docinto html + dodoc -r doc/doxygen/html/. + dodoc doc/manual.html + fi + + newbin ninja ninja-reference + + newbashcomp misc/bash-completion ${PN} + + insinto /usr/share/vim/vimfiles/syntax/ + doins misc/ninja.vim + + echo 'au BufNewFile,BufRead *.ninja set ft=ninja' > "${T}"/ninja.vim || die + insinto /usr/share/vim/vimfiles/ftdetect + doins "${T}"/ninja.vim + + insinto /usr/share/zsh/site-functions + newins misc/zsh-completion _ninja +} + +pkg_postinst() { + if ! [[ -e "${EROOT}/usr/bin/ninja" ]]; then + ln -s ninja-reference "${EROOT}/usr/bin/ninja" || die + fi +} diff --git a/dev-util/ninja/ninja-9999.ebuild b/dev-util/ninja/ninja-9999.ebuild index c4874b6be066..e76fd4222cba 100644 --- a/dev-util/ninja/ninja-9999.ebuild +++ b/dev-util/ninja/ninja-9999.ebuild @@ -1,11 +1,11 @@ -# Copyright 2012-2023 Gentoo Authors +# Copyright 2012-2024 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=8 PYTHON_COMPAT=( python3_{10..12} ) -inherit edo bash-completion-r1 elisp-common flag-o-matic python-any-r1 toolchain-funcs +inherit edo bash-completion-r1 flag-o-matic python-any-r1 toolchain-funcs if [[ ${PV} == 9999 ]]; then EGIT_REPO_URI="https://github.com/ninja-build/ninja.git" @@ -20,7 +20,6 @@ HOMEPAGE="https://ninja-build.org/" LICENSE="Apache-2.0" SLOT="0" - IUSE="doc emacs test" RESTRICT="!test? ( test )" @@ -35,8 +34,10 @@ BDEPEND=" ) test? ( dev-cpp/gtest ) " -RDEPEND="emacs? ( >=app-editors/emacs-23.1:* )" -PDEPEND="app-alternatives/ninja" +PDEPEND=" + app-alternatives/ninja + emacs? ( app-emacs/ninja-mode ) +" PATCHES=( "${FILESDIR}"/ninja-cflags.patch @@ -75,10 +76,6 @@ src_compile() { if use doc; then ./ninja-build -v doxygen manual || die fi - - if use emacs; then - elisp-compile misc/ninja-mode.el || die - fi } src_test() { @@ -112,20 +109,10 @@ src_install() { insinto /usr/share/zsh/site-functions newins misc/zsh-completion _ninja - - if use emacs; then - cd misc || die - elisp-install ninja ninja-mode.el* || die - fi } pkg_postinst() { - use emacs && elisp-site-regen if ! [[ -e "${EROOT}/usr/bin/ninja" ]]; then ln -s ninja-reference "${EROOT}/usr/bin/ninja" || die fi } - -pkg_postrm() { - use emacs && elisp-site-regen -} |