diff options
-rw-r--r-- | src/interfaces/localed/localed.c | 7 | ||||
-rw-r--r-- | src/interfaces/logind/logind.c | 8 | ||||
-rw-r--r-- | src/interfaces/timedated/timedated.c | 7 |
3 files changed, 19 insertions, 3 deletions
diff --git a/src/interfaces/localed/localed.c b/src/interfaces/localed/localed.c index 27448ac..3fdb7cf 100644 --- a/src/interfaces/localed/localed.c +++ b/src/interfaces/localed/localed.c @@ -152,6 +152,8 @@ void set_signal_handlers() { int main() { + set_signal_handlers(); + localed_loop = g_main_loop_new(NULL, TRUE); localed_freeable = g_ptr_array_new(); @@ -165,11 +167,14 @@ int main() { NULL); g_main_loop_run(localed_loop); + /* runs until single g_main_loop_quit() call is raised inside <interface>_mem_clean() */ g_main_loop_unref(localed_loop); + /* guaranteed unownable */ g_bus_unown_name(bus_descriptor); - localed_mem_clean(); + /* at this point no operations can occur with our data, it is safe to free it + its container */ + g_ptr_array_free(localed_freeable, TRUE); return 0; } diff --git a/src/interfaces/logind/logind.c b/src/interfaces/logind/logind.c index da9e24b..274bf16 100644 --- a/src/interfaces/logind/logind.c +++ b/src/interfaces/logind/logind.c @@ -152,6 +152,8 @@ void set_signal_handlers() { int main() { + set_signal_handlers(); + logind_loop = g_main_loop_new(NULL, TRUE); logind_freeable = g_ptr_array_new(); @@ -165,11 +167,15 @@ int main() { NULL); g_main_loop_run(logind_loop); + /* runs until single g_main_loop_quit() call is raised inside <interface>_mem_clean() */ g_main_loop_unref(logind_loop); + /* guaranteed unownable */ g_bus_unown_name(bus_descriptor); - logind_mem_clean(); + /* at this point no operations can occur with our data, it is safe to free it + its container */ + g_ptr_array_free(logind_freeable, TRUE); + return 0; } diff --git a/src/interfaces/timedated/timedated.c b/src/interfaces/timedated/timedated.c index 32f040a..a0d536d 100644 --- a/src/interfaces/timedated/timedated.c +++ b/src/interfaces/timedated/timedated.c @@ -152,6 +152,8 @@ void set_signal_handlers() { int main() { + set_signal_handlers(); + timedated_loop = g_main_loop_new(NULL, TRUE); timedated_freeable = g_ptr_array_new(); @@ -165,11 +167,14 @@ int main() { NULL); g_main_loop_run(timedated_loop); + /* runs until single g_main_loop_quit() call is raised inside <interface>_mem_clean() */ g_main_loop_unref(timedated_loop); + /* guaranteed unownable */ g_bus_unown_name(bus_descriptor); - timedated_mem_clean(); + /* at this point no operations can occur with our data, it is safe to free it + its container */ + g_ptr_array_free(timedated_freeable, TRUE); return 0; } |