diff options
author | Ted Gould <ted@gould.cx> | 2015-02-11 15:47:12 -0600 |
---|---|---|
committer | Ted Gould <ted@gould.cx> | 2015-02-11 15:47:12 -0600 |
commit | 10d44ff66a7efb25cd2f69300ed04e97b084034f (patch) | |
tree | b8298900d2d72ead4471ba9a32abd2e2af9beb20 /src/main.c | |
parent | 48117fc3ea085d123567ccb621809f43a4358938 (diff) | |
download | ayatana-indicator-sound-10d44ff66a7efb25cd2f69300ed04e97b084034f.tar.gz ayatana-indicator-sound-10d44ff66a7efb25cd2f69300ed04e97b084034f.tar.bz2 ayatana-indicator-sound-10d44ff66a7efb25cd2f69300ed04e97b084034f.zip |
Pulling the mainloop out of the service object
Diffstat (limited to 'src/main.c')
-rw-r--r-- | src/main.c | 22 |
1 files changed, 18 insertions, 4 deletions
@@ -9,15 +9,28 @@ #include "indicator-sound-service.h" #include "config.h" +gboolean +sigterm_handler (gpointer data) +{ + g_debug("Got SIGTERM"); + g_main_loop_quit((GMainLoop *)data); + return G_SOURCE_REMOVE; +} + int main (int argc, char ** argv) { - gint result = 0; + GMainLoop * loop = NULL; IndicatorSoundService* service = NULL; bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8"); setlocale (LC_ALL, ""); bindtextdomain (GETTEXT_PACKAGE, GNOMELOCALEDIR); + /* Build Mainloop */ + loop = g_main_loop_new(NULL, FALSE); + + g_unix_signal_add(SIGTERM, sigterm_handler, loop); + /* Initialize libnotify */ notify_init ("indicator-sound"); @@ -33,14 +46,15 @@ main (int argc, char ** argv) { VolumeControlPulse * volume = volume_control_pulse_new(); - service = indicator_sound_service_new (playerlist, volume, accounts); - result = indicator_sound_service_run (service); + service = indicator_sound_service_new (loop, playerlist, volume, accounts); + + g_main_loop_run(loop); g_object_unref(playerlist); g_clear_object(&accounts); g_object_unref(service); - return result; + return 0; } |