diff options
author | Milan Crha <mcrha@redhat.com> | 2012-08-30 21:37:11 +0800 |
---|---|---|
committer | Milan Crha <mcrha@redhat.com> | 2012-08-30 21:37:11 +0800 |
commit | 350f7118fec5b5d7bcf6a6c40d2fba6bedaf512e (patch) | |
tree | 095c36fe06e9b413ccd7d80c76ea8fe9bf5e8339 | |
parent | d34fc73590606c129cd4f72ec3b0960243217318 (diff) | |
download | gsoc2013-evolution-350f7118fec5b5d7bcf6a6c40d2fba6bedaf512e.tar.gz gsoc2013-evolution-350f7118fec5b5d7bcf6a6c40d2fba6bedaf512e.tar.zst gsoc2013-evolution-350f7118fec5b5d7bcf6a6c40d2fba6bedaf512e.zip |
Make sure evolution-alarm-notify is running on Evolution's start
-rw-r--r-- | calendar/alarm-notify/alarm-notify.c | 27 | ||||
-rw-r--r-- | calendar/alarm-notify/notify-main.c | 14 | ||||
-rw-r--r-- | modules/calendar/Makefile.am | 2 | ||||
-rw-r--r-- | modules/calendar/e-cal-shell-backend.c | 32 |
4 files changed, 63 insertions, 12 deletions
diff --git a/calendar/alarm-notify/alarm-notify.c b/calendar/alarm-notify/alarm-notify.c index 3738a7c359..dc588b726c 100644 --- a/calendar/alarm-notify/alarm-notify.c +++ b/calendar/alarm-notify/alarm-notify.c @@ -135,19 +135,12 @@ alarm_notify_startup (GApplication *application) static void alarm_notify_activate (GApplication *application) { - /* Disregard. This is just here to prevent the default - * activate method from running, which issues a warning - * if there are no handlers connected to this signal. */ -} + AlarmNotify *an = ALARM_NOTIFY (application); -static gboolean -alarm_notify_initable (GInitable *initable, - GCancellable *cancellable, - GError **error) -{ - AlarmNotify *an = ALARM_NOTIFY (initable); - - an->priv->registry = e_source_registry_new_sync (cancellable, error); + if (g_application_get_is_remote (application)) { + g_application_quit (application); + return; + } if (an->priv->registry != NULL) { alarm_notify_load_calendars (an); @@ -160,6 +153,16 @@ alarm_notify_initable (GInitable *initable, an->priv->registry, "source-removed", G_CALLBACK (alarm_notify_remove_calendar), an); } +} + +static gboolean +alarm_notify_initable (GInitable *initable, + GCancellable *cancellable, + GError **error) +{ + AlarmNotify *an = ALARM_NOTIFY (initable); + + an->priv->registry = e_source_registry_new_sync (cancellable, error); return (an->priv->registry != NULL); } diff --git a/calendar/alarm-notify/notify-main.c b/calendar/alarm-notify/notify-main.c index 2b04104417..c112331a3d 100644 --- a/calendar/alarm-notify/notify-main.c +++ b/calendar/alarm-notify/notify-main.c @@ -99,6 +99,20 @@ main (gint argc, exit (EXIT_FAILURE); } + g_application_register (G_APPLICATION (alarm_notify_service), NULL, &error); + + if (error != NULL) { + g_printerr ("%s\n", error->message); + g_error_free (error); + g_object_unref (alarm_notify_service); + exit (EXIT_FAILURE); + } + + if (g_application_get_is_remote (G_APPLICATION (alarm_notify_service))) { + g_object_unref (alarm_notify_service); + return 0; + } + exit_status = g_application_run ( G_APPLICATION (alarm_notify_service), argc, argv); diff --git a/modules/calendar/Makefile.am b/modules/calendar/Makefile.am index 0bcc72cfde..c5e547549a 100644 --- a/modules/calendar/Makefile.am +++ b/modules/calendar/Makefile.am @@ -3,6 +3,8 @@ module_LTLIBRARIES = module-calendar.la module_calendar_la_CPPFLAGS = \ $(AM_CPPFLAGS) \ -DG_LOG_DOMAIN=\"calendar-modules\" \ + -DEVOLUTION_BINDIR=\""$(bindir)"\" \ + -DEVOLUTION_PRIVLIBEXECDIR=\""$(PRIVLIBEXECDIR)"\" \ -I$(top_srcdir) \ -I$(top_srcdir)/widgets \ -DEVOLUTION_ETSPECDIR=\""$(etspecdir)"\" \ diff --git a/modules/calendar/e-cal-shell-backend.c b/modules/calendar/e-cal-shell-backend.c index 44179dc934..cb5fb243e9 100644 --- a/modules/calendar/e-cal-shell-backend.c +++ b/modules/calendar/e-cal-shell-backend.c @@ -564,6 +564,36 @@ cal_shell_backend_window_added_cb (EShellBackend *shell_backend, } static void +ensure_alarm_notify_is_running (void) +{ + const gchar *base_dir; + gchar *filename; + + #ifdef G_OS_WIN32 + base_dir = EVOLUTION_BINDIR; + #else + base_dir = EVOLUTION_PRIVLIBEXECDIR; + #endif + + filename = g_build_filename (base_dir, "evolution-alarm-notify", NULL); + + if (g_file_test (filename, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_EXECUTABLE)) { + gchar *argv[2]; + GError *error = NULL; + + argv[0] = filename; + argv[1] = NULL; + + if (!g_spawn_async (base_dir, argv, NULL, 0, NULL, NULL, NULL, &error)) + g_message ("Failed to start '%s': %s", filename, error ? error->message : "Unknown error"); + + g_clear_error (&error); + } + + g_free (filename); +} + +static void cal_shell_backend_constructed (GObject *object) { EShell *shell; @@ -607,6 +637,8 @@ cal_shell_backend_constructed (GObject *object) /* Chain up to parent's constructed() method. */ G_OBJECT_CLASS (e_cal_shell_backend_parent_class)->constructed (object); + + ensure_alarm_notify_is_running (); } static void |