diff options
author | Samuli Suominen <ssuominen@gentoo.org> | 2010-09-28 06:20:47 +0000 |
---|---|---|
committer | Samuli Suominen <ssuominen@gentoo.org> | 2010-09-28 06:20:47 +0000 |
commit | c304e9b1f02259f7a0e68ed7ee15d3fe6e162f5d (patch) | |
tree | 24d3b0afecaac1377b399f4e91c692845730a0e0 | |
parent | old (diff) | |
download | historical-c304e9b1f02259f7a0e68ed7ee15d3fe6e162f5d.tar.gz historical-c304e9b1f02259f7a0e68ed7ee15d3fe6e162f5d.tar.bz2 historical-c304e9b1f02259f7a0e68ed7ee15d3fe6e162f5d.zip |
Remove now unnecessary workaround for PATH and 512 bytes limit in init script wrt #267928.
Package-Manager: portage-2.2_rc87/cvs/Linux x86_64
-rw-r--r-- | sys-apps/hal/ChangeLog | 9 | ||||
-rw-r--r-- | sys-apps/hal/Manifest | 4 | ||||
-rw-r--r-- | sys-apps/hal/files/0.5.14-hald.rc.1 | 39 | ||||
-rw-r--r-- | sys-apps/hal/hal-0.5.14-r3.ebuild | 322 |
4 files changed, 372 insertions, 2 deletions
diff --git a/sys-apps/hal/ChangeLog b/sys-apps/hal/ChangeLog index fd0c44202f96..24a786b93e4a 100644 --- a/sys-apps/hal/ChangeLog +++ b/sys-apps/hal/ChangeLog @@ -1,6 +1,13 @@ # ChangeLog for sys-apps/hal # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-apps/hal/ChangeLog,v 1.326 2010/09/28 04:47:53 ssuominen Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-apps/hal/ChangeLog,v 1.327 2010/09/28 06:20:47 ssuominen Exp $ + +*hal-0.5.14-r3 (28 Sep 2010) + + 28 Sep 2010; Samuli Suominen <ssuominen@gentoo.org> + +files/0.5.14-hald.rc.1, +hal-0.5.14-r3.ebuild: + Remove now unnecessary workaround for PATH and 512 bytes limit in init + script wrt #267928. 28 Sep 2010; Samuli Suominen <ssuominen@gentoo.org> hal-0.5.14-r2.ebuild: Remove old sys-auth/consolekit from dependencies. diff --git a/sys-apps/hal/Manifest b/sys-apps/hal/Manifest index 81fa5f1d6dd5..e1f8a35ea9b4 100644 --- a/sys-apps/hal/Manifest +++ b/sys-apps/hal/Manifest @@ -1,9 +1,11 @@ AUX 0.5.14-hald.conf 119 RMD160 06e205ba7fa8acfb6f68e84a247845a3ad028351 SHA1 c8a62a808c7f632154dda1686fe344a4a136e28f SHA256 b19e6df9c78b6f813405a7cbff20e049714db1a000e6b71ab2eca02d372d58af AUX 0.5.14-hald.rc 1174 RMD160 e9371f69f6594cf53de234e443a204c2b2127d31 SHA1 35ff148aec2d457cdeaed7e2032a414315a7236b SHA256 0ba01941ed8b7946524fb7ba4253c3ae57c6bdf9ddb4eaa01bd9bd89d1d4ef21 +AUX 0.5.14-hald.rc.1 1114 RMD160 24c508a1a8df09252a21b178addba8a18a17ba1e SHA1 6bcca0ce11b50529b71cb2ff3af4ad877c3f144c SHA256 ab68ed700d2c3044da6ec2cc88f315c33518d4df503c52eda1ded3354b751cca AUX hal-0.5.14-r2-fbsd.patch 4380 RMD160 9a3483cf3a7eee5f43b582b9ca531da7487221f9 SHA1 67d41b9b74d89ab7645ac3750780895a70856e50 SHA256 8299068a7d0276e2e08785a56e3285d4232435a427c3059cc9f88ebe87e97ee2 AUX hal-unmount.dev 397 RMD160 78286dd9527bbb421082e73b0d08e06cd514d275 SHA1 31169a28448fb1eb1dfee5d1699de9a02449a6b7 SHA256 747a4c483f8a558f2c75666e9547e539475f112363f1dbfc6ea19ca393c8e89b DIST hal-0.5.14-gentoo-patches-3.tar.bz2 4706 RMD160 98b761f78e8f1dda3d533c6921ca530afde85478 SHA1 2fd202df7b4dab55a6f81d90b5660f5a25d0b506 SHA256 d9997ce4890d66bca6611f3e5ee34112a0bdddf0675d4dc13f3268ba9d886a62 DIST hal-0.5.14.tar.bz2 942954 RMD160 0314dace9512bf49a62bd1556963fc60a6c9caf9 SHA1 a6ec098d78112e18e2773afa5f9ed642b00c4c59 SHA256 c4c5ecc5d50d5d9c061dc06c405461b1f71c12f2c60ed062350b2e6db2f1c51e EBUILD hal-0.5.14-r2.ebuild 10161 RMD160 7e92d06d3ff4176b829bd7a01dd5078fb2595338 SHA1 e3b45dd1fbb3717fcd6136eb03c9ed0b8c1b7d3e SHA256 3d399ea3e6e07e92d4ff88d808455015c37fcad78e1c1d40798cc918a25178b0 -MISC ChangeLog 57262 RMD160 6d75e29cf954387e945213d4d196f4e9070e8c81 SHA1 1ca6c0d1186b46d620d0047d8d35ab0fa5fb8fe8 SHA256 1fffb045378a301607ac835b650728c08457872ff82619d852f1c9987c2303d3 +EBUILD hal-0.5.14-r3.ebuild 10180 RMD160 d015719f5a49bf1176da302ceb62e80b78c2d0d9 SHA1 d04149d8331f8f71e3b8ae0878950e1fd2b93805 SHA256 4451441cca68759498e5c164cf4ae745660835333eba383619e869cd96021c0a +MISC ChangeLog 57492 RMD160 3bbbe82c8794a11e6638cef1b68cedd206830381 SHA1 2ca427c072fa5d271ce22cbbfdcd4e86ac534823 SHA256 c3c0784b993567bd311ef173eecff11c5c439512a40bb98832f04385acfd8a48 MISC metadata.xml 2018 RMD160 3fdb4c4b31f4a910022e1a51b305779048fc9d8b SHA1 c193d48cfa7402e7287b9582583f57c46ef259ab SHA256 c2f9bc7dfe991c4d93630e1c1d64e7b159fd9f5805f11f85ab2952f0acdfbf52 diff --git a/sys-apps/hal/files/0.5.14-hald.rc.1 b/sys-apps/hal/files/0.5.14-hald.rc.1 new file mode 100644 index 000000000000..6a312f434f48 --- /dev/null +++ b/sys-apps/hal/files/0.5.14-hald.rc.1 @@ -0,0 +1,39 @@ +#!/sbin/runscript +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License, v2 or later +# $Header: /var/cvsroot/gentoo-x86/sys-apps/hal/files/0.5.14-hald.rc.1,v 1.1 2010/09/28 06:20:47 ssuominen Exp $ + +depend() { + use logger acpid + need dbus + after coldplug dns nscd +} + +start() { + [ -z "${HALD_VERBOSE}" ] && HALD_VERBOSE="no" + ebegin "Starting Hardware Abstraction Layer daemon" + +# REAL_ROOT=`mount -fv / | cut -d' ' -f1` +# TEST_ROOT=`cat /proc/mounts | cut -d' ' -f1 | head -n 2 | tail -n 1` + +# if [ ! -e ${TEST_ROOT} ]; then +# echo "You need a ${TEST_ROOT} that points to your ${REAL_ROOT}" +# echo "See http://bugs.gentoo.org/show_bug.cgi?id=175243" +# echo "Quick fix is: ln -s ${REAL_ROOT} ${TEST_ROOT}" +# eend 2 +# fi + + if [ -f /proc/acpi/event ]; then + chgrp haldaemon /proc/acpi/event + chmod 440 /proc/acpi/event + fi + + start-stop-daemon --start -q --exec /usr/sbin/hald -- --use-syslog --verbose=${HALD_VERBOSE} + eend $? +} + +stop() { + ebegin "Stopping Hardware Abstraction Layer daemon" + start-stop-daemon --stop -q --pidfile /var/run/hald.pid + eend $? +} diff --git a/sys-apps/hal/hal-0.5.14-r3.ebuild b/sys-apps/hal/hal-0.5.14-r3.ebuild new file mode 100644 index 000000000000..4b4f1223aa4e --- /dev/null +++ b/sys-apps/hal/hal-0.5.14-r3.ebuild @@ -0,0 +1,322 @@ +# Copyright 1999-2010 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-apps/hal/hal-0.5.14-r3.ebuild,v 1.1 2010/09/28 06:20:47 ssuominen Exp $ + +EAPI="2" + +inherit eutils linux-info autotools flag-o-matic multilib + +PATCH_VERSION="3" + +MY_P=${P/_/} +S=${WORKDIR}/${MY_P} +PATCHNAME="${MY_P}-gentoo-patches-${PATCH_VERSION}" +DESCRIPTION="Hardware Abstraction Layer" +HOMEPAGE="http://www.freedesktop.org/wiki/Software/hal" +SRC_URI="http://hal.freedesktop.org/releases/${MY_P}.tar.bz2 + http://dev.gentoo.org/~dang/files/${PATCHNAME}.tar.bz2" + +LICENSE="|| ( GPL-2 AFL-2.0 )" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sh ~sparc ~x86 ~x86-fbsd" + +KERNEL_IUSE="kernel_linux kernel_FreeBSD" +IUSE="X acpi apm crypt consolekit debug dell disk-partition doc laptop policykit selinux ${KERNEL_IUSE}" + +RDEPEND=">=dev-libs/dbus-glib-0.61 + >=dev-libs/glib-2.14 + >=dev-libs/expat-1.95.8 + =virtual/libusb-0* + >=sys-apps/pciutils-2.2.7-r1 + sys-apps/usbutils + virtual/eject + amd64? ( >=sys-apps/dmidecode-2.7 ) + dell? ( >=sys-libs/libsmbios-0.13.4 ) + disk-partition? ( >=sys-block/parted-1.8.0 ) + ia64? ( >=sys-apps/dmidecode-2.7 ) + kernel_linux? ( + >=sys-fs/udev-125 + >=sys-apps/util-linux-2.16 + >=sys-kernel/linux-headers-2.6.22 + crypt? ( >=sys-fs/cryptsetup-1.0.5 ) + ) + kernel_FreeBSD? ( >=dev-libs/libvolume_id-0.77 ) + x86? ( >=sys-apps/dmidecode-2.7 ) + selinux? ( sys-libs/libselinux sec-policy/selinux-hal ) + consolekit? ( >=sys-auth/consolekit-0.4 ) + policykit? ( + sys-auth/consolekit[policykit] + sys-auth/policykit[pam] + )" +DEPEND="${RDEPEND} + dev-util/pkgconfig + >=dev-util/gperf-3.0.3 + >=dev-util/intltool-0.35 + doc? ( + app-text/xmlto + dev-libs/libxml2 + dev-util/gtk-doc + app-text/docbook-sgml-utils + )" +PDEPEND=">=app-misc/hal-info-20081219 + !gnome-extra/hal-device-manager + laptop? ( >=sys-power/pm-utils-0.99.3 )" + +## HAL Daemon drops privledges so we need group access to read disks +HALDAEMON_GROUPS_LINUX="haldaemon,plugdev,disk,cdrom,cdrw,floppy,usb" +HALDAEMON_GROUPS_FREEBSD="haldaemon,plugdev,operator" + +function check_hotplug_net() { + local CONFIG_CHECK="~HOTPLUG ~NET" + local WARNING_HOTPLUG="CONFIG_HOTPLUG:\tis not set (required for HAL)\n" + local WARNING_NET="CONFIG_NET:\tis not set (required for HAL)\n" + check_extra_config +} + +function check_inotify() { + local CONFIG_CHECK="~INOTIFY_USER" + local WARNING_INOTIFY_USER="CONFIG_INOTIFY_USER:\tis not set (required for HAL)\n" + check_extra_config +} + +function check_acpi_proc() { + local CONFIG_CHECK="~ACPI_PROCFS ~ACPI_PROC_EVENT" + local WARNING_ACPI_PROCFS="CONFIG_ACPI_PROCFS:\tis not set (required for HAL)\n" + local WARNING_ACPI_PROC_EVENT="CONFIG_ACPI_PROC_EVENT:\tis not set (required for HAL)\n" + check_extra_config +} + +pkg_setup() { + if use kernel_linux ; then + if [[ -e "${ROOT}/usr/src/linux/.config" ]] ; then + kernel_is ge 2 6 19 || ewarn "HAL requires a kernel version 2.6.19 or newer" + + if kernel_is lt 2 6 23 && use acpi ; then + check_acpi_proc + fi + fi + + check_hotplug_net + check_inotify + fi + + # http://devmanual.gentoo.org/ebuild-writing/functions/ + # http://bugs.gentoo.org/show_bug.cgi?id=191605 + + # Create groups for hotplugging and HAL + enewgroup haldaemon + enewgroup plugdev + + # HAL drops priviledges by default now ... + # ... so we must make sure it can read disk/cdrom info (ie. be in ${HALDAEMON_GROUPS} groups) + if use kernel_linux; then + enewuser haldaemon -1 "-1" /dev/null ${HALDAEMON_GROUPS_LINUX} + elif use kernel_FreeBSD; then + enewuser haldaemon -1 "-1" /dev/null ${HALDAEMON_GROUPS_FREEBSD} + fi + + # Make sure that the haldaemon user is in the ${HALDAEMON_GROUPS} + # If users have a problem with this, let them file a bug + if [[ ${ROOT} == / ]] ; then + if use kernel_linux; then + usermod -G ${HALDAEMON_GROUPS_LINUX} haldaemon + elif use kernel_FreeBSD; then + pw usermod haldaemon -G ${HALDAEMON_GROUPS_FREEBSD} + fi + fi +} + +src_prepare() { + # Patch for fbsd, Bug #309263. MOVE INTO PATCHSET FOR NEXT BUMP! + epatch "${FILESDIR}"/${P}-r2-fbsd.patch + + # Only apply one of the policy patches. Bug #267042 + if use policykit ; then + rm "${WORKDIR}/${PATCHNAME}/patches/0001-plugdev-dbus-policy.patch" + else + rm "${WORKDIR}/${PATCHNAME}/patches/0002-policykit-dbus-policy.patch" + fi + + EPATCH_MULTI_MSG="Applying Gentoo Patchset ..." \ + EPATCH_SUFFIX="patch" \ + EPATCH_SOURCE="${WORKDIR}/${PATCHNAME}/patches/" \ + EPATCH_FORCE="yes" \ + epatch + + eautoreconf +} + +src_configure() { + local acpi="$(use_enable acpi)" + local backend= + local hardware= + local consolekit="$(use_enable consolekit console-kit)" + + append-flags -rdynamic + + if use kernel_linux ; then + backend="linux" + elif use kernel_FreeBSD ; then + backend="freebsd" + else + eerror "Invalid backend" + fi + + if use kernel_linux ; then + if use acpi ; then + # Using IBM ACPI and Toshiba ACPI results in double notification as this + # was merged into the Linux Kernel 2.6.22 + if kernel_is lt 2 6 22 ; then + acpi="$acpi --enable-acpi-ibm --enable-acpi-toshiba" + else + acpi="$acpi --disable-acpi-ibm --disable-acpi-toshiba" + fi + + acpi="$acpi --enable-acpi-proc --enable-acpi-acpid" + else + acpi="$acpi --disable-acpi-ibm --disable-acpi-toshiba" + acpi="$acpi --disable-acpi-proc --disable-acpi-acpid" + fi + + hardware="--with-cpufreq --with-usb-csr --with-keymaps" + use arm && hardware="$hardware --with-omap --enable-pmu" + use ppc && hardware="$hardware --enable-pmu" + if use x86 || use amd64; then + hardware="$hardware --with-macbook --with-macbookpro" + fi + + if use dell ; then + hardware="$hardware --with-dell-backlight" + else + hardware="$hardware --without-dell-backlight" + fi + + hardware="$hardware --enable-sonypic" + else + hardware="--without-cpufreq --without-usb-csr --without-keymaps" + hardware="$hardware --without-omap" + hardware="$hardware --without-dell-backlight" + hardware="$hardware --enable-acpi-ibm --enable-acpi-toshiba" + hardware="$hardware --disable-sonypic" + fi + + # Policykit support depends on consolekit support. Therefore, force on + # consolekit, even if it's USE flag is off, if policykit support is on. + # This enables packages to USE-depend on hal[policykit?] + if use policykit ; then + consolekit="--enable-console-kit" + fi + + econf --with-backend=${backend} \ + --with-os-type=gentoo \ + --with-pid-file=/var/run/hald.pid \ + --with-hwdata=/usr/share/misc \ + --with-socket-dir=/var/run/hald \ + --with-udev-prefix=/etc \ + --enable-umount-helper \ + --enable-man-pages \ + --disable-acl-management \ + --enable-pci \ + $(use_enable apm) \ + $(use_enable debug verbose-mode) \ + $(use_enable disk-partition parted) \ + $(use_enable doc docbook-docs) \ + $(use_enable doc gtk-doc) \ + $(use_enable policykit policy-kit) \ + ${consolekit} \ + --docdir=/usr/share/doc/${PF} \ + --localstatedir=/var \ + ${acpi} ${hardware} \ + || die "configure failed" +} + +src_install() { + emake DESTDIR="${D}" install || die + dodoc AUTHORS ChangeLog NEWS README || die "docs failed" + + # hal umount for unclean unmounts + exeinto /$(get_libdir)/udev/ + newexe "${FILESDIR}/hal-unmount.dev" hal_unmount || die "udev helper failed" + + # initscript + cp "${FILESDIR}/0.5.14-hald.rc.1" "${WORKDIR}/" || \ + die "failed to copy hald.rc.1" + if use consolekit || use policykit; then + sed -e 's:need dbus:need dbus consolekit:' \ + -i "${WORKDIR}/0.5.14-hald.rc.1" || die "failed to change verbose" + fi + newinitd "${WORKDIR}/0.5.14-hald.rc.1" hald || die "init script failed" + + # configuration + cp "${FILESDIR}/0.5.14-hald.conf" "${WORKDIR}/" || \ + die "failed to copy hald.conf" + + if use debug; then + sed -e 's:HALD_VERBOSE="no":HALD_VERBOSE="yes":' \ + -i "${WORKDIR}/0.5.14-hald.conf" || die "failed to change verbose" + fi + newconfd "${WORKDIR}/0.5.14-hald.conf" hald || \ + die "failed to install hald.conf" + + if use X ; then + # New Configuration Snippets + dodoc "${WORKDIR}/${PATCHNAME}/config-examples/"*.fdi || \ + die "dodoc X examples failed" + fi + + # We now create and keep /media here as both gnome-mount and pmount + # use these directories, to avoid collision. + keepdir /media + + # We also need to create and keep /etc/fdi/{information,policy,preprobe} + # or else hal bombs. + keepdir /etc/hal/fdi/{information,policy,preprobe} + + # HAL stores it's fdi cache in /var/cache/hald + keepdir /var/cache/hald + + # HAL keeps its unix socket here + keepdir /var/run/hald + keepdir /var/lib/hal +} + +pkg_postinst() { + # Despite what people keep changing this location. Either one works.. it doesn't matter + # http://dev.gentoo.org/~plasmaroo/devmanual/ebuild-writing/functions/ + + elog "The HAL daemon needs to be running for certain applications to" + elog "work. Suggested is to add the init script to your start-up" + elog "scripts, this should be done like this :" + elog "\`rc-update add hald default\`" + echo + elog "Access to hal is now protected by either policykit or the plugdev group." + elog "If you have problems discovering/configuring hardware, try adding" + elog "yourself to plugdev, or ensuring consolekit is started" + echo + elog "IF you have additional applications which consume ACPI events, you" + elog "should consider installing acpid to allow applications to share ACPI" + elog "events." + if use X ; then + echo + elog "If you wish to use a non US layout, you may do so by executing:" + elog "setxkbmap <layout> or by utilizing your Desktop Environment's" + elog "Keyboard Layout Settings mechanism." + elog "Under GNOME, this is gnome-keyboard-properties, and under KDE" + elog "it is kxkb." + fi + echo + elog "In order have suspend/hibernate function with HAL or apps that use HAL" + elog "(such as gnome-power-manager), you should build HAL with the laptop" + elog "useflag which will install pm-utils." + if use X ; then + echo + elog "X Input Hotplugging (if you build xorg-server with the HAL useflag)" + elog "reads user specific configuration from /etc/hal/fdi/policy/." + echo + elog "You should remove the Input sections from your xorg.conf once you have" + elog "migrated the rules to a HAL fdi file." + fi + + ebeep 5 + epause 5 +} |