Contents
A list of the installed files, along with their short descriptions can be found at ../../../../lfs/view/12.4-systemd/chapter08/dbus.html#contents-dbus.
Even though D-Bus was built in LFS, there are some features provided by the package that other BLFS packages need, but their dependencies didn't fit into LFS.
This package is known to build and work properly using an LFS 12.4 platform.
Download (HTTP): https://dbus.freedesktop.org/releases/dbus/dbus-1.16.2.tar.xz
Download MD5 sum: 97832e6f0a260936d28536e5349c22e5
Download size: 1.1 MB
Estimated disk space required: 25 MB (add 6 MB for tests)
Estimated build time: 0.3 SBU (add 0.4 SBU for tests)
Xorg Libraries (for dbus-launch program)
Systemd-257.8 (runtime, for registering services launched by D-Bus session daemon as systemd user services); For the tests: D-Bus Python-1.4.0, PyGObject-3.52.3, and Valgrind-3.25.1; for documentation: Doxygen-1.14.0, xmlto-0.0.29, Ducktype, and Yelp Tools
Install D-Bus by running the following commands (you may wish to review the meson_options.txt file first and add any additional desired options to the meson setup line below):
mkdir build &&
cd    build &&
meson setup --prefix=/usr          \
            --buildtype=release    \
            --wrap-mode=nofallback \
            .. &&
ninja
        See below for test instructions.
          Now, as the root user:
        
ninja install
          If you are using a DESTDIR install, dbus-daemon-launch-helper needs
          to be fixed afterwards. Issue, as root user:
        
chown -v root:messagebus /usr/libexec/dbus-daemon-launch-helper && chmod -v 4750 /usr/libexec/dbus-daemon-launch-helper
          Finally, still as the root user,
          rename the documentation directory (it only exists if the optional
          dependencies are satisfied for at least one documentation format)
          to make it versioned:
        
if [ -e /usr/share/doc/dbus ]; then
  rm -rf /usr/share/doc/dbus-1.16.2    &&
  mv -v  /usr/share/doc/dbus{,-1.16.2}
fi
        Many tests are disabled unless both D-Bus Python-1.4.0 and PyGObject-3.52.3 have been installed. They must be run as an unprivileged user from a local session with bus address. To run the standard tests issue ninja test.
If you want to run the unit regression tests, meson requires additional parameters which expose additional functionality in the binaries that are not intended to be used in a production build of D-Bus. If you would like to run the tests, issue the following commands (for the tests, you don't need to build the docs):
meson configure -D asserts=true -D intrusive_tests=true && ninja test
          --wrap-mode=nofallback:
          This switch prevents meson from using subproject
          fallbacks for any dependency declarations in the build files,
          preventing it from downloading any optional dependencies which are
          not installed on the system.
        
          -D intrusive_tests=true:
          Builds extra parts of the code to support all tests. Do not use on
          a production build.
        
          -D asserts=true: Enables
          debugging code to run assertions for statements normally assumed to
          be true. This prevents a warning that '-D asserts=true' on its own is only
          useful for profiling and might not give true results for all tests,
          but adds its own NOTE that this should not be used in a production
          build.
        
            The configuration files listed above should probably not be
            modified. If changes are required, you should create /etc/dbus-1/session-local.conf and/or
            /etc/dbus-1/system-local.conf and
            make any desired changes to these files.
          
            If any packages install a D-Bus
            .service file outside of the
            standard /usr/share/dbus-1/services
            directory, that directory should be added to the local session
            configuration. For instance, /usr/local/share/dbus-1/services can be added
            by performing the following commands as the root user:
          
cat > /etc/dbus-1/session-local.conf << "EOF"
<!DOCTYPE busconfig PUBLIC
 "-//freedesktop//DTD D-BUS Bus Configuration 1.0//EN"
 "http://www.freedesktop.org/standards/dbus/1.0/busconfig.dtd">
<busconfig>
  <!-- Search for .service files in /usr/local -->
  <servicedir>/usr/local/share/dbus-1/services</servicedir>
</busconfig>
EOF
        There are many methods you can use to start a session daemon using the dbus-launch command. Review the dbus-launch man page for details about the available parameters and options. Here are some suggestions and examples:
                  Add dbus-launch to the line
                  in the ~/.xinitrc file that
                  starts your graphical desktop environment.
                
                  If you use gdm or some other display
                  manager that calls the ~/.xsession file, you can add
                  dbus-launch
                  to the line in your ~/.xsession file that starts your
                  graphical desktop environment. The syntax would be similar
                  to the example in the ~/.xinitrc file.
                
                  The examples shown previously use dbus-launch to specify a
                  program to be run. This has the benefit (when also using
                  the --exit-with-x11
                  parameter) of stopping the session daemon when the
                  specified program is stopped. You can also start the
                  session daemon in your system or personal startup scripts
                  by adding the following lines:
                
# Start the D-Bus session daemon
eval `dbus-launch`
export DBUS_SESSION_BUS_ADDRESS
                  This method will not stop the session daemon when you exit
                  your shell, therefore you should add the following line to
                  your ~/.bash_logout file:
                
# Kill the D-Bus session daemon
kill $DBUS_SESSION_BUS_PIDA list of the installed files, along with their short descriptions can be found at ../../../../lfs/view/12.4-systemd/chapter08/dbus.html#contents-dbus.