mirror of
https://git.yoctoproject.org/poky
synced 2026-01-29 21:08:42 +01:00
There was a report that enabling assertions and all tests results in notices in log.do_configure: NOTE: building with unit tests increases the size of the installed library and renders it insecure. NOTE: building with assertions increases library size and decreases performance. This was overlooked when dbus and dbus-tests recipes were merged; enabling all tests and assertions still requires a special, separate build of dbus. If those tests are useful this could be revisited. Until then, we should use productions settings for the main recipe. Buildhistory-diff: packages/core2-64-poky-linux/dbus/dbus-dbg: PKGSIZE changed from 9958176 to 8627824 (-13%) packages/core2-64-poky-linux/dbus/dbus-lib: PKGSIZE changed from 544347 to 346339 (-36%) packages/core2-64-poky-linux/dbus/dbus-ptest: PKGSIZE changed from 3524983 to 3116951 (-12%) packages/core2-64-poky-linux/dbus/dbus-ptest: FILELIST: removed "/usr/share/installed-tests/dbus/test-dbus-launch-eval.sh_with_config.test /usr/share/installed-tests/dbus/test-counter_with_config.test /usr/libexec/installed-tests/dbus/test-dbus-launch-eval.sh /usr/libexec/installed-tests/dbus/test-dbus-launch-x11.sh /usr/share/installed-tests/dbus/test-counter.test /usr/libexec/installed-tests/dbus/test-counter /usr/share/installed-tests/dbus/test-dbus-launch-x11.sh.test /usr/share/installed-tests/dbus/test-dbus-launch-x11.sh_with_config.test /usr/share/installed-tests/dbus/test-dbus-launch-eval.sh.test" packages/core2-64-poky-linux/dbus/dbus: PKGSIZE changed from 510939 to 350331 (-31%) (From OE-Core rev: 054ce01ae84eb10e055a41ec8dd85ebce9ea23c8) Signed-off-by: Alexander Kanavin <alex@linutronix.de> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
187 lines
7.1 KiB
BlitzBasic
187 lines
7.1 KiB
BlitzBasic
SUMMARY = "D-Bus message bus"
|
|
DESCRIPTION = "D-Bus is a message bus system, a simple way for applications to talk to one another. In addition to interprocess communication, D-Bus helps coordinate process lifecycle; it makes it simple and reliable to code a \"single instance\" application or daemon, and to launch applications and daemons on demand when their services are needed."
|
|
HOMEPAGE = "https://dbus.freedesktop.org"
|
|
SECTION = "base"
|
|
|
|
inherit autotools pkgconfig gettext upstream-version-is-even ptest-gnome
|
|
|
|
LICENSE = "AFL-2.1 | GPL-2.0-or-later"
|
|
LIC_FILES_CHKSUM = "file://COPYING;md5=6423dcd74d7be9715b0db247fd889da3 \
|
|
file://dbus/dbus.h;beginline=6;endline=20;md5=866739837ccd835350af94dccd6457d8 \
|
|
"
|
|
|
|
SRC_URI = "https://dbus.freedesktop.org/releases/dbus/dbus-${PV}.tar.xz \
|
|
file://run-ptest \
|
|
file://tmpdir.patch \
|
|
file://dbus-1.init \
|
|
"
|
|
|
|
SRC_URI[sha256sum] = "ba1f21d2bd9d339da2d4aa8780c09df32fea87998b73da24f49ab9df1e36a50f"
|
|
|
|
EXTRA_OECONF = "--disable-xml-docs \
|
|
--disable-doxygen-docs \
|
|
--enable-largefile \
|
|
--with-system-socket=/run/dbus/system_bus_socket \
|
|
--enable-modular-tests \
|
|
--enable-checks \
|
|
--runstatedir=/run \
|
|
"
|
|
EXTRA_OECONF:append:class-target = " SYSTEMCTL=${base_bindir}/systemctl"
|
|
|
|
PACKAGECONFIG ??= "${@bb.utils.filter('DISTRO_FEATURES', 'systemd x11', d)} \
|
|
user-session \
|
|
"
|
|
PACKAGECONFIG:class-native = ""
|
|
PACKAGECONFIG:class-nativesdk = ""
|
|
|
|
PACKAGECONFIG[systemd] = "--enable-systemd --with-systemdsystemunitdir=${systemd_system_unitdir},--disable-systemd --without-systemdsystemunitdir,systemd"
|
|
PACKAGECONFIG[x11] = "--enable-x11-autolaunch,--without-x --disable-x11-autolaunch, virtual/libx11 libsm"
|
|
PACKAGECONFIG[user-session] = "--enable-user-session --with-systemduserunitdir=${systemd_user_unitdir},--disable-user-session"
|
|
PACKAGECONFIG[verbose-mode] = "--enable-verbose-mode,,,"
|
|
PACKAGECONFIG[audit] = "--enable-libaudit,--disable-libaudit,audit"
|
|
PACKAGECONFIG[selinux] = "--enable-selinux,--disable-selinux,libselinux"
|
|
|
|
DEPENDS = "expat virtual/libintl autoconf-archive-native glib-2.0"
|
|
RDEPENDS:${PN} += "${PN}-common ${PN}-tools"
|
|
RDEPENDS:${PN}:class-native = ""
|
|
|
|
inherit useradd update-rc.d
|
|
|
|
INITSCRIPT_NAME = "dbus-1"
|
|
INITSCRIPT_PARAMS = "start 02 5 3 2 . stop 20 0 1 6 ."
|
|
|
|
python __anonymous() {
|
|
if not bb.utils.contains('DISTRO_FEATURES', 'sysvinit', True, False, d):
|
|
d.setVar("INHIBIT_UPDATERCD_BBCLASS", "1")
|
|
}
|
|
|
|
PACKAGES =+ "${PN}-lib ${PN}-common ${PN}-tools"
|
|
|
|
USERADD_PACKAGES = "dbus-common"
|
|
USERADD_PARAM:dbus-common = "--system --home ${localstatedir}/lib/dbus \
|
|
--no-create-home --shell /bin/false \
|
|
--user-group messagebus"
|
|
|
|
CONFFILES:${PN} = "${sysconfdir}/dbus-1/system.conf ${sysconfdir}/dbus-1/session.conf"
|
|
|
|
DEBIANNAME:${PN} = "dbus-1"
|
|
|
|
OLDPKGNAME = "dbus-x11"
|
|
OLDPKGNAME:class-nativesdk = ""
|
|
|
|
# for compatibility
|
|
RPROVIDES:${PN} = "${OLDPKGNAME}"
|
|
RREPLACES:${PN} += "${OLDPKGNAME}"
|
|
|
|
FILES:${PN} = "${bindir}/dbus-daemon* \
|
|
${bindir}/dbus-cleanup-sockets \
|
|
${bindir}/dbus-launch \
|
|
${bindir}/dbus-run-session \
|
|
${libexecdir}/dbus* \
|
|
${sysconfdir} \
|
|
${localstatedir} \
|
|
${systemd_system_unitdir} \
|
|
${systemd_user_unitdir} \
|
|
${nonarch_libdir}/tmpfiles.d/dbus.conf \
|
|
"
|
|
FILES:${PN}-common = "${sysconfdir}/dbus-1 \
|
|
${datadir}/dbus-1/services \
|
|
${datadir}/dbus-1/system-services \
|
|
${datadir}/dbus-1/session.d \
|
|
${datadir}/dbus-1/session.conf \
|
|
${datadir}/dbus-1/system.d \
|
|
${datadir}/dbus-1/system.conf \
|
|
${systemd_system_unitdir}/dbus.socket \
|
|
${systemd_system_unitdir}/sockets.target.wants \
|
|
${systemd_user_unitdir}/dbus.socket \
|
|
${systemd_user_unitdir}/sockets.target.wants \
|
|
${nonarch_libdir}/sysusers.d/dbus.conf \
|
|
"
|
|
FILES:${PN}-tools = "${bindir}/dbus-uuidgen \
|
|
${bindir}/dbus-send \
|
|
${bindir}/dbus-monitor \
|
|
${bindir}/dbus-update-activation-environment \
|
|
"
|
|
FILES:${PN}-lib = "${libdir}/lib*.so.*"
|
|
RRECOMMENDS:${PN}-lib = "${PN}"
|
|
FILES:${PN}-dev += "${libdir}/dbus-1.0/include ${bindir}/dbus-test-tool ${datadir}/xml/dbus-1"
|
|
|
|
RDEPENDS:${PN}-ptest += "bash make dbus"
|
|
|
|
PACKAGE_WRITE_DEPS += "${@bb.utils.contains('DISTRO_FEATURES','systemd sysvinit','systemd-systemctl-native','',d)}"
|
|
pkg_postinst:dbus() {
|
|
# If both systemd and sysvinit are enabled, mask the dbus-1 init script
|
|
if ${@bb.utils.contains('DISTRO_FEATURES','systemd sysvinit','true','false',d)}; then
|
|
if [ -n "$D" ]; then
|
|
OPTS="--root=$D"
|
|
fi
|
|
systemctl $OPTS mask dbus-1.service
|
|
fi
|
|
|
|
if [ -z "$D" ] && [ -e /etc/init.d/populate-volatile.sh ] ; then
|
|
/etc/init.d/populate-volatile.sh update
|
|
fi
|
|
}
|
|
|
|
|
|
do_install() {
|
|
autotools_do_install
|
|
|
|
if ${@bb.utils.contains('DISTRO_FEATURES', 'sysvinit', 'true', 'false', d)}; then
|
|
install -d ${D}${sysconfdir}/init.d
|
|
sed 's:@bindir@:${bindir}:' < ${WORKDIR}/dbus-1.init >${WORKDIR}/dbus-1.init.sh
|
|
install -m 0755 ${WORKDIR}/dbus-1.init.sh ${D}${sysconfdir}/init.d/dbus-1
|
|
install -d ${D}${sysconfdir}/default/volatiles
|
|
echo "d messagebus messagebus 0755 /run/dbus none" \
|
|
> ${D}${sysconfdir}/default/volatiles/99_dbus
|
|
fi
|
|
|
|
if ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
|
|
for i in dbus.target.wants sockets.target.wants multi-user.target.wants; do \
|
|
install -d ${D}${systemd_system_unitdir}/$i; done
|
|
install -m 0644 ${B}/bus/dbus.service ${B}/bus/dbus.socket ${D}${systemd_system_unitdir}/
|
|
ln -fs ../dbus.socket ${D}${systemd_system_unitdir}/dbus.target.wants/dbus.socket
|
|
ln -fs ../dbus.socket ${D}${systemd_system_unitdir}/sockets.target.wants/dbus.socket
|
|
ln -fs ../dbus.service ${D}${systemd_system_unitdir}/multi-user.target.wants/dbus.service
|
|
fi
|
|
|
|
|
|
mkdir -p ${D}${localstatedir}/lib/dbus
|
|
|
|
chown messagebus:messagebus ${D}${localstatedir}/lib/dbus
|
|
|
|
chown root:messagebus ${D}${libexecdir}/dbus-daemon-launch-helper
|
|
chmod 4755 ${D}${libexecdir}/dbus-daemon-launch-helper
|
|
|
|
# Remove Red Hat initscript
|
|
rm -rf ${D}${sysconfdir}/rc.d
|
|
|
|
# Remove empty testexec directory as we don't build tests
|
|
rm -rf ${D}${libdir}/dbus-1.0/test
|
|
|
|
# Remove /var/run as it is created on startup
|
|
rm -rf ${D}${localstatedir}/run
|
|
}
|
|
|
|
do_install:class-native() {
|
|
autotools_do_install
|
|
|
|
# dbus-launch has no X support so lets not install it in case the host
|
|
# has a more featured and useful version
|
|
rm -f ${D}${bindir}/dbus-launch
|
|
}
|
|
|
|
do_install:class-nativesdk() {
|
|
autotools_do_install
|
|
|
|
# dbus-launch has no X support so lets not install it in case the host
|
|
# has a more featured and useful version
|
|
rm -f ${D}${bindir}/dbus-launch
|
|
|
|
# Remove /var/run to avoid QA error
|
|
rm -rf ${D}${localstatedir}/run
|
|
}
|
|
BBCLASSEXTEND = "native nativesdk"
|
|
|
|
CVE_PRODUCT += "d-bus_project:d-bus freedesktop:dbus freedesktop:libdbus"
|