summaryrefslogtreecommitdiff
path: root/src/sydra.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/sydra.c')
-rw-r--r--src/sydra.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/src/sydra.c b/src/sydra.c
index 747d605..b45ef3c 100644
--- a/src/sydra.c
+++ b/src/sydra.c
@@ -35,15 +35,25 @@
#include <sys/select.h>
#include <time.h>
+#include <glib.h>
+#include <glib-unix.h>
#include <gst/gst.h>
#include "datatypes.h"
#include "options.h"
#include "string_list.h"
#include "log.h"
-#include "sig_handler.h"
#include "daemon.h"
+static gboolean sig_handler_terminate(gpointer user_data)
+{
+ GMainLoop *loop = (GMainLoop *)user_data;
+
+ log_printf(NOTICE, "signal received, closing application");
+ g_main_loop_quit(loop);
+ return TRUE;
+}
+
static gboolean bus_call(GstBus *bus, GstMessage *msg, gpointer data)
{
GMainLoop *loop = (GMainLoop *)data;
@@ -161,7 +171,7 @@ int main_loop(options_t* opt)
int rtcp_port_a = opt->rtp_port_base_ + 300;
char* sender_desc;
- int slen = asprintf(&sender_desc, "rtpbin name=rtpbin \
+ int slen = asprintf(&sender_desc, "rtpbin name=rtpbin \
%s ! tee name=vt \
vt. ! queue silent=true ! %s ! tee name=cvt \
cvt. ! %s ! rtpbin.send_rtp_sink_0 \
@@ -202,9 +212,10 @@ int main_loop(options_t* opt)
log_printf(INFO, "Set State: Playing");
gst_element_set_state(pipeline, GST_STATE_PLAYING);
- signal_start(loop);
+ g_unix_signal_add(SIGHUP, sig_handler_terminate, loop);
+ g_unix_signal_add(SIGINT, sig_handler_terminate, loop);
+ g_unix_signal_add(SIGTERM, sig_handler_terminate, loop);
g_main_loop_run(loop);
- signal_stop();
log_printf(NOTICE, "Stopping pipeline");
gst_element_set_state (pipeline, GST_STATE_NULL);
@@ -310,7 +321,6 @@ int main(int argc, char* argv[])
fclose(pid_file);
}
- signal_init();
gst_init(NULL, NULL);
const gchar *nano_str;
guint major, minor, micro, nano;