diff options
-rw-r--r-- | ChangeLog | 14 | ||||
-rwxr-xr-x | autogen.sh | 2 | ||||
-rw-r--r-- | libempathy/gossip-chatroom-manager.c | 52 | ||||
-rw-r--r-- | src/Makefile.am | 18 | ||||
-rw-r--r-- | src/empathy-accounts.c (renamed from src/empathy-accounts-main.c) | 0 | ||||
-rw-r--r-- | src/empathy-chat-main.c | 200 | ||||
-rw-r--r-- | src/empathy.c (renamed from src/empathy-main.c) | 91 | ||||
-rw-r--r-- | src/org.gnome.Empathy.Chat.service.in | 2 |
8 files changed, 92 insertions, 287 deletions
@@ -1,5 +1,19 @@ 2007-06-14 Xavier Claessens <xclaesse@gmail.com> + * src/org.gnome.Empathy.Chat.service.in: + * src/empathy-accounts.c: + * src/empathy-accounts-main.c: + * src/empathy-chat-main.c: + * src/empathy.c: + * src/Makefile.am: + * src/empathy-main.c: + * libempathy/gossip-chatroom-manager.c: + * autogen.sh: Empathy is no more splitted into 2 processes. It makes + debugging more difficult when emmpathy-chat crashes. It's also more + optimised like that since contact objects can be shared. + +2007-06-14 Xavier Claessens <xclaesse@gmail.com> + * libempathy-gtk/gossip-chat-window.c: Disconnect signals from chatroom_manager. Fixes bug #447178. diff --git a/autogen.sh b/autogen.sh index c5d700121..371172140 100755 --- a/autogen.sh +++ b/autogen.sh @@ -17,7 +17,7 @@ ORIGDIR=`pwd` cd $srcdir PROJECT="empathy" TEST_TYPE=-f -FILE=src/empathy-main.c +FILE=src/empathy.c CONFIGURE=configure.ac DIE=0 diff --git a/libempathy/gossip-chatroom-manager.c b/libempathy/gossip-chatroom-manager.c index f85d5407e..cc6aa81ad 100644 --- a/libempathy/gossip-chatroom-manager.c +++ b/libempathy/gossip-chatroom-manager.c @@ -31,8 +31,6 @@ #include <libxml/parser.h> #include <libxml/tree.h> -#include <libgnomevfs/gnome-vfs.h> - #include "gossip-debug.h" #include "gossip-chatroom-manager.h" #include "gossip-utils.h" @@ -46,18 +44,12 @@ struct _GossipChatroomManagerPriv { GList *chatrooms; - GHashTable *monitors; }; static void gossip_chatroom_manager_class_init (GossipChatroomManagerClass *klass); static void gossip_chatroom_manager_init (GossipChatroomManager *manager); static void chatroom_manager_finalize (GObject *object); static gboolean chatroom_manager_get_all (GossipChatroomManager *manager); -static void chatroom_manager_file_changed_cb (GnomeVFSMonitorHandle *handle, - const gchar *monitor_uri, - const gchar *info_uri, - GnomeVFSMonitorEventType event_type, - GossipChatroomManager *manager); static gboolean chatroom_manager_file_parse (GossipChatroomManager *manager, const gchar *filename); static void chatroom_manager_parse_chatroom (GossipChatroomManager *manager, @@ -110,11 +102,6 @@ gossip_chatroom_manager_init (GossipChatroomManager *manager) GossipChatroomManagerPriv *priv; priv = GET_PRIV (manager); - - priv->monitors = g_hash_table_new_full (g_str_hash, - g_str_equal, - (GDestroyNotify) g_free, - (GDestroyNotify) gnome_vfs_monitor_cancel); } static void @@ -126,7 +113,6 @@ chatroom_manager_finalize (GObject *object) g_list_foreach (priv->chatrooms, (GFunc) g_object_unref, NULL); g_list_free (priv->chatrooms); - g_hash_table_destroy (priv->monitors); (G_OBJECT_CLASS (gossip_chatroom_manager_parent_class)->finalize) (object); } @@ -340,31 +326,6 @@ chatroom_manager_get_all (GossipChatroomManager *manager) return TRUE; } -static void -chatroom_manager_file_changed_cb (GnomeVFSMonitorHandle *handle, - const gchar *monitor_uri, - const gchar *info_uri, - GnomeVFSMonitorEventType event_type, - GossipChatroomManager *manager) -{ - GossipChatroomManagerPriv *priv; - GList *l; - - priv = GET_PRIV (manager); - - gossip_debug (DEBUG_DOMAIN, "Reload file: %s", monitor_uri); - - /* FIXME: This is not optimised */ - for (l = priv->chatrooms; l; l = l->next) { - g_signal_emit (manager, signals[CHATROOM_REMOVED], 0, l->data); - g_object_unref (l->data); - } - g_list_free (priv->chatrooms); - priv->chatrooms = NULL; - - chatroom_manager_get_all (manager); -} - static gboolean chatroom_manager_file_parse (GossipChatroomManager *manager, const gchar *filename) @@ -377,19 +338,6 @@ chatroom_manager_file_parse (GossipChatroomManager *manager, priv = GET_PRIV (manager); - /* Do not monitor this file twice if it's already monitored */ - if (!g_hash_table_lookup (priv->monitors, filename)) { - GnomeVFSMonitorHandle *handle; - - gnome_vfs_monitor_add (&handle, - filename, - GNOME_VFS_MONITOR_FILE, - (GnomeVFSMonitorCallback) chatroom_manager_file_changed_cb, - manager); - - g_hash_table_insert (priv->monitors, g_strdup (filename), handle); - } - gossip_debug (DEBUG_DOMAIN, "Attempting to parse file:'%s'...", filename); ctxt = xmlNewParserCtxt (); diff --git a/src/Makefile.am b/src/Makefile.am index 0f0c2d0c0..b89a4218d 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -1,4 +1,4 @@ -cppflags = \ +AM_CPPFLAGS = \ -I$(top_srcdir) \ -DPREFIX="\"$(prefix)"\" \ -DSYSCONFDIR=\""$(sysconfdir)"\" \ @@ -8,26 +8,16 @@ cppflags = \ $(EMPATHY_CFLAGS) \ $(WARN_CFLAGS) -libs = \ +LDADD = \ $(top_builddir)/libempathy-gtk/libempathy-gtk.la \ $(EMPATHY_LIBS) bin_PROGRAMS = \ empathy \ - empathy-chat \ empathy-accounts -empathy_SOURCES = empathy-main.c -empathy_CPPFLAGS = $(cppflags) -empathy_LDADD = $(libs) - -empathy_accounts_SOURCES = empathy-accounts-main.c -empathy_accounts_CPPFLAGS = $(cppflags) -empathy_accounts_LDADD = $(libs) - -empathy_chat_SOURCES = empathy-chat-main.c -empathy_chat_CPPFLAGS = $(cppflags) -empathy_chat_LDADD = $(libs) +empathy_SOURCES = empathy.c +empathy_accounts_SOURCES = empathy-accounts.c # Dbus service file servicedir = $(datadir)/dbus-1/services diff --git a/src/empathy-accounts-main.c b/src/empathy-accounts.c index bc569d315..bc569d315 100644 --- a/src/empathy-accounts-main.c +++ b/src/empathy-accounts.c diff --git a/src/empathy-chat-main.c b/src/empathy-chat-main.c deleted file mode 100644 index 3af734ba8..000000000 --- a/src/empathy-chat-main.c +++ /dev/null @@ -1,200 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ -/* - * Copyright (C) 2007 Collabora Ltd. - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of the - * License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * General Public License for more details. - * - * You should have received a copy of the GNU General Public - * License along with this program; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place - Suite 330, - * Boston, MA 02111-1307, USA. - * - * Authors: Xavier Claessens <xclaesse@gmail.com> - */ - -#include <config.h> - -#include <stdlib.h> - -#include <glib.h> -#include <glib/gi18n.h> -#include <gtk/gtk.h> - -#include <libgnome/gnome-program.h> -#include <libgnomeui/gnome-ui-init.h> - -#include <libtelepathy/tp-conn.h> -#include <libtelepathy/tp-chan.h> -#include <libmissioncontrol/mc-account.h> - -#include <libempathy/gossip-contact.h> -#include <libempathy/gossip-debug.h> -#include <libempathy/gossip-utils.h> -#include <libempathy/empathy-chandler.h> -#include <libempathy/empathy-tp-chat.h> -#include <libempathy-gtk/gossip-private-chat.h> -#include <libempathy-gtk/gossip-group-chat.h> - -#define DEBUG_DOMAIN "ChatMain" - -#define BUS_NAME "org.gnome.Empathy.Chat" -#define OBJECT_PATH "/org/freedesktop/Telepathy/ChannelHandler" - -/* Time to wait before exit, in seconds */ -#define EXIT_TIMEOUT 5 - - -static guint chat_count = 0; -static guint exit_timeout = 0; -static gboolean debug_mode = FALSE; - -static gboolean -exit_timeout_cb (gpointer user_data) -{ - gossip_debug (DEBUG_DOMAIN, "Timeout, exiting"); - - gtk_main_quit (); - - return FALSE; -} - -static void -exit_timeout_start (void) -{ - if (exit_timeout || debug_mode) { - return; - } - - exit_timeout = g_timeout_add (EXIT_TIMEOUT * 1000, - (GSourceFunc) exit_timeout_cb, - NULL); -} - -static void -exit_timeout_stop (void) -{ - if (exit_timeout) { - gossip_debug (DEBUG_DOMAIN, "Exit timeout canceled"); - g_source_remove (exit_timeout); - exit_timeout = 0; - } -} - -static void -chat_finalized_cb (gpointer user_data, - GossipChat *chat) -{ - chat_count--; - if (chat_count == 0) { - gossip_debug (DEBUG_DOMAIN, "No more chat, start exit timeout"); - exit_timeout_start (); - } -} - -static void -new_channel_cb (EmpathyChandler *chandler, - TpConn *tp_conn, - TpChan *tp_chan, - gpointer user_data) -{ - MissionControl *mc; - McAccount *account; - GossipChat *chat; - gchar *id; - - mc = gossip_mission_control_new (); - account = mission_control_get_account_for_connection (mc, tp_conn, NULL); - id = gossip_get_channel_id (account, tp_chan); - chat = gossip_chat_window_find_chat (account, id); - - g_free (id); - g_object_unref (mc); - - if (chat) { - /* The chat already exists */ - if (!gossip_chat_is_connected (chat)) { - EmpathyTpChat *tp_chat; - - /* The chat died, give him the new text channel */ - tp_chat = empathy_tp_chat_new (account, tp_chan); - gossip_chat_set_tp_chat (chat, tp_chat); - g_object_unref (tp_chat); - } - gossip_chat_present (chat); - - g_object_unref (account); - return; - } - - if (tp_chan->handle_type == TP_HANDLE_TYPE_CONTACT) { - /* We have a new private chat channel */ - chat = GOSSIP_CHAT (gossip_private_chat_new (account, tp_chan)); - } - else if (tp_chan->handle_type == TP_HANDLE_TYPE_ROOM) { - /* We have a new group chat channel */ - chat = GOSSIP_CHAT (gossip_group_chat_new (account, tp_chan)); - } - - g_object_weak_ref (G_OBJECT (chat), - (GWeakNotify) chat_finalized_cb, - NULL); - - exit_timeout_stop (); - chat_count++; - - gossip_chat_present (GOSSIP_CHAT (chat)); - - g_object_unref (chat); - g_object_unref (account); - -} - -int -main (int argc, char *argv[]) -{ - EmpathyChandler *chandler; - GnomeProgram *program; - - bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR); - bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8"); - textdomain (GETTEXT_PACKAGE); - - program = gnome_program_init ("empathy-chat", - PACKAGE_VERSION, - LIBGNOMEUI_MODULE, - argc, argv, - GNOME_PROGRAM_STANDARD_PROPERTIES, - GNOME_PARAM_HUMAN_READABLE_NAME, PACKAGE_NAME, - NULL); - - gtk_window_set_default_icon_name ("empathy"); - gtk_icon_theme_append_search_path (gtk_icon_theme_get_default (), - DATADIR G_DIR_SEPARATOR_S "empathy"); - - if (g_getenv ("EMPATHY_DEBUG")) { - debug_mode = TRUE; - } - - //sexit_timeout_start (); - chandler = empathy_chandler_new (BUS_NAME, OBJECT_PATH); - - g_signal_connect (chandler, "new-channel", - G_CALLBACK (new_channel_cb), - NULL); - - gtk_main (); - - g_object_unref (program); - g_object_unref (chandler); - - return EXIT_SUCCESS; -} - diff --git a/src/empathy-main.c b/src/empathy.c index 92a66b2c8..51fa25937 100644 --- a/src/empathy-main.c +++ b/src/empathy.c @@ -31,6 +31,8 @@ #include <libgnome/gnome-program.h> #include <libgnomeui/gnome-ui-init.h> +#include <libtelepathy/tp-conn.h> +#include <libtelepathy/tp-chan.h> #include <libmissioncontrol/mc-account.h> #include <libmissioncontrol/mc-account-monitor.h> #include <libmissioncontrol/mission-control.h> @@ -38,21 +40,18 @@ #include <libempathy/gossip-debug.h> #include <libempathy/gossip-utils.h> #include <libempathy/gossip-presence.h> +#include <libempathy/gossip-contact.h> +#include <libempathy/empathy-chandler.h> +#include <libempathy/empathy-tp-chat.h> #include <libempathy-gtk/empathy-main-window.h> #include <libempathy-gtk/empathy-status-icon.h> +#include <libempathy-gtk/gossip-private-chat.h> +#include <libempathy-gtk/gossip-group-chat.h> #define DEBUG_DOMAIN "EmpathyMain" -static void error_cb (MissionControl *mc, - GError *error, - gpointer data); -static void service_ended_cb (MissionControl *mc, - gpointer user_data); -static void operation_error_cb (MissionControl *mc, - guint operation_id, - guint error_code, - gpointer user_data); -static void start_mission_control (MissionControl *mc); +#define BUS_NAME "org.gnome.Empathy.Chat" +#define OBJECT_PATH "/org/freedesktop/Telepathy/ChannelHandler" static void error_cb (MissionControl *mc, @@ -83,15 +82,6 @@ operation_error_cb (MissionControl *mc, } static void -account_enabled_cb (McAccountMonitor *monitor, - gchar *unique_name, - MissionControl *mc) -{ - gossip_debug (DEBUG_DOMAIN, "Account enabled: %s", unique_name); - start_mission_control (mc); -} - -static void start_mission_control (MissionControl *mc) { McPresence presence; @@ -112,6 +102,61 @@ start_mission_control (MissionControl *mc) NULL); } +static void +account_enabled_cb (McAccountMonitor *monitor, + gchar *unique_name, + MissionControl *mc) +{ + gossip_debug (DEBUG_DOMAIN, "Account enabled: %s", unique_name); + start_mission_control (mc); +} + +static void +new_channel_cb (EmpathyChandler *chandler, + TpConn *tp_conn, + TpChan *tp_chan, + MissionControl *mc) +{ + McAccount *account; + GossipChat *chat; + gchar *id; + + account = mission_control_get_account_for_connection (mc, tp_conn, NULL); + id = gossip_get_channel_id (account, tp_chan); + chat = gossip_chat_window_find_chat (account, id); + g_free (id); + + if (chat) { + /* The chat already exists */ + if (!gossip_chat_is_connected (chat)) { + EmpathyTpChat *tp_chat; + + /* The chat died, give him the new text channel */ + tp_chat = empathy_tp_chat_new (account, tp_chan); + gossip_chat_set_tp_chat (chat, tp_chat); + g_object_unref (tp_chat); + } + gossip_chat_present (chat); + + g_object_unref (account); + return; + } + + if (tp_chan->handle_type == TP_HANDLE_TYPE_CONTACT) { + /* We have a new private chat channel */ + chat = GOSSIP_CHAT (gossip_private_chat_new (account, tp_chan)); + } + else if (tp_chan->handle_type == TP_HANDLE_TYPE_ROOM) { + /* We have a new group chat channel */ + chat = GOSSIP_CHAT (gossip_group_chat_new (account, tp_chan)); + } + + gossip_chat_present (GOSSIP_CHAT (chat)); + + g_object_unref (chat); + g_object_unref (account); +} + int main (int argc, char *argv[]) { @@ -119,6 +164,7 @@ main (int argc, char *argv[]) GtkWidget *window; MissionControl *mc; McAccountMonitor *monitor; + EmpathyChandler *chandler; GnomeProgram *program; gboolean no_connect = FALSE; GOptionContext *context; @@ -173,12 +219,19 @@ main (int argc, char *argv[]) window = empathy_main_window_show (); icon = empathy_status_icon_new (GTK_WINDOW (window)); + /* Setting up channel handler */ + chandler = empathy_chandler_new (BUS_NAME, OBJECT_PATH); + g_signal_connect (chandler, "new-channel", + G_CALLBACK (new_channel_cb), + mc); + gtk_main (); mission_control_set_presence (mc, MC_PRESENCE_OFFLINE, NULL, NULL, NULL); + g_object_unref (chandler); g_object_unref (monitor); g_object_unref (mc); g_object_unref (icon); diff --git a/src/org.gnome.Empathy.Chat.service.in b/src/org.gnome.Empathy.Chat.service.in index 6a794e4b8..071c96e96 100644 --- a/src/org.gnome.Empathy.Chat.service.in +++ b/src/org.gnome.Empathy.Chat.service.in @@ -1,3 +1,3 @@ [D-BUS Service] Name=org.gnome.Empathy.Chat -Exec=@bindir@/empathy-chat +Exec=@bindir@/empathy |