commit:     5ad71de752224d90f6368bd20d030075a55f9fd6
Author:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 24 13:47:26 2016 +0000
Commit:     Anthony G. Basile <blueness <AT> gentoo <DOT> org>
CommitDate: Fri Jun 24 13:47:26 2016 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5ad71de7

sys-fs/eudev: add live ebuild for testing eudev-4 branch

Package-Manager: portage-2.2.28

 sys-fs/eudev/eudev-4.9999.ebuild | 226 +++++++++++++++++++++++++++++++++++++++
 sys-fs/eudev/metadata.xml        |   3 +
 2 files changed, 229 insertions(+)

diff --git a/sys-fs/eudev/eudev-4.9999.ebuild b/sys-fs/eudev/eudev-4.9999.ebuild
new file mode 100644
index 0000000..fc9ab64
--- /dev/null
+++ b/sys-fs/eudev/eudev-4.9999.ebuild
@@ -0,0 +1,226 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI="5"
+
+KV_min=2.6.39
+
+inherit autotools eutils linux-info multilib multilib-minimal user
+
+if [[ ${PV} = 4.9999* ]]; then
+       EGIT_REPO_URI="git://github.com/gentoo/eudev.git"
+       EGIT_BRANCH="eudev-4"
+       inherit git-r3
+else
+       SRC_URI="https://dev.gentoo.org/~blueness/${PN}/${P}.tar.gz";
+       #KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 
~sparc ~x86"
+       KEYWORDS=""
+fi
+
+DESCRIPTION="Linux dynamic and persistent device naming support (aka userspace 
devfs)"
+HOMEPAGE="https://github.com/gentoo/eudev";
+
+LICENSE="LGPL-2.1 GPL-2"
+SLOT="0"
+IUSE="+blkid efi +hwdb +kmod selinux smack test"
+
+COMMON_DEPEND=">=sys-apps/util-linux-2.20
+       kmod? ( >=sys-apps/kmod-16 )
+       selinux? ( >=sys-libs/libselinux-2.1.9 )
+       !<sys-libs/glibc-2.11
+       !sys-apps/gentoo-systemd-integration
+       !sys-apps/systemd
+       abi_x86_32? (
+               !<=app-emulation/emul-linux-x86-baselibs-20130224-r7
+               !app-emulation/emul-linux-x86-baselibs[-abi_x86_32(-)]
+       )"
+DEPEND="${COMMON_DEPEND}
+       dev-util/gperf
+       virtual/os-headers
+       virtual/pkgconfig
+       >=sys-devel/make-3.82-r4
+       >=sys-kernel/linux-headers-${KV_min}
+       >=dev-util/intltool-0.50
+       test? ( app-text/tree dev-lang/perl )"
+
+RDEPEND="${COMMON_DEPEND}
+       !<sys-fs/lvm2-2.02.103
+       !<sec-policy/selinux-base-2.20120725-r10
+       !sys-fs/udev
+       !sys-apps/systemd"
+
+PDEPEND=">=sys-fs/udev-init-scripts-26
+       hwdb? ( >=sys-apps/hwids-20140304[udev] )"
+
+# The multilib-build.eclass doesn't handle situation where the installed 
headers
+# are different in ABIs. In this case, we install libgudev headers in native
+# ABI but not for non-native ABI.
+multilib_check_headers() { :; }
+
+pkg_pretend() {
+       ewarn
+       ewarn "As of 2013-01-29, ${P} provides the new interface renaming 
functionality,"
+       ewarn "as described in the URL below:"
+       ewarn 
"https://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames";
+       ewarn
+       ewarn "This functionality is enabled BY DEFAULT because eudev has no 
means of synchronizing"
+       ewarn "between the default or user-modified choice of sys-fs/udev.  If 
you wish to disable"
+       ewarn "this new iface naming, please be sure that 
/etc/udev/rules.d/80-net-name-slot.rules"
+       ewarn "exists: touch /etc/udev/rules.d/80-net-name-slot.rules"
+       ewarn
+}
+
+pkg_setup() {
+       CONFIG_CHECK="~BLK_DEV_BSG ~DEVTMPFS ~!IDE ~INOTIFY_USER 
~!SYSFS_DEPRECATED ~!SYSFS_DEPRECATED_V2 ~SIGNALFD ~EPOLL ~FHANDLE ~NET ~UNIX"
+       linux-info_pkg_setup
+       get_running_version
+
+       # These are required kernel options, but we don't error out on them
+       # because you can build under one kernel and run under another.
+       if kernel_is lt ${KV_min//./ }; then
+               ewarn
+               ewarn "Your current running kernel version ${KV_FULL} is too 
old to run ${P}."
+               ewarn "Make sure to run udev under kernel version ${KV_min} or 
above."
+               ewarn
+       fi
+}
+
+src_prepare() {
+       # change rules back to group uucp instead of dialout for now
+       sed -e 's/GROUP="dialout"/GROUP="uucp"/' -i rules/*.rules \
+       || die "failed to change group dialout to uucp"
+
+       epatch_user
+       eautoreconf
+}
+
+multilib_src_configure() {
+       tc-export CC #463846
+       export cc_cv_CFLAGS__flto=no #502950
+
+       # Keep sorted by ./configure --help and only pass --disable flags
+       # when *required* to avoid external deps or unnecessary compile
+       local econf_args
+       econf_args=(
+               ac_cv_search_cap_init=
+               ac_cv_header_sys_capability_h=yes
+               DBUS_CFLAGS=' '
+               DBUS_LIBS=' '
+               --libdir=/usr/$(get_libdir)
+               --enable-manpages
+               --disable-hwdb
+               --exec-prefix=/
+       )
+
+       # Only build libudev for non-native_abi, and only install it to libdir,
+       # that means all options only apply to native_abi
+       if multilib_is_native_abi; then
+               econf_args+=(
+                       $(use_enable blkid)
+                       $(use_enable efi)
+                       $(use_enable kmod)
+                       $(use_enable selinux)
+                       $(use_enable smack)
+               )
+       else
+               econf_args+=(
+                       --disable-blkid
+                       --disable-efi
+                       --disable-kmod
+                       --disable-selinux
+                       --disable-smack
+               )
+       fi
+       ECONF_SOURCE="${S}" econf "${econf_args[@]}"
+}
+
+#multilib_src_compile() {
+#      if multilib_is_native_abi; then
+#              emake
+#      else
+#              emake -C src/libudev
+#      fi
+#}
+
+#multilib_src_install() {
+#      if multilib_is_native_abi; then
+#              emake DESTDIR="${D}" install
+#      else
+#              emake -C src/libudev DESTDIR="${D}" install
+#      fi
+#}
+
+multilib_src_test() {
+       # make sandbox get out of the way
+       # these are safe because there is a fake root filesystem put in place,
+       # but sandbox seems to evaluate the paths of the test i/o instead of the
+       # paths of the actual i/o that results.
+       # also only test for native abi
+       if multilib_is_native_abi; then
+               addread /sys
+               addwrite /dev
+               addwrite /run
+               default_src_test
+       fi
+}
+
+multilib_src_install_all() {
+       prune_libtool_files --all
+
+       insinto /lib/udev/rules.d
+       doins "${FILESDIR}"/40-gentoo.rules
+}
+
+pkg_postinst() {
+       mkdir -p "${EROOT}"run
+
+       # "losetup -f" is confused if there is an empty /dev/loop/, Bug #338766
+       # So try to remove it here (will only work if empty).
+       rmdir "${EROOT}"dev/loop 2>/dev/null
+       if [[ -d ${EROOT}dev/loop ]]; then
+               ewarn "Please make sure your remove /dev/loop,"
+               ewarn "else losetup may be confused when looking for unused 
devices."
+       fi
+
+       if use hwdb && has_version 'sys-apps/hwids[udev]'; then
+               udevadm hwdb --update --root="${ROOT%/}"
+
+               # 
https://cgit.freedesktop.org/systemd/systemd/commit/?id=1fab57c209035f7e66198343074e9cee06718bda
+               # reload database after it has be rebuilt, but only if we are 
not upgrading
+               # also pass if we are -9999 since who knows what hwdb related 
changes there might be
+               if [[ ${REPLACING_VERSIONS%-r*} == ${PV} || -z 
${REPLACING_VERSIONS} ]] && \
+               [[ ${ROOT%/} == "" ]] && [[ ${PV} != "9999" ]]; then
+                       udevadm control --reload
+               fi
+       fi
+
+       ewarn
+       ewarn "You need to restart eudev as soon as possible to make the"
+       ewarn "upgrade go into effect:"
+       ewarn "\t/etc/init.d/udev --nodeps restart"
+
+       elog
+       elog "For more information on eudev on Gentoo, writing udev rules, and"
+       elog "fixing known issues visit:"
+       elog "         https://www.gentoo.org/doc/en/udev-guide.xml";
+       elog
+
+       # 
https://cgit.freedesktop.org/systemd/systemd/commit/rules/50-udev-default.rules?id=3dff3e00e044e2d53c76fa842b9a4759d4a50e69
+       # https://bugs.gentoo.org/246847
+       # https://bugs.gentoo.org/514174
+       enewgroup input
+
+       # Update hwdb database in case the format is changed by udev version.
+       if has_version 'sys-apps/hwids[udev]'; then
+               udevadm hwdb --update --root="${ROOT%/}"
+               # Only reload when we are not upgrading to avoid potential race 
w/ incompatible hwdb.bin and the running udevd
+               if [[ -z ${REPLACING_VERSIONS} ]]; then
+                       # 
https://cgit.freedesktop.org/systemd/systemd/commit/?id=1fab57c209035f7e66198343074e9cee06718bda
+                       if [[ ${ROOT} != "" ]] && [[ ${ROOT} != "/" ]]; then
+                               return 0
+                       fi
+                       udevadm control --reload
+               fi
+       fi
+}

diff --git a/sys-fs/eudev/metadata.xml b/sys-fs/eudev/metadata.xml
index 8bd5d67..334d6ee 100644
--- a/sys-fs/eudev/metadata.xml
+++ b/sys-fs/eudev/metadata.xml
@@ -5,12 +5,15 @@
     <email>[email protected]</email>
   </maintainer>
   <use>
+       <flag name="blkid">enable blkid support</flag>
+       <flag name="efi">enable EFI support</flag>
     <flag name="gudev">enable libudev gobject interface</flag>
     <flag name="hwdb">read vendor/device string database and add it to udev 
database</flag>
     <flag name="keymap">map custom hardware's multimedia keys</flag>
     <flag name="kmod">enable module loading through libkmod</flag>
     <flag name="modutils">enable module loading support - use modutils calls 
if kmod not enabled</flag>
     <flag name="openrc">install the OpenRC init scripts</flag>
+    <flag name="smack">enable SMACK security model</flag>
     <flag name="rule-generator">install legacy rule generator rules and 
support scripts - note
        that the functionality within was dropped from sys-fs/udev as it is not 
stable in
        all cases; use at your own risk</flag>

Reply via email to