summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys-block/nbd/files/nbd-3.17-automagic.patch84
-rw-r--r--sys-block/nbd/metadata.xml3
-rw-r--r--sys-block/nbd/nbd-9999.ebuild65
3 files changed, 152 insertions, 0 deletions
diff --git a/sys-block/nbd/files/nbd-3.17-automagic.patch b/sys-block/nbd/files/nbd-3.17-automagic.patch
new file mode 100644
index 000000000000..4ece53596da4
--- /dev/null
+++ b/sys-block/nbd/files/nbd-3.17-automagic.patch
@@ -0,0 +1,84 @@
+From 55c225b53c24b0ae93f49d5f004291da8c265870 Mon Sep 17 00:00:00 2001
+From: Lars Wendler <polynomial-c@gentoo.org>
+Date: Mon, 9 Apr 2018 11:26:06 +0200
+Subject: [PATCH] Don't make gnutls and libnl automagic
+
+Introduce --without-gnutls and --without-libnl configure options so that
+users can disable gnutls/libnl even if the packages are available on the
+system. The default is unchanged from before this patch. If no
+--with(out)-* option has been given on the command line, the macro looks
+for presence and uses the packages if found.
+---
+ configure.ac | 47 ++++++++++++++++++++++++++++++++++++++---------
+ 1 file changed, 38 insertions(+), 9 deletions(-)
+
+diff --git a/configure.ac b/configure.ac
+index cdb4af3..4b76007 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -212,10 +212,25 @@ dnl ;;
+ dnl esac
+ dnl fi
+
+-PKG_CHECK_MODULES(GnuTLS, [gnutls >= 2.12.0],[HAVE_GNUTLS=1],[HAVE_GNUTLS=0])
+-if test x$HAVE_GNUTLS = x1; then
+- AC_DEFINE(HAVE_GNUTLS, 1, [Define to 1 if you have a GnuTLS version of 2.12 or above])
++AC_ARG_WITH([gnutls],
++ [AS_HELP_STRING([--without-gnutls],
++ [do not use gnutls])],
++ [],
++ [with_gnutls=check]
++)
++if test "x$with_gnutls" != "xno"; then
++ PKG_CHECK_MODULES(GnuTLS, [gnutls >= 2.12.0],
++ [HAVE_GNUTLS=1
++ AC_DEFINE(HAVE_GNUTLS, 1, [Define to 1 if you have a GnuTLS version of 2.12 or above])],
++ [if test "x$with_gnutls" = "xyes"; then
++ AC_MSG_ERROR([--with-gnutls given but cannot find gnutls])
++ else
++ HAVE_GNUTLS=0
++ AC_DEFINE(HAVE_GNUTLS, 0)
++ fi]
++ )
+ else
++ HAVE_GNUTLS=0
+ AC_DEFINE(HAVE_GNUTLS, 0)
+ fi
+ AM_CONDITIONAL([GNUTLS], [test "x$HAVE_GNUTLS" = "x1"])
+@@ -294,13 +309,27 @@ AC_PREPROC_IFELSE(
+ [AC_MSG_RESULT([yes]); NEED_BSD_SOURCE=1])
+ AC_DEFINE([NEED_BSD_SOURCE], $NEED_BSD_SOURCE, [Define to 1 if _BSD_SOURCE needs to be defined before certain inclusions])
+
+-PKG_CHECK_MODULES(LIBNL3, libnl-genl-3.0 >= 3.1, [have_libnl3=yes], [have_libnl3=no])
+-if test "${have_libnl3}" = "yes"
+-then
+- AC_DEFINE(HAVE_NETLINK, 1, [Define to 1 if we have netlink support])
+- CFLAGS+=" $LIBNL3_CFLAGS"
+- LIBS+=" $LIBNL3_LIBS"
++AC_ARG_WITH([libnl],
++ [AS_HELP_STRING([--without-libnl],
++ [do not use libnl])],
++ [],
++ [with_libnl=check]
++)
++if test "x$with_libnl" != "xno"; then
++ PKG_CHECK_MODULES(LIBNL3, libnl-genl-3.0 >= 3.1,
++ [HAVE_NETLINK=1
++ AC_DEFINE(HAVE_NETLINK, 1, [Define to 1 if we have netlink support])
++ CFLAGS+=" $LIBNL3_CFLAGS"
++ LIBS+=" $LIBNL3_LIBS"],
++ [if test "x$with_libnl" = "xyes"; then
++ AC_MSG_ERROR([--with-libnl given but cannot find libnl])
++ else
++ HAVE_NETLINK=0
++ AC_DEFINE(HAVE_NETLINK, 0)
++ fi]
++ )
+ else
++ HAVE_NETLINK=0
+ AC_DEFINE(HAVE_NETLINK, 0, [Define to 1 if we have netlink support])
+ fi
+
+--
+2.17.0
+
diff --git a/sys-block/nbd/metadata.xml b/sys-block/nbd/metadata.xml
index f583809ec477..e233f07bc3f4 100644
--- a/sys-block/nbd/metadata.xml
+++ b/sys-block/nbd/metadata.xml
@@ -5,6 +5,9 @@
<email>base-system@gentoo.org</email>
<name>Gentoo Base System</name>
</maintainer>
+<use>
+ <flag name="netlink">Add support for netlink protocol via <pkg>dev-libs/libnl</pkg></flag>
+</use>
<upstream>
<remote-id type="sourceforge">nbd</remote-id>
</upstream>
diff --git a/sys-block/nbd/nbd-9999.ebuild b/sys-block/nbd/nbd-9999.ebuild
new file mode 100644
index 000000000000..1117affd0207
--- /dev/null
+++ b/sys-block/nbd/nbd-9999.ebuild
@@ -0,0 +1,65 @@
+# Copyright 1999-2018 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+DESCRIPTION="Userland client/server for kernel network block device"
+HOMEPAGE="http://nbd.sourceforge.net/"
+if [[ "${PV}" = 9999 ]] ; then
+ inherit autotools git-r3
+ EGIT_REPO_URI="https://github.com/NetworkBlockDevice/nbd.git"
+else
+ SRC_URI="mirror://sourceforge/nbd/${P}.tar.xz"
+ KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86"
+fi
+LICENSE="GPL-2"
+SLOT="0"
+IUSE="debug gnutls netlink zlib"
+
+# gnutls is an automagic dep.
+RDEPEND="
+ >=dev-libs/glib-2.26.0
+ gnutls? ( >=net-libs/gnutls-2.12.0 )
+ netlink? ( >=dev-libs/libnl-3.1 )
+ zlib? ( sys-libs/zlib )
+"
+DEPEND="${RDEPEND}
+ virtual/pkgconfig
+"
+
+if [[ "${PV}" = 9999 ]] ; then
+ DEPEND+="
+ app-text/docbook-sgml-dtd:4.5
+ app-text/docbook-sgml-utils
+ "
+fi
+
+PATCHES=(
+ "${FILESDIR}/${PN}-3.17-automagic.patch"
+)
+
+src_prepare() {
+ default
+ if [[ "${PV}" = 9999 ]] ; then
+ emake -C man -f Makefile.am \
+ nbd-server.1.sh.in \
+ nbd-server.5.sh.in \
+ nbd-client.8.sh.in \
+ nbd-trdump.1.sh.in \
+ nbdtab.5.sh.in
+ emake -C systemd -f Makefile.am nbd@.service.sh.in
+ eautoreconf
+ fi
+}
+
+src_configure() {
+ local myeconfargs=(
+ --enable-lfs
+ $(use_enable !debug syslog)
+ $(use_enable debug)
+ $(use_enable zlib gznbd)
+ $(use_with gnutls)
+ $(use_with netlink libnl)
+ )
+ econf "${myeconfargs[@]}"
+}