chiark / gitweb /
bus: automatically flush bus queue when we exit the event loop
authorLennart Poettering <lennart@poettering.net>
Thu, 17 Oct 2013 23:43:11 +0000 (01:43 +0200)
committerLennart Poettering <lennart@poettering.net>
Thu, 17 Oct 2013 23:43:55 +0000 (01:43 +0200)
This way, we do not have to call it manually

src/hostname/hostnamed.c
src/libsystemd-bus/bus-internal.h
src/libsystemd-bus/bus-util.c
src/libsystemd-bus/sd-bus.c
src/timedate/timedated.c

index a8f0574ec70d42e4ccb9e803f7422007226b8f8b..db0762140b286405048c7b53e3c7562f2aafbdbe 100644 (file)
@@ -665,7 +665,6 @@ int main(int argc, char *argv[]) {
                 goto finish;
         }
 
-        sd_bus_flush(bus);
         r = 0;
 
 finish:
index 1726b618418a45f76f6fc976478340e5816bdc6b..5f8298bbb151e38126b3c534729ad3bbf2adbb13 100644 (file)
@@ -244,6 +244,7 @@ struct sd_bus {
         sd_event_source *input_io_event_source;
         sd_event_source *output_io_event_source;
         sd_event_source *time_event_source;
+        sd_event_source *quit_event_source;
         sd_event *event;
 };
 
index 0046b486cf0225e4cb477943d0c447daca300f9a..c72610466dc4e9d1cd4b37e88042ba1174b2e929 100644 (file)
@@ -83,7 +83,7 @@ int bus_event_loop_with_idle(sd_event *e, sd_bus *bus, const char *name, usec_t
                 if (r == SD_EVENT_FINISHED)
                         break;
 
-                r = sd_event_run(e, exiting ? (uint64_t) -1 : DEFAULT_EXIT_USEC);
+                r = sd_event_run(e, exiting ? (uint64_t) -1 : timeout);
                 if (r < 0)
                         return r;
 
index 665f1e6c8bae11c7035eed493f168389ac0bb0a9..55d964ed8f0269d20ae09fb4f5470e199f4220d5 100644 (file)
@@ -2208,6 +2208,16 @@ static int prepare_callback(sd_event_source *s, void *userdata) {
         return 1;
 }
 
+static int quit_callback(sd_event_source *event, void *userdata) {
+        sd_bus *bus = userdata;
+
+        assert(event);
+
+        sd_bus_flush(bus);
+
+        return 1;
+}
+
 int sd_bus_attach_event(sd_bus *bus, sd_event *event, int priority) {
         int r;
 
@@ -2251,6 +2261,10 @@ int sd_bus_attach_event(sd_bus *bus, sd_event *event, int priority) {
         if (r < 0)
                 goto fail;
 
+        r = sd_event_add_quit(event, quit_callback, bus, &bus->quit_event_source);
+        if (r < 0)
+                goto fail;
+
         return 0;
 
 fail:
@@ -2271,6 +2285,9 @@ int sd_bus_detach_event(sd_bus *bus) {
         if (bus->time_event_source)
                 bus->time_event_source = sd_event_source_unref(bus->time_event_source);
 
+        if (bus->quit_event_source)
+                bus->quit_event_source = sd_event_source_unref(bus->quit_event_source);
+
         if (bus->event)
                 bus->event = sd_event_unref(bus->event);
 
index 61f8fc55b5cd026d06045d9e5030604ef510b3bb..2ead4b99993b91c44f099b0e25a52ee7d0bf8cf0 100644 (file)
@@ -880,7 +880,6 @@ int main(int argc, char *argv[]) {
                 goto finish;
         }
 
-        sd_bus_flush(bus);
         r = 0;
 
 finish: