diff options
| author | Patrick McLean <chutzpah@gentoo.org> | 2025-05-08 12:14:27 -0700 |
|---|---|---|
| committer | Patrick McLean <chutzpah@gentoo.org> | 2025-05-08 12:15:47 -0700 |
| commit | 2d3ef0372cce3fef09c7b7374c7e26312accd3a9 (patch) | |
| tree | 6e8346869a38677130beb311d3230edf936079cd /dev-lang/jsonnet/jsonnet-0.21.0.ebuild | |
| parent | d79a0a6a6c3f36a5fcd597fe7ffb38b926e1324f (diff) | |
| download | gentoo-2d3ef0372cce3fef09c7b7374c7e26312accd3a9.tar.gz gentoo-2d3ef0372cce3fef09c7b7374c7e26312accd3a9.tar.bz2 gentoo-2d3ef0372cce3fef09c7b7374c7e26312accd3a9.zip | |
dev-lang/jsonnet: add 0.21.0
Closes: https://bugs.gentoo.org/952297
Bug: https://bugs.gentoo.org/955391
Signed-off-by: Patrick McLean <chutzpah@gentoo.org>
Diffstat (limited to 'dev-lang/jsonnet/jsonnet-0.21.0.ebuild')
| -rw-r--r-- | dev-lang/jsonnet/jsonnet-0.21.0.ebuild | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/dev-lang/jsonnet/jsonnet-0.21.0.ebuild b/dev-lang/jsonnet/jsonnet-0.21.0.ebuild new file mode 100644 index 000000000000..adefc9418b4d --- /dev/null +++ b/dev-lang/jsonnet/jsonnet-0.21.0.ebuild @@ -0,0 +1,106 @@ +# Copyright 1999-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +DISTUTILS_OPTIONAL=1 +DISTUTILS_USE_PEP517=setuptools +DISTUTILS_EXT=1 +PYTHON_COMPAT=( pypy3 pypy3_11 python3_{10..13} python3_13t ) + +inherit cmake toolchain-funcs flag-o-matic distutils-r1 + +DESCRIPTION="A data templating language for app and tool developers" +HOMEPAGE="https://jsonnet.org/" +SRC_URI="https://github.com/google/jsonnet/archive/v${PV}.tar.gz -> ${P}.tar.gz" + +LICENSE="Apache-2.0" +SLOT="0" +KEYWORDS="~amd64 ~arm64 ~ppc64 ~riscv ~x86" +IUSE="custom-optimization doc examples python test" + +RDEPEND=" + dev-cpp/nlohmann_json:= + python? ( ${PYTHON_DEPS} ) +" + +DEPEND=" + ${RDEPEND} + test? ( dev-cpp/gtest ) +" + +BDEPEND=" + python? ( + ${PYTHON_DEPS} + ${DISTUTILS_DEPS} + >=dev-python/setuptools-72.2[${PYTHON_USEDEP}] + ) +" +RESTRICT="!test? ( test )" + +REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )" + +PATCHES=( + "${FILESDIR}/jsonnet-0.16.0-libdir.patch" + "${FILESDIR}/jsonnet-0.16.0-cp-var.patch" +) + +distutils_enable_tests unittest + +src_prepare() { + cmake_src_prepare + use python && distutils-r1_src_prepare +} + +src_configure() { + use custom-optimization || replace-flags '-O*' -O3 + tc-export CC CXX + + local mycmakeargs=( + -DUSE_SYSTEM_JSON=ON + -DBUILD_STATIC_LIBS=OFF + ) + + if use test; then + mycmakeargs+=( + -DBUILD_TESTS=ON + -DUSE_SYSTEM_GTEST=ON + ) + else + mycmakeargs+=( + -DBUILD_TESTS=OFF + ) + fi + + cmake_src_configure +} + +src_compile() { + cmake_src_compile + use python && CMAKE_BUILD_DIR="${BUILD_DIR}" distutils-r1_src_compile +} + +src_test() { + cmake_src_test + use python && CMAKE_BUILD_DIR="${BUILD_DIR}" distutils-r1_src_test +} + +python_test() { + LD_LIBRARY_PATH="${CMAKE_BUILD_DIR}" "${EPYTHON}" -m unittest python._jsonnet_test -v \ + || die "Tests failed with ${EPYTHON}" +} + +src_install() { + cmake_src_install + use python && distutils-r1_src_install + + if use doc; then + find doc -name '.gitignore' -delete || die + docinto html + dodoc -r doc/. + fi + if use examples; then + docinto examples + dodoc -r examples/. + fi +} |
