From: "Sam James" <sam@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:master commit in: net-analyzer/rrdtool/
Date: Fri, 19 Sep 2025 19:16:32 +0000 (UTC) [thread overview]
Message-ID: <1758309237.3e3bc904ac5d0d0d73b06db44a27bf22de661ea5.sam@gentoo> (raw)
commit: 3e3bc904ac5d0d0d73b06db44a27bf22de661ea5
Author: Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 19 19:13:57 2025 +0000
Commit: Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Sep 19 19:13:57 2025 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3e3bc904
net-analyzer/rrdtool: use PERL_FEATURES
Signed-off-by: Sam James <sam <AT> gentoo.org>
net-analyzer/rrdtool/rrdtool-1.9.0-r3.ebuild | 286 +++++++++++++++++++++++++++
1 file changed, 286 insertions(+)
diff --git a/net-analyzer/rrdtool/rrdtool-1.9.0-r3.ebuild b/net-analyzer/rrdtool/rrdtool-1.9.0-r3.ebuild
new file mode 100644
index 000000000000..ecea3c80fbc7
--- /dev/null
+++ b/net-analyzer/rrdtool/rrdtool-1.9.0-r3.ebuild
@@ -0,0 +1,286 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+LUA_COMPAT=( lua5-{1..4} luajit )
+PYTHON_COMPAT=( python3_{10..13} )
+DISTUTILS_EXT=1
+DISTUTILS_OPTIONAL="true"
+DISTUTILS_USE_PEP517="setuptools"
+GENTOO_DEPEND_ON_PERL="no"
+MY_P="${P/_/-}"
+
+inherit autotools lua perl-module distutils-r1 flag-o-matic
+
+DESCRIPTION="A data logging and graphing system for time series data"
+HOMEPAGE="https://oss.oetiker.ch/rrdtool/"
+# upstream dist doesnt include python tests
+SRC_URI="
+ https://github.com/oetiker/rrdtool-1.x/archive/refs/tags/v${PV}.tar.gz
+ -> ${P}.gh.tar.gz
+"
+S="${WORKDIR}/rrdtool-1.x-${PV}"
+
+LICENSE="GPL-2"
+SLOT="0/8.0.0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux"
+IUSE="dbi doc examples graph lua perl python rados rrdcached rrdcgi ruby static-libs tcl tcpd test ${GENTOO_PERL_USESTRING}"
+
+RESTRICT="!test? ( test )"
+
+# perl? ( graph ) bug #940931
+REQUIRED_USE="
+ perl? ( graph )
+ python? ( ${PYTHON_REQUIRED_USE} )
+ lua? ( ${LUA_REQUIRED_USE} )
+"
+
+PDEPEND="ruby? ( ~dev-ruby/rrdtool-bindings-${PV} )"
+
+RDEPEND="
+ dev-libs/glib:2[static-libs(+)?]
+ dev-libs/libxml2:2=[static-libs(+)?]
+ dbi? ( dev-db/libdbi[static-libs(+)?] )
+ graph? (
+ media-libs/libpng:0=[static-libs(+)?]
+ x11-libs/cairo[svg(+),static-libs(+)?]
+ x11-libs/pango
+ )
+ lua? ( ${LUA_DEPS} )
+ perl? (
+ ${GENTOO_PERL_DEPSTRING}
+ dev-lang/perl:=
+ )
+ python? ( ${PYTHON_DEPS} )
+ rados? ( sys-cluster/ceph )
+ rrdcached? (
+ acct-group/rrdcached
+ acct-user/rrdcached
+ )
+ tcl? ( dev-lang/tcl:0= )
+ tcpd? ( sys-apps/tcp-wrappers )
+"
+
+DEPEND="${RDEPEND}"
+
+BDEPEND="
+ sys-apps/groff
+ virtual/pkgconfig
+ app-alternatives/awk
+ python? (
+ ${DISTUTILS_DEPS}
+ $(python_gen_cond_dep 'dev-python/setuptools[${PYTHON_USEDEP}]')
+ )
+ test? (
+ app-alternatives/bc
+ lua? ( ${LUA_DEPS} )
+ )
+"
+
+PATCHES=(
+ "${FILESDIR}"/${PN}-1.7.0-disable-rrd_graph-cgi.patch
+ "${FILESDIR}"/${PN}-1.7.1-configure.ac.patch
+)
+
+src_prepare() {
+ default
+
+ # Bug #456810
+ local mysedargs=(
+ -e 's|$LUA_CFLAGS|IGNORE_THIS_BAD_TEST|g'
+ -e 's|^sleep 1$||g'
+ -e '/^dnl.*png/s|^dnl||g'
+ -i configure.ac
+ )
+
+ sed "${mysedargs[@]}" || die
+
+ # Python bindings are built and installed manually
+ local mysedargs=(
+ -e '/^all-local:/s| @COMP_PYTHON@||'
+ -i bindings/Makefile.am
+ )
+
+ sed "${mysedargs[@]}" || die
+
+ if ! use graph ; then
+ # Makefile needs to be adjusted for disabling 'graph' feature
+ local mysedargs=(
+ -e '/^TESTS =/,/^$/ {
+ s:rpn[0-9]*::g;
+ s:create-with-source-4::;
+ s:xport1::;
+ s:dcounter1::;
+ s:vformatter1::;
+ s:graph[0-9]*::g;
+ }'
+ -i tests/Makefile.am
+ )
+
+ sed "${mysedargs[@]}" || die
+
+ # Remove graph test from lua
+ sed -i -e '/Testing rrd.graphv/,$ d' bindings/lua/test.lua{,50}.bottom || die
+ fi
+
+ # Makefile needs to be adjusted for disabling 'rrdcached' feature
+ if ! use rrdcached ; then
+ local mysedargs=(
+ -e '/^TESTS =/,/^$/ {
+ s:list1::;
+ }'
+ -i tests/Makefile.am
+ )
+
+ sed "${mysedargs[@]}" || die
+ fi
+
+ eautoreconf
+}
+
+src_configure() {
+ export rd_cv_gcc_flag__Werror=no
+ export rd_cv_ms_async=ok
+ export RRDDOCDIR="${EPREFIX}/usr/share/doc/${PF}"
+
+ # Bug #260380
+ [[ ${CHOST} == *-solaris* ]] && append-flags -D__EXTENSIONS__
+
+ # Enabling '-ffast-math' is known to cause problems.
+ filter-flags -ffast-math
+
+ # We will handle Lua bindings ourselves, upstream is not multi-impl-ready
+ # and their Lua-detection logic depends on having the right version of the Lua
+ # interpreter available at build time.
+ local myeconfargs=(
+ --disable-lua
+ --disable-ruby
+ --disable-ruby-site-install
+ --disable-python
+ $(usex !dbi '--disable-libdbi' '')
+ $(usex !examples '--disable-examples' '')
+ $(use_enable graph rrd_graph)
+ $(use_enable perl perl-site-install)
+ $(use_enable perl)
+ $(usex !rados '--disable-librados' '')
+ $(usex !rrdcached '--disable-rrdcached' '')
+ $(use_enable rrdcgi)
+ $(use_enable static-libs static)
+ $(usex !tcpd '--disable-libwrap' '')
+ $(use_enable tcl)
+ $(use_enable tcl tcl-site)
+ $(use_with tcl tcllib "${EPREFIX}"/usr/$(get_libdir))
+ --with-perl-options="INSTALLDIRS=vendor"
+ )
+
+ econf "${myeconfargs[@]}"
+}
+
+lua_src_compile() {
+ pushd "${BUILD_DIR}"/bindings/lua || die
+
+ # We do need the CMOD-dir path here, otherwise libtool complains.
+ # Use the real one (i.e. not within ${ED}) just in case.
+ local myemakeargs=(
+ LUA_CFLAGS="$(lua_get_CFLAGS)"
+ LUA_INSTALL_CMOD="$(lua_get_cmod_dir)"
+ )
+
+ emake "${myemakeargs[@]}"
+
+ popd || die
+}
+
+python_compile() {
+ cd bindings/python || die
+ distutils-r1_python_compile
+}
+
+src_compile() {
+ default
+
+ # Only copy sources now so that we do not
+ # trigger librrd compilation multiple times.
+ if use lua; then
+ lua_copy_sources
+ lua_foreach_impl lua_src_compile
+ fi
+
+ use python && distutils-r1_src_compile
+}
+
+lua_src_test() {
+ pushd "${BUILD_DIR}"/bindings/lua || die
+ LUA_CPATH="${PWD}/.libs/?.so" emake LUA="${LUA}" test
+ popd || die
+}
+
+python_test() {
+ LD_LIBRARY_PATH="${S}/src/.libs:${LD_LIBRARY_PATH}" eunittest
+}
+
+src_test() {
+ export LC_ALL=C
+ default
+
+ if use lua; then
+ lua_foreach_impl lua_src_test
+ fi
+
+ if use perl; then
+ pushd bindings/perl-shared >/dev/null || die
+ LD_LIBRARY_PATH="${S}/src/.libs:${LD_LIBRARY_PATH}" perl-module_src_test
+ popd >/dev/null || die
+ pushd bindings/perl-piped >/dev/null || die
+ LD_LIBRARY_PATH="${S}/src/.libs:${LD_LIBRARY_PATH}" perl-module_src_test
+ popd >/dev/null || die
+ fi
+
+ if use python && use graph ; then
+ # All tests explicitly use graph
+ pushd bindings/python >/dev/null || die
+ distutils-r1_src_test
+ popd >/dev/null || die
+ fi
+}
+
+lua_src_install() {
+ pushd "${BUILD_DIR}"/bindings/lua || die
+
+ # This time we must prefix the CMOD-dir path with ${ED},
+ # so that make does not try to violate the sandbox.
+ local myemakeargs=(
+ LUA_INSTALL_CMOD="${ED}/$(lua_get_cmod_dir)"
+ )
+
+ emake "${myemakeargs[@]}" install
+
+ popd || die
+}
+
+src_install() {
+ default
+
+ if ! use doc; then
+ rm -rf "${ED}"/usr/share/doc/"${PF}"/{html,txt} || die
+ fi
+
+ if use lua; then
+ lua_foreach_impl lua_src_install
+ fi
+
+ if use perl; then
+ perl_delete_localpod
+ perl_delete_packlist
+ fi
+
+ use python && distutils-r1_src_install
+
+ if use rrdcached; then
+ newconfd "${FILESDIR}"/rrdcached.confd-r1 rrdcached
+ newinitd "${FILESDIR}"/rrdcached.init-r1 rrdcached
+ fi
+
+ find "${ED}" -name '*.la' -delete || die
+}
next reply other threads:[~2025-09-19 19:16 UTC|newest]
Thread overview: 95+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-19 19:16 Sam James [this message]
-- strict thread matches above, loose matches on Subject: below --
2025-04-03 22:25 [gentoo-commits] repo/gentoo:master commit in: net-analyzer/rrdtool/ Sam James
2025-04-03 16:52 Arthur Zamarin
2025-04-03 2:42 Sam James
2025-04-03 2:42 Sam James
2025-04-03 2:42 Sam James
2025-04-03 2:42 Sam James
2025-04-03 2:42 Sam James
2025-03-30 16:44 Viorel Munteanu
2025-03-01 1:14 Conrad Kostecki
2024-09-17 16:00 Sam James
2024-09-17 16:00 Sam James
2024-08-11 14:22 Conrad Kostecki
2024-01-08 9:48 Sam James
2024-01-05 21:48 Conrad Kostecki
2024-01-02 17:58 Conrad Kostecki
2022-11-29 15:58 WANG Xuerui
2022-11-03 23:38 Conrad Kostecki
2022-11-03 23:15 Conrad Kostecki
2022-11-03 22:37 Conrad Kostecki
2022-10-08 0:23 Conrad Kostecki
2022-09-06 9:16 David Seifert
2022-05-28 15:55 Jakov Smolić
2022-05-06 11:34 Jakov Smolić
2022-05-06 11:34 Jakov Smolić
2022-05-06 11:34 Jakov Smolić
2022-05-06 11:34 Jakov Smolić
2022-05-06 11:29 Jakov Smolić
2022-05-06 8:09 Arthur Zamarin
2022-04-05 20:41 Conrad Kostecki
2022-04-05 19:34 Conrad Kostecki
2022-04-04 22:33 Conrad Kostecki
2021-03-16 0:10 Sam James
2021-03-16 0:10 Sam James
2021-03-16 0:06 Sam James
2021-03-16 0:06 Sam James
2021-02-15 2:19 Rick Farina
2021-01-24 3:52 Sam James
2021-01-23 22:51 Sam James
2021-01-23 22:51 Sam James
2021-01-23 22:42 Sam James
2021-01-23 4:20 Sam James
2021-01-23 4:09 Sam James
2021-01-06 14:35 Fabian Groffen
2020-12-15 2:37 Matt Turner
2020-12-09 0:53 Marek Szuba
2020-12-07 23:05 Marek Szuba
2020-08-06 6:47 Sergei Trofimovich
2020-08-05 9:28 Jeroen Roovers
2020-08-03 16:34 Sergei Trofimovich
2020-07-18 0:29 Sam James
2020-07-08 10:59 Michał Górny
2020-07-08 10:59 Michał Górny
2020-07-05 8:52 Sergei Trofimovich
2020-07-05 8:47 Sergei Trofimovich
2020-07-01 17:59 Jeroen Roovers
2020-07-01 16:54 Jeroen Roovers
2020-07-01 16:54 Jeroen Roovers
2020-06-28 20:56 Thomas Deutschmann
2020-06-27 20:41 Mart Raudsepp
2020-05-07 15:17 Michał Górny
2020-04-25 11:29 Jeroen Roovers
2020-04-25 10:42 Jeroen Roovers
2019-09-14 8:40 Jeroen Roovers
2019-05-28 12:08 Jeroen Roovers
2019-04-27 22:56 Aaron Bauman
2019-03-03 11:49 Mikle Kolyada
2018-06-26 19:21 Pacho Ramos
2018-03-24 12:44 Jeroen Roovers
2018-01-05 19:40 Mikle Kolyada
2017-12-20 22:04 Sergei Trofimovich
2017-12-01 7:32 Sergei Trofimovich
2017-12-01 7:32 Sergei Trofimovich
2017-12-01 7:32 Sergei Trofimovich
2017-06-19 20:07 Alexis Ballier
2017-06-06 8:25 Sergei Trofimovich
2017-06-06 8:25 Sergei Trofimovich
2017-05-26 7:57 Jeroen Roovers
2017-04-23 11:29 David Seifert
2017-03-01 7:55 Michael Weber
2017-02-18 8:51 Jeroen Roovers
2017-01-29 19:33 Fabian Groffen
2016-12-21 18:39 Thomas Deutschmann
2016-10-22 11:50 Tobias Klausmann
2016-10-22 8:38 Jeroen Roovers
2016-04-24 19:45 Jeroen Roovers
2016-02-15 19:52 Tobias Klausmann
2016-02-05 12:49 Tobias Klausmann
2015-12-26 12:07 Jeroen Roovers
2015-12-26 12:07 Jeroen Roovers
2015-12-26 10:14 Jeroen Roovers
2015-12-14 14:12 Agostino Sarubbo
2015-09-23 6:54 Jeroen Roovers
2015-09-23 6:04 Jeroen Roovers
2015-09-23 4:18 Jeroen Roovers
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1758309237.3e3bc904ac5d0d0d73b06db44a27bf22de661ea5.sam@gentoo \
--to=sam@gentoo.org \
--cc=gentoo-commits@lists.gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox