diff options
author | 2011-10-20 20:46:36 +0000 | |
---|---|---|
committer | 2011-10-20 20:46:36 +0000 | |
commit | ef5e36800bd445ae148f6a81f9c94bb2aa3412f4 (patch) | |
tree | 4fe0bd78f656dc496c8a26b30038c6550618c099 /sys-apps/dbus | |
parent | Move qt-phonon blocker to COMMONDEPEND, bug 374111 (diff) | |
download | gentoo-2-ef5e36800bd445ae148f6a81f9c94bb2aa3412f4.tar.gz gentoo-2-ef5e36800bd445ae148f6a81f9c94bb2aa3412f4.tar.bz2 gentoo-2-ef5e36800bd445ae148f6a81f9c94bb2aa3412f4.zip |
Dropped keepdir on /var/run/dbus as the init.d script already ensures this path exists (bug 387897)
(Portage version: 2.1.10.11/cvs/Linux i686)
Diffstat (limited to 'sys-apps/dbus')
-rw-r--r-- | sys-apps/dbus/ChangeLog | 8 | ||||
-rw-r--r-- | sys-apps/dbus/dbus-1.4.16-r1.ebuild | 188 |
2 files changed, 195 insertions, 1 deletions
diff --git a/sys-apps/dbus/ChangeLog b/sys-apps/dbus/ChangeLog index 7b53c47b3ed0..e660702c19ad 100644 --- a/sys-apps/dbus/ChangeLog +++ b/sys-apps/dbus/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for sys-apps/dbus # Copyright 1999-2011 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/sys-apps/dbus/ChangeLog,v 1.308 2011/10/19 00:52:57 jer Exp $ +# $Header: /var/cvsroot/gentoo-x86/sys-apps/dbus/ChangeLog,v 1.309 2011/10/20 20:46:36 axs Exp $ + +*dbus-1.4.16-r1 (20 Oct 2011) + + 20 Oct 2011; Ian Stakenvicius <axs@gentoo.org> +dbus-1.4.16-r1.ebuild: + Dropped keepdir on /var/run/dbus as the init.d script already ensures this + path exists (bug 387897) 19 Oct 2011; Jeroen Roovers <jer@gentoo.org> dbus-1.4.16.ebuild: Stable for HPPA (bug #387257). diff --git a/sys-apps/dbus/dbus-1.4.16-r1.ebuild b/sys-apps/dbus/dbus-1.4.16-r1.ebuild new file mode 100644 index 000000000000..a2b1be640113 --- /dev/null +++ b/sys-apps/dbus/dbus-1.4.16-r1.ebuild @@ -0,0 +1,188 @@ +# Copyright 1999-2011 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/sys-apps/dbus/dbus-1.4.16-r1.ebuild,v 1.1 2011/10/20 20:46:36 axs Exp $ + +EAPI=2 +inherit autotools eutils multilib flag-o-matic python systemd virtualx + +DESCRIPTION="A message bus system, a simple way for applications to talk to each other" +HOMEPAGE="http://dbus.freedesktop.org/" +SRC_URI="http://dbus.freedesktop.org/releases/dbus/${P}.tar.gz" + +LICENSE="|| ( GPL-2 AFL-2.1 )" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~x86-fbsd" +IUSE="debug doc selinux static-libs test X" + +RDEPEND=" + X? ( + x11-libs/libX11 + x11-libs/libXt + ) + selinux? ( + sys-libs/libselinux + sec-policy/selinux-dbus + ) + >=dev-libs/expat-1.95.8 +" +DEPEND="${RDEPEND} + dev-util/pkgconfig + doc? ( + app-doc/doxygen + app-text/docbook-xml-dtd:4.1.2 + app-text/xmlto + ) + test? ( + =dev-lang/python-2* + >=dev-libs/glib-2.22:2 + ) +" + +# out of sources build directory +BD=${WORKDIR}/${P}-build +# out of sources build dir for make check +TBD=${WORKDIR}/${P}-tests-build + +pkg_setup() { + enewgroup messagebus + enewuser messagebus -1 "-1" -1 messagebus + + if use test; then + python_set_active_version 2 + python_pkg_setup + fi +} + +src_prepare() { + # Tests were restricted because of this + sed -i \ + -e 's/.*bus_dispatch_test.*/printf ("Disabled due to excess noise\\n");/' \ + -e '/"dispatch"/d' \ + bus/test-main.c || die + + epatch "${FILESDIR}"/${PN}-1.4.0-asneeded.patch + + # required for asneeded patch but also for bug 263909, cross-compile so + # don't remove eautoreconf + eautoreconf +} + +src_configure() { + local my_conf + + # so we can get backtraces from apps + append-flags -rdynamic + + # libaudit is *only* used in DBus wrt SELinux support, so disable it, if + # not on an SELinux profile. + my_conf="--disable-asserts + --disable-checks + --disable-embedded-tests + --disable-modular-tests + $(use_with X x) + $(use_enable debug verbose-mode) + --disable-asserts + $(use_enable kernel_linux inotify) + $(use_enable kernel_FreeBSD kqueue) + $(use_enable selinux) + $(use_enable selinux libaudit) + $(use_enable static-libs static) + --enable-shared + --with-xml=expat + --with-system-pid-file=/var/run/dbus.pid + --with-system-socket=/var/run/dbus/system_bus_socket + --with-session-socket-dir=/tmp + --with-dbus-user=messagebus + $(systemd_with_unitdir) + --localstatedir=/var + --docdir=/usr/share/doc/${PF} + --htmldir=/usr/share/doc/${PF}/html" + + mkdir "${BD}" + cd "${BD}" + einfo "Running configure in ${BD}" + ECONF_SOURCE="${S}" econf ${my_conf} \ + $(use_enable doc doxygen-docs) \ + $(use_enable doc xml-docs) + + if use test; then + local circ + has_version dev-libs/dbus-glib && circ="--enable-modular-tests" + + mkdir "${TBD}" + cd "${TBD}" + einfo "Running configure in ${TBD}" + ECONF_SOURCE="${S}" econf \ + ${my_conf} \ + $(use_enable test checks) \ + $(use_enable test embedded-tests) \ + $(use_enable test asserts) \ + ${circ} + fi +} + +src_compile() { + # after the compile, it uses a selinuxfs interface to + # check if the SELinux policy has the right support + use selinux && addwrite /selinux/access + + cd "${BD}" + einfo "Running make in ${BD}" + emake || die + + if use test; then + cd "${TBD}" + einfo "Running make in ${TBD}" + emake || die + fi +} + +src_test() { + cd "${TBD}" + DBUS_VERBOSE=1 Xemake -j1 check || die +} + +src_install() { + # initscript + newinitd "${FILESDIR}"/dbus.init-1.0 dbus || die + + if use X; then + # dbus X session script (#77504) + # turns out to only work for GDM (and startx). has been merged into + # other desktop (kdm and such scripts) + exeinto /etc/X11/xinit/xinitrc.d/ + doexe "${FILESDIR}"/80-dbus || die + fi + + # needs to exist for dbus sessions to launch + keepdir /usr/lib/dbus-1.0/services + keepdir /usr/share/dbus-1/services + keepdir /etc/dbus-1/system.d/ + keepdir /etc/dbus-1/session.d/ + + dodoc AUTHORS ChangeLog HACKING NEWS README doc/TODO || die + + cd "${BD}" + emake DESTDIR="${D}" install || die + + # remove .la files + find "${D}" -type f -name '*.la' -exec rm -f {} + +} + +pkg_postinst() { + elog "To start the D-Bus system-wide messagebus by default" + elog "you should add it to the default runlevel :" + elog "\`rc-update add dbus default\`" + elog + elog "Some applications require a session bus in addition to the system" + elog "bus. Please see \`man dbus-launch\` for more information." + elog + ewarn "You must restart D-Bus \`/etc/init.d/dbus restart\` to run" + ewarn "the new version of the daemon." + ewarn "Don't do this while X is running because it will restart your X as well." + + # Move to /etc per #370451 and ensure unique id is generated + [[ -e ${ROOT}/var/lib/dbus/machine-id ]] && \ + mv -vf "${ROOT}"/var/lib/dbus/machine-id "${ROOT}"/etc/machine-id + dbus-uuidgen --ensure="${ROOT}"/etc/machine-id +} |