X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flibsystemd%2Fsd-bus%2Fbus-util.c;h=86b83db1be2c12793563eeee9eb45744fbf38e37;hb=b798e7baa5dc3ca6199bbff69f71a08d94299fdd;hp=29520f95d217ab42597aa0cf9b2bd507a70617db;hpb=d8f52ed25a9edce75fda5251c977b7898e33887e;p=elogind.git diff --git a/src/libsystemd/sd-bus/bus-util.c b/src/libsystemd/sd-bus/bus-util.c index 29520f95d..86b83db1b 100644 --- a/src/libsystemd/sd-bus/bus-util.c +++ b/src/libsystemd/sd-bus/bus-util.c @@ -1638,13 +1638,21 @@ int bus_wait_for_jobs_new(sd_bus *bus, BusWaitForJobs **ret) { d->bus = sd_bus_ref(bus); + /* When we are a bus client we match by sender. Direct + * connections OTOH have no initialized sender field, and + * hence we ignore the sender then */ r = sd_bus_add_match( bus, &d->slot_job_removed, + bus->bus_client ? "type='signal'," "sender='org.freedesktop.systemd1'," "interface='org.freedesktop.systemd1.Manager'," "member='JobRemoved'," + "path='/org/freedesktop/systemd1'" : + "type='signal'," + "interface='org.freedesktop.systemd1.Manager'," + "member='JobRemoved'," "path='/org/freedesktop/systemd1'", match_job_removed, d); if (r < 0)