aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/interfaces/localed/localed.c7
-rw-r--r--src/interfaces/logind/logind.c8
-rw-r--r--src/interfaces/timedated/timedated.c7
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;
}