diff options
Diffstat (limited to 'camel/providers')
-rw-r--r-- | camel/providers/mbox/camel-mbox-store.c | 26 | ||||
-rw-r--r-- | camel/providers/pop3/camel-pop3-store.c | 31 |
2 files changed, 43 insertions, 14 deletions
diff --git a/camel/providers/mbox/camel-mbox-store.c b/camel/providers/mbox/camel-mbox-store.c index 32d25becf1..0081aedb0e 100644 --- a/camel/providers/mbox/camel-mbox-store.c +++ b/camel/providers/mbox/camel-mbox-store.c @@ -35,8 +35,10 @@ #define CF_CLASS(so) CAMEL_FOLDER_CLASS (GTK_OBJECT(so)->klass) #define CMBOXF_CLASS(so) CAMEL_MBOX_FOLDER_CLASS (GTK_OBJECT(so)->klass) -static CamelFolder *_get_folder (CamelStore *store, const gchar *folder_name, CamelException *ex); - +static CamelFolder *get_folder (CamelStore *store, const char *folder_name, + CamelException *ex); +static char *get_folder_name (CamelStore *store, const char *folder_name, + CamelException *ex); static void camel_mbox_store_class_init (CamelMboxStoreClass *camel_mbox_store_class) @@ -44,7 +46,8 @@ camel_mbox_store_class_init (CamelMboxStoreClass *camel_mbox_store_class) CamelStoreClass *camel_store_class = CAMEL_STORE_CLASS (camel_mbox_store_class); /* virtual method overload */ - camel_store_class->get_folder = _get_folder; + camel_store_class->get_folder = get_folder; + camel_store_class->get_folder_name = get_folder_name; } @@ -53,8 +56,12 @@ static void camel_mbox_store_init (gpointer object, gpointer klass) { CamelService *service = CAMEL_SERVICE (object); + CamelStore *store = CAMEL_STORE (object); service->url_flags = CAMEL_SERVICE_URL_NEED_PATH; + + /* mbox names are filenames, so they are case-sensitive. */ + store->folders = g_hash_table_new (g_str_hash, g_str_equal); } @@ -97,15 +104,11 @@ camel_mbox_store_get_toplevel_dir (CamelMboxStore *store) static CamelFolder * -_get_folder (CamelStore *store, const gchar *folder_name, CamelException *ex) +get_folder (CamelStore *store, const char *folder_name, CamelException *ex) { CamelMboxFolder *new_mbox_folder; CamelFolder *new_folder; - /* check if folder has already been created */ - /* call the standard routine for that when */ - /* it is done ... */ - CAMEL_LOG_FULL_DEBUG ("Entering CamelMboxStore::get_folder\n"); new_mbox_folder = gtk_type_new (CAMEL_MBOX_FOLDER_TYPE); new_folder = CAMEL_FOLDER (new_mbox_folder); @@ -121,3 +124,10 @@ _get_folder (CamelStore *store, const gchar *folder_name, CamelException *ex) return new_folder; } + +static char * +get_folder_name (CamelStore *store, const char *folder_name, + CamelException *ex) +{ + return g_strdup (folder_name); +} diff --git a/camel/providers/pop3/camel-pop3-store.c b/camel/providers/pop3/camel-pop3-store.c index f14ed1dc55..b63cd30342 100644 --- a/camel/providers/pop3/camel-pop3-store.c +++ b/camel/providers/pop3/camel-pop3-store.c @@ -55,8 +55,11 @@ static gboolean pop3_disconnect (CamelService *service, CamelException *ex); static GList *query_auth_types (CamelService *service); static void free_auth_types (CamelService *service, GList *authtypes); -static CamelFolder *get_folder (CamelStore *store, const gchar *folder_name, +static CamelFolder *get_folder (CamelStore *store, const char *folder_name, CamelException *ex); +static char *get_folder_name (CamelStore *store, const char *folder_name, + CamelException *ex); +static char *get_root_folder_name (CamelStore *store, CamelException *ex); static void @@ -79,9 +82,9 @@ camel_pop3_store_class_init (CamelPop3StoreClass *camel_pop3_store_class) camel_service_class->query_auth_types = query_auth_types; camel_service_class->free_auth_types = free_auth_types; - camel_store_class->get_root_folder = camel_pop3_folder_new; - camel_store_class->get_default_folder = camel_pop3_folder_new; camel_store_class->get_folder = get_folder; + camel_store_class->get_folder_name = get_folder_name; + camel_store_class->get_root_folder_name = get_root_folder_name; } @@ -90,9 +93,11 @@ static void camel_pop3_store_init (gpointer object, gpointer klass) { CamelService *service = CAMEL_SERVICE (object); + CamelStore *store = CAMEL_STORE (object); service->url_flags = ( CAMEL_SERVICE_URL_NEED_USER | CAMEL_SERVICE_URL_NEED_HOST ); + store->folders = g_hash_table_new (g_str_hash, g_str_equal); } @@ -324,11 +329,18 @@ pop3_disconnect (CamelService *service, CamelException *ex) return TRUE; } -static CamelFolder *get_folder (CamelStore *store, const gchar *folder_name, - CamelException *ex) +static CamelFolder * +get_folder (CamelStore *store, const char *folder_name, CamelException *ex) +{ + return camel_pop3_folder_new (store, ex); +} + +static char * +get_folder_name (CamelStore *store, const char *folder_name, + CamelException *ex) { if (!strcasecmp (folder_name, "inbox")) - return camel_pop3_folder_new (store, ex); + return g_strdup ("inbox"); else { camel_exception_setv (ex, CAMEL_EXCEPTION_FOLDER_INVALID, "No such folder `%s'.", folder_name); @@ -336,6 +348,13 @@ static CamelFolder *get_folder (CamelStore *store, const gchar *folder_name, } } +static char * +get_root_folder_name (CamelStore *store, CamelException *ex) +{ + return g_strdup ("inbox"); +} + + /** * camel_pop3_command: Send a command to a POP3 server. * @store: the POP3 store |