aboutsummaryrefslogtreecommitdiffstats
path: root/mail/e-mail-store.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/e-mail-store.c')
-rw-r--r--mail/e-mail-store.c47
1 files changed, 15 insertions, 32 deletions
diff --git a/mail/e-mail-store.c b/mail/e-mail-store.c
index 948683d5e4..f9d18456b4 100644
--- a/mail/e-mail-store.c
+++ b/mail/e-mail-store.c
@@ -50,7 +50,6 @@ struct _StoreInfo {
gint ref_count;
CamelStore *store;
- gchar *display_name;
/* Hold a reference to keep them alive. */
CamelFolder *vtrash;
@@ -65,27 +64,17 @@ CamelStore *vfolder_store; /* XXX write a get () function for this */
static GHashTable *store_table;
static StoreInfo *
-store_info_new (CamelStore *store,
- const gchar *display_name)
+store_info_new (CamelStore *store)
{
- CamelService *service;
StoreInfo *store_info;
g_return_val_if_fail (CAMEL_IS_STORE (store), NULL);
- service = CAMEL_SERVICE (store);
-
store_info = g_slice_new0 (StoreInfo);
store_info->ref_count = 1;
store_info->store = g_object_ref (store);
- if (display_name == NULL)
- store_info->display_name =
- camel_service_get_name (service, TRUE);
- else
- store_info->display_name = g_strdup (display_name);
-
/* If these are vfolders then they need to be opened now,
* otherwise they won't keep track of all folders. */
if (store->flags & CAMEL_STORE_VTRASH)
@@ -118,7 +107,6 @@ store_info_unref (StoreInfo *store_info)
if (g_atomic_int_dec_and_test (&store_info->ref_count)) {
g_object_unref (store_info->store);
- g_free (store_info->display_name);
if (store_info->vtrash != NULL)
g_object_unref (store_info->vtrash);
@@ -167,7 +155,6 @@ mail_store_note_store_cb (MailFolderCache *folder_cache,
static void
mail_store_add (EMailSession *session,
CamelStore *store,
- const gchar *display_name,
AddStoreCallback callback)
{
EMFolderTreeModel *default_model;
@@ -187,13 +174,12 @@ mail_store_add (EMailSession *session,
default_model = em_folder_tree_model_get_default ();
folder_cache = e_mail_session_get_folder_cache (session);
- store_info = store_info_new (store, display_name);
+ store_info = store_info_new (store);
store_info->callback = callback;
g_hash_table_insert (store_table, store, store_info);
- em_folder_tree_model_add_store (
- default_model, store, store_info->display_name);
+ em_folder_tree_model_add_store (default_model, store);
mail_folder_cache_note_store (
folder_cache, CAMEL_SESSION (session), store, NULL,
@@ -231,8 +217,8 @@ mail_store_load_accounts (EMailSession *session,
local_store = e_mail_local_get_store ();
mail_store_add (
- session, local_store, _("On This Computer"),
- (AddStoreCallback) mail_store_add_local_done_cb);
+ session, local_store, (AddStoreCallback)
+ mail_store_add_local_done_cb);
/* Set up remote stores. */
@@ -280,14 +266,12 @@ e_mail_store_init (EMailSession *session,
void
e_mail_store_add (EMailSession *session,
- CamelStore *store,
- const gchar *display_name)
+ CamelStore *store)
{
g_return_if_fail (E_IS_MAIL_SESSION (session));
g_return_if_fail (CAMEL_IS_STORE (store));
- g_return_if_fail (display_name != NULL);
- mail_store_add (session, store, display_name, NULL);
+ mail_store_add (session, store, NULL);
}
CamelStore *
@@ -319,6 +303,8 @@ e_mail_store_add_by_account (EMailSession *session,
account->uid, account->source->url,
CAMEL_PROVIDER_STORE, &error);
+ camel_service_set_display_name (service, account->name);
+
handle_transport:
if (account->transport) {
@@ -358,8 +344,7 @@ handle_transport:
}
if (!skip && (provider->flags & CAMEL_PROVIDER_IS_STORAGE))
- e_mail_store_add (
- session, CAMEL_STORE (service), account->name);
+ e_mail_store_add (session, CAMEL_STORE (service));
return CAMEL_STORE (service);
@@ -434,11 +419,11 @@ e_mail_store_remove_by_account (EMailSession *session,
}
void
-e_mail_store_foreach (GHFunc func,
+e_mail_store_foreach (GFunc func,
gpointer user_data)
{
GHashTableIter iter;
- gpointer key, value;
+ gpointer store;
g_return_if_fail (func != NULL);
@@ -448,13 +433,11 @@ e_mail_store_foreach (GHFunc func,
g_hash_table_iter_init (&iter, store_table);
- while (g_hash_table_iter_next (&iter, &key, &value)) {
- StoreInfo *store_info = value;
+ while (g_hash_table_iter_next (&iter, &store, NULL)) {
/* Just being paranoid. */
- g_return_if_fail (CAMEL_IS_STORE (key));
- g_return_if_fail (store_info != NULL);
+ g_return_if_fail (CAMEL_IS_STORE (store));
- func (key, store_info->display_name, user_data);
+ func (store, user_data);
}
}