aboutsummaryrefslogtreecommitdiffstats
path: root/mail/component-factory.c
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2002-06-07 04:56:43 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2002-06-07 04:56:43 +0800
commite0a6088f3374aa60c176dcc058595c801d31351c (patch)
tree633e6d009b4042a8c32e8a2c5b345c1d23cf2ae9 /mail/component-factory.c
parent2dd7e35afd3c0985aed13c80eb1f670c669a66aa (diff)
downloadgsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.tar
gsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.tar.gz
gsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.tar.bz2
gsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.tar.lz
gsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.tar.xz
gsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.tar.zst
gsoc2013-evolution-e0a6088f3374aa60c176dcc058595c801d31351c.zip
If this account is not a completely new account (ie, it is an edited
2002-06-06 Jeffrey Stedfast <fejj@ximian.com> * mail-account-gui.c (mail_account_gui_save): If this account is not a completely new account (ie, it is an edited account), then remove any trace of it from the shell storages. If the new account belongs in the folder-tree, add it to the list of storages. * component-factory.c (mail_add_storage): New function to add a single storage. svn path=/trunk/; revision=17138
Diffstat (limited to 'mail/component-factory.c')
-rw-r--r--mail/component-factory.c37
1 files changed, 33 insertions, 4 deletions
diff --git a/mail/component-factory.c b/mail/component-factory.c
index 668b1fef48..df4a08c9ae 100644
--- a/mail/component-factory.c
+++ b/mail/component-factory.c
@@ -1283,6 +1283,34 @@ add_storage (const char *name, const char *uri, CamelService *store,
}
}
+
+void
+mail_add_storage (CamelStore *store, const char *name, const char *uri)
+{
+ EvolutionShellClient *shell_client;
+ GNOME_Evolution_Shell shell;
+ CamelException ex;
+
+ g_return_if_fail (CAMEL_IS_STORE (store));
+
+ shell_client = evolution_shell_component_get_owner (shell_component);
+ shell = bonobo_object_corba_objref (BONOBO_OBJECT (shell_client));
+
+ camel_exception_init (&ex);
+
+ if (name == NULL) {
+ char *service_name;
+
+ service_name = camel_service_get_name (store, TRUE);
+ add_storage (service_name, uri, store, shell, &ex);
+ g_free (service_name);
+ } else {
+ add_storage (name, uri, store, shell, &ex);
+ }
+
+ camel_exception_clear (&ex);
+}
+
void
mail_load_storage_by_uri (GNOME_Evolution_Shell shell, const char *uri, const char *name)
{
@@ -1338,7 +1366,8 @@ mail_load_storage_by_uri (GNOME_Evolution_Shell shell, const char *uri, const ch
camel_object_unref (CAMEL_OBJECT (store));
}
-/* FIXME: 'is_account_data' is an ugly hack, if we remove support for NNTP we can take it out -- fejj */
+/* FIXME: 'is_account_data' is an ugly hack, if we move support for
+ NNTP into the normal Account stuff, we can take it out -- fejj */
void
mail_load_storages (GNOME_Evolution_Shell shell, const GSList *sources, gboolean is_account_data)
{
@@ -1380,7 +1409,7 @@ mail_hash_storage (CamelService *store, EvolutionStorage *storage)
g_hash_table_insert (storages_hash, store, storage);
}
-EvolutionStorage*
+EvolutionStorage *
mail_lookup_storage (CamelStore *store)
{
EvolutionStorage *storage;
@@ -1423,7 +1452,7 @@ mail_remove_storage (CamelStore *store)
return;
g_hash_table_remove (storages_hash, store);
-
+
/* so i guess potentially we could have a race, add a store while one
being removed. ?? */
mail_note_store_remove(store);
@@ -1432,7 +1461,7 @@ mail_remove_storage (CamelStore *store)
corba_shell = bonobo_object_corba_objref (BONOBO_OBJECT (shell_client));
evolution_storage_deregister_on_shell (storage, corba_shell);
-
+
mail_async_event_emit(async_event, MAIL_ASYNC_THREAD, (MailAsyncFunc)store_disconnect, store, NULL, NULL);
}