X-Git-Url: https://git.0d.be/?p=empathy.git;a=blobdiff_plain;f=src%2Fempathy-chat.c;h=b35480dc912b92c3b359e4aa782e79b9cdbe9a26;hp=3094b5137015f3063be880cbd336de163416285e;hb=15aa6a83ff96fad9f959762f2b57646f9e735cd1;hpb=26b9e04f1c40888bba66bcaace30d9f0feac45fc diff --git a/src/empathy-chat.c b/src/empathy-chat.c index 3094b513..b35480dc 100644 --- a/src/empathy-chat.c +++ b/src/empathy-chat.c @@ -20,32 +20,25 @@ * Guillaume Desmottes */ -#include +#include "config.h" -#include #include -#include - #include -#include - -#include -#include - -#include -#include - +#include "empathy-bus-names.h" #include "empathy-chat-manager.h" +#include "empathy-chat-resources.h" +#include "empathy-presence-manager.h" +#include "empathy-theme-manager.h" +#include "empathy-ui-utils.h" +#include "empathy-utils.h" #define DEBUG_FLAG EMPATHY_DEBUG_CHAT -#include +#include "empathy-debug.h" /* Exit after $TIMEOUT seconds if not displaying any call window */ #define TIMEOUT 60 -#define EMPATHY_CHAT_DBUS_NAME "org.gnome.Empathy.Chat" - static GtkApplication *app = NULL; static gboolean activated = FALSE; static gboolean use_timer = TRUE; @@ -72,6 +65,7 @@ activate_cb (GApplication *application) return; activated = TRUE; + empathy_gtk_init (); if (!use_timer) { @@ -82,6 +76,8 @@ activate_cb (GApplication *application) g_assert (chat_mgr == NULL); chat_mgr = empathy_chat_manager_dup_singleton (); + empathy_chat_window_present_chat(NULL, 0); + g_signal_connect (chat_mgr, "displayed-chats-changed", G_CALLBACK (displayed_chats_changed_cb), GUINT_TO_POINTER (1)); } @@ -94,6 +90,7 @@ main (int argc, GOptionEntry options[] = { { NULL } }; + GResource *resource; #ifdef ENABLE_DEBUG TpDebugSender *debug_sender; #endif @@ -101,10 +98,9 @@ main (int argc, EmpathyPresenceManager *presence_mgr; EmpathyThemeManager *theme_mgr; gint retval; - EmpathyIndividualManager *individual_mgr; optcontext = g_option_context_new (N_("- Empathy Chat Client")); - g_option_context_add_group (optcontext, gtk_get_option_group (TRUE)); + g_option_context_add_group (optcontext, gtk_get_option_group (FALSE)); g_option_context_add_main_entries (optcontext, options, GETTEXT_PACKAGE); g_option_context_set_translation_domain (optcontext, GETTEXT_PACKAGE); @@ -119,7 +115,7 @@ main (int argc, g_option_context_free (optcontext); - empathy_gtk_init (); + empathy_init (); /* Make empathy and empathy-chat appear as the same app in gnome-shell */ gdk_set_program_class ("Empathy"); @@ -128,7 +124,10 @@ main (int argc, notify_init (_(PACKAGE_NAME)); - app = gtk_application_new (EMPATHY_CHAT_DBUS_NAME, G_APPLICATION_FLAGS_NONE); + resource = empathy_chat_get_resource (); + g_resources_register (resource); + + app = gtk_application_new (EMPATHY_CHAT_BUS_NAME, G_APPLICATION_FLAGS_NONE); g_signal_connect (app, "activate", G_CALLBACK (activate_cb), NULL); #ifdef ENABLE_DEBUG @@ -143,10 +142,6 @@ main (int argc, /* Keep the theme manager alive as it does some caching */ theme_mgr = empathy_theme_manager_dup_singleton (); - /* Keep the individual manager alive so we won't fetch everything from Folks - * each time we need to use it. */ - individual_mgr = empathy_individual_manager_dup_singleton (); - if (g_getenv ("EMPATHY_PERSIST") != NULL) { DEBUG ("Disable timer"); @@ -167,12 +162,14 @@ main (int argc, g_object_unref (presence_mgr); g_object_unref (theme_mgr); tp_clear_object (&chat_mgr); - g_object_unref (individual_mgr); #ifdef ENABLE_DEBUG g_object_unref (debug_sender); #endif + g_resources_unregister (resource); + g_resource_unref (resource); + notify_uninit (); return retval;