aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-account-widget-jabber.c
diff options
context:
space:
mode:
Diffstat (limited to 'libempathy-gtk/empathy-account-widget-jabber.c')
-rw-r--r--libempathy-gtk/empathy-account-widget-jabber.c27
1 files changed, 19 insertions, 8 deletions
diff --git a/libempathy-gtk/empathy-account-widget-jabber.c b/libempathy-gtk/empathy-account-widget-jabber.c
index a4db08fdf..947da4a0e 100644
--- a/libempathy-gtk/empathy-account-widget-jabber.c
+++ b/libempathy-gtk/empathy-account-widget-jabber.c
@@ -102,15 +102,26 @@ account_widget_jabber_entry_focus_cb (GtkWidget *widget,
mc_account_set_param_string (settings->account, param, str);
if (widget == settings->entry_id) {
- /* Try to guess the server */
- gchar *server;
-
- server = strstr (str, "@");
- if (server != NULL) {
- /* skip the leading @ */
- server++;
- gtk_entry_set_text (GTK_ENTRY (settings->entry_server), server);
+ McProfile *profile;
+ const gchar *profile_name;
+
+ /* Try to guess the server if we are using the vanilla
+ * jabber profile. We don't have to do that with
+ * gtalk profile. */
+ profile = mc_account_get_profile (settings->account);
+ profile_name = mc_profile_get_unique_name (profile);
+ if (strcmp (profile_name, "jabber") == 0) {
+ gchar *server;
+
+ server = strstr (str, "@");
+ if (server != NULL) {
+ /* skip the leading @ */
+ server++;
+ gtk_entry_set_text (GTK_ENTRY (settings->entry_server), server);
+ mc_account_set_param_string (settings->account, "server", server);
+ }
}
+ g_object_unref (profile);
}
}