On Mon, 2014-03-10 at 01:45 -0400, Alexandre Rostovtsev wrote:
> On Sun, 2014-03-09 at 23:22 -0400, Joshua Kinard wrote:
> > On 03/08/2014 9:55 PM, Alexandre Rostovtsev wrote:
> > > On Sat, 2014-03-08 at 21:23 -0500, Joshua Kinard wrote:
> > >> So I want to try and play around with a particular network domination 
> > >> tool
> > >> on my home network, Omphalos.  However, its current configure script has 
> > >> a
> > >> hard dependency on bluetooth.h, part of the net-wireless/bluez package.
> > >>
> > >> Currently, net-wireless/bluez has a harddep on virtual/udev, which works
> > >> great if you use either udev or eudev.  I'm using busybox's mdev 
> > >> instead, so
> > >> the logic of the bluez ebuild needs some changes:
> > > [...]
> > >> Thoughts on this?
> > > 
> > > Does mdev have any API which is equivalent to libudev's hwdb? See
> > > http://www.freedesktop.org/software/systemd/libudev/libudev-udev-hwdb.html
> > > 
> > > If yes, then optimal solution would be to patch bluez to allow using
> > > mdev's hwdb support, and get the patch upstreamed :)
> > 
> > It's actually not a matter of the hwdb support, it's just the fact that
> > bluez currently has a harddep on a specific device manager, either udev or
> > eudev.
> 
> Bluez does not require an abstract device manager. It requires the
> libudev library. Or rather, it requires some kind of library which
> provides the following API:
> 
> 1. querying hwdb (given a kernel modalias for a device, retrieve
> corresponding oui, vendor, and model data); and
> 2. querying the device tree (manually traversing /sys is of course
> possible, but not very easy to do correctly, so bluez developers are
> relying on libudev).

And by "requires", I mean that without libudev, a variety of bluetooth
devices and adapters will simply fail to work.

So if mdev does not have some equivalent of libudev, a reasonable
solution would probably be the following:

@@ -14,19 +14,19 @@
 LICENSE="GPL-2+ LGPL-2.1+"
 SLOT="0/3"
 KEYWORDS="~amd64 ~arm ~hppa ~ppc ~ppc64 ~x86"
-IUSE="cups debug +obex readline selinux systemd test"
+IUSE="cups debug +obex readline selinux systemd test +udev"
 REQUIRED_USE="test? ( ${PYTHON_REQUIRED_USE} )"
 
 RDEPEND="
        >=dev-libs/glib-2.28:2
        >=sys-apps/dbus-1.6:=
        >=sys-apps/hwids-20121202.2
-       >=virtual/udev-171
        cups? ( net-print/cups:= )
        obex? ( dev-libs/libical )
        readline? ( sys-libs/readline:= )
        selinux? ( sec-policy/selinux-bluetooth )
        systemd? ( sys-apps/systemd )
+       udev? ( >=virtual/udev-171 )
 "
 DEPEND="${RDEPEND}
        virtual/pkgconfig
@@ -46,6 +46,11 @@
 pkg_setup() {
        enewgroup plugdev
        use test && python-any-r1_pkg_setup
+
+       if ! use udev; then
+               ewarn "You are installing ${P} with USE=-udev. This means 
various bluetooth"
+               ewarn "devices and adapters from Apple, Dell, Logitech etc. 
will fail to work."
+       fi
 }
 
 src_prepare() {
@@ -92,13 +97,13 @@
                $(use_enable test) \
                --enable-tools \
                --enable-monitor \
-               --enable-udev \
+               $(use_enable udev) \
                $(use_enable cups) \
                $(use_enable obex) \
                --enable-client \
                $(use_enable systemd) \
                $(systemd_with_unitdir) \
-               --enable-sixaxis
+               $(use_enable udev sixaxis)
 }
 
 src_install() {
@@ -134,7 +139,7 @@
 pkg_postinst() {
        readme.gentoo_print_elog
 
-       udev_reload
+       use udev && udev_reload
 
        has_version net-dialup/ppp || elog "To use dial up networking you must 
install net-dialup/ppp."
 


Reply via email to