empathy r1621 - trunk/src



Author: xclaesse
Date: Fri Oct 17 12:47:18 2008
New Revision: 1621
URL: http://svn.gnome.org/viewvc/empathy?rev=1621&view=rev

Log:
Display a warning when no accounts could be found for importing. (Jonny Lamb)

Signed-off-by: Jonny Lamb <jonny lamb collabora co uk>

Modified:
   trunk/src/empathy-import-dialog.c

Modified: trunk/src/empathy-import-dialog.c
==============================================================================
--- trunk/src/empathy-import-dialog.c	(original)
+++ trunk/src/empathy-import-dialog.c	Fri Oct 17 12:47:18 2008
@@ -488,17 +488,20 @@
   import_dialog_free (dialog);
 }
 
-static void
+static gboolean
 import_dialog_add_accounts_to_model (EmpathyImportDialog *dialog)
 {
   GtkTreeModel *model;
   GtkTreeIter iter;
   GList *accounts, *account;
+  guint length;
 
   model = gtk_tree_view_get_model (GTK_TREE_VIEW (dialog->treeview));
 
   accounts = import_dialog_pidgin_load ();
 
+  length = g_list_length (accounts);
+
   for (account = accounts; account; account = account->next)
     {
       GValue *value, *account_data;
@@ -521,6 +524,24 @@
     }
 
   g_list_free (accounts);
+
+  if (length == 0)
+    {
+      GtkWidget *message;
+
+      message = gtk_message_dialog_new (NULL,
+          GTK_DIALOG_MODAL, GTK_MESSAGE_WARNING,
+          GTK_BUTTONS_CLOSE,
+          _("No accounts to import could be found. Empathy currently only "
+            "supports importing accounts from Pidgin."));
+
+      gtk_dialog_run (GTK_DIALOG (message));
+      gtk_widget_destroy (message);
+      import_dialog_free (dialog);
+      return FALSE;
+    }
+  else
+    return TRUE;
 }
 
 static void
@@ -544,7 +565,7 @@
   gtk_tree_path_free (path);
 }
 
-static void
+static gboolean
 import_dialog_set_up_account_list (EmpathyImportDialog *dialog)
 {
   GtkListStore *store;
@@ -612,7 +633,7 @@
   gtk_tree_view_column_pack_start (column, cell, TRUE);
   gtk_tree_view_column_add_attribute (column, cell, "text", COL_SOURCE);
 
-  import_dialog_add_accounts_to_model (dialog);
+  return import_dialog_add_accounts_to_model (dialog);
 }
 
 void
@@ -644,8 +665,6 @@
       "button_cancel", "clicked", import_dialog_button_cancel_clicked_cb,
       NULL);
 
-  import_dialog_set_up_account_list (dialog);
-
   g_object_add_weak_pointer (G_OBJECT (dialog->window), (gpointer) &dialog);
 
   g_free (filename);
@@ -654,5 +673,6 @@
   if (parent)
     gtk_window_set_transient_for (GTK_WINDOW (dialog->window), parent);
 
-  gtk_widget_show (dialog->window);
+  if (import_dialog_set_up_account_list (dialog))
+    gtk_widget_show (dialog->window);
 }



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]