aboutsummaryrefslogtreecommitdiffstats
path: root/src/interfaces
diff options
context:
space:
mode:
Diffstat (limited to 'src/interfaces')
-rw-r--r--src/interfaces/localed/localed.c9
-rw-r--r--src/interfaces/logind/logind.c9
-rw-r--r--src/interfaces/timedated/timedated.c9
3 files changed, 27 insertions, 0 deletions
diff --git a/src/interfaces/localed/localed.c b/src/interfaces/localed/localed.c
index e2fd3f4..83c8de2 100644
--- a/src/interfaces/localed/localed.c
+++ b/src/interfaces/localed/localed.c
@@ -133,6 +133,15 @@ void localed_mem_clean() {
}
+/* wrapper for glib's unix signal handling; called only once if terminating signal is raised against us */
+gboolean unix_sig_terminate_handler(gpointer data) {
+
+ g_printf("caught SIGINT/HUP/TERM, exiting\n");
+
+ localed_mem_clean();
+ return G_SOURCE_REMOVE;
+}
+
int main() {
localed_loop = g_main_loop_new(NULL, TRUE);
diff --git a/src/interfaces/logind/logind.c b/src/interfaces/logind/logind.c
index 78775cf..a0b0343 100644
--- a/src/interfaces/logind/logind.c
+++ b/src/interfaces/logind/logind.c
@@ -133,6 +133,15 @@ void logind_mem_clean() {
}
+/* wrapper for glib's unix signal handling; called only once if terminating signal is raised against us */
+gboolean unix_sig_terminate_handler(gpointer data) {
+
+ g_printf("caught SIGINT/HUP/TERM, exiting\n");
+
+ logind_mem_clean();
+ return G_SOURCE_REMOVE;
+}
+
int main() {
logind_loop = g_main_loop_new(NULL, TRUE);
diff --git a/src/interfaces/timedated/timedated.c b/src/interfaces/timedated/timedated.c
index 72d14f8..265a33f 100644
--- a/src/interfaces/timedated/timedated.c
+++ b/src/interfaces/timedated/timedated.c
@@ -133,6 +133,15 @@ void timedated_mem_clean() {
}
+/* wrapper for glib's unix signal handling; called only once if terminating signal is raised against us */
+gboolean unix_sig_terminate_handler(gpointer data) {
+
+ g_printf("caught SIGINT/HUP/TERM, exiting\n");
+
+ timedated_mem_clean();
+ return G_SOURCE_REMOVE;
+}
+
int main() {
timedated_loop = g_main_loop_new(NULL, TRUE);