Robin H. Johnson wrote:
Heya,

So now this is not a flamewar.

Jakub was originally going to complain at me for the upstream usbutils
adding support for gzipped usb.ids files, but a group of us (myself,
dsd, jakub, leio, steev) had a discussion about it, and came up with a
solution that both ends the breakage for direct users (HAL and others),
and provides forward momentum.

So firstly, what's the real problem? The original complaint came up
because HAL expected the uncompressed file to exist as pci.ids, and
wasn't ready to look at pci.ids.gz. While this caused breakage, it was
only a warning sign that there was a deeper problem.

I don't feel strongly enough to make an objection to your commit, but I think pciutils is doing the right thing, and despite me and Mike putting a hours into getting a decent HAL patch together the response I got was that as upstream they are simply "not interested" (no technical or logical objections provided), so I don't feel you should be putting workarounds in pciutils just to make HAL happy.

Especially because HAL really doesn't use pci.ids for anything useful. I am attaching a HAL ebuild patch which is the approach I'm in favour of and first mentioned several months ago. It does not require any HAL patches or pciutils modifications. It stems from the fact that really HAL doesn't really do anything useful with the ID-to-name mappings provided in pci.ids. It makes "that HAL bug" disappear with the click of the fingers. I didn't really get any proper answer why our HAL maintainers weren't keen on this when I first mentioned it.

Daniel
--- hal-0.5.9-r1.ebuild.orig    2007-10-31 10:34:34.000000000 +0000
+++ hal-0.5.9-r1.ebuild 2007-10-31 10:46:15.000000000 +0000
@@ -80,13 +80,6 @@ function notify_inotify() {
 }
 
 pkg_setup() {
-       if ! built_with_use --missing false sys-apps/pciutils hal ; then
-               if built_with_use --missing false sys-apps/pciutils zlib ; then
-                       eerror "You MUST build sys-apps/pciutils without the 
zlib USE flag"
-                       die "You MUST build sys-apps/pciutils without the zlib 
USE flag"
-               fi
-       fi
-
        if use kernel_linux; then
                kernel_is ge 2 6 17 || ewarn "HAL requires a kernel version 
2.6.17 or newer"
 
@@ -147,6 +140,7 @@ src_unpack() {
 src_compile() {
        local backend=""
        local acpi=""
+       local myconf=""
 
        # TODO :: policykit should have a pam useflag
        append-flags -rdynamic
@@ -164,6 +158,15 @@ src_compile() {
                acpi="--disable-acpi-proc --disable-acpi-acpid"
        fi
 
+       if [[ ! -e "${ROOT}"/usr/share/misc/pci.ids ]]; then
+               myconf="--disable-pci-ids"
+               elog "It looks like you've built pciutils with the zlib USE 
flag"
+               elog "meaning that your /usr/share/misc/pci.ids file is 
compressed"
+               elog "and incompatible with HAL. You almost certainly won't 
notice "
+               elog "any feature loss here, but if you do, just re-emerge 
pciutils "
+               elog "without the zlib flag, then re-emerge hal."
+       fi
+
        econf --disable-policy-kit \
                  --docdir=/usr/share/doc/${PF} \
                  --with-os-type=gentoo \
@@ -182,6 +185,7 @@ src_compile() {
                  $(use_enable selinux) \
                  --disable-console-kit \
                  ${acpi} \
+                 $myconf \
        || die "configure failed"
 #$(use_enable pam console-kit)
 

Reply via email to