aboutsummaryrefslogtreecommitdiffstats
path: root/camel/providers/pop3/camel-pop3-store.c
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2002-07-17 20:17:52 +0800
committerMichael Zucci <zucchi@src.gnome.org>2002-07-17 20:17:52 +0800
commita2affe7e4dbec98b1080f9650123c33cdfb4005d (patch)
tree5403f80ac8bca13a977716b9823307a722c6b529 /camel/providers/pop3/camel-pop3-store.c
parent3556d21a8e198b9ffbae74501a10bfe224d31cab (diff)
downloadgsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar.gz
gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar.zst
gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.zip
Got rid of the stupid "tryagain" semantics, which didn't work.
2002-07-17 Not Zed <NotZed@Ximian.com> * providers/pop3/camel-pop3-store.c (pop3_try_authenticate): Got rid of the stupid "tryagain" semantics, which didn't work. (pop3_connect): Fixed here to only retry under proper conditions. svn path=/trunk/; revision=17488
Diffstat (limited to 'camel/providers/pop3/camel-pop3-store.c')
-rw-r--r--camel/providers/pop3/camel-pop3-store.c63
1 files changed, 32 insertions, 31 deletions
diff --git a/camel/providers/pop3/camel-pop3-store.c b/camel/providers/pop3/camel-pop3-store.c
index c35a4f5f13..66125247ef 100644
--- a/camel/providers/pop3/camel-pop3-store.c
+++ b/camel/providers/pop3/camel-pop3-store.c
@@ -440,7 +440,7 @@ try_sasl(CamelPOP3Store *store, const char *mech, CamelException *ex)
return -1;
}
-static gboolean
+static int
pop3_try_authenticate (CamelService *service, const char *errmsg,
CamelException *ex)
{
@@ -501,25 +501,24 @@ pop3_try_authenticate (CamelService *service, const char *errmsg,
return FALSE;
}
- while ((status = camel_pop3_engine_iterate (store->engine, pcp)) > 0)
+ while ((status = camel_pop3_engine_iterate(store->engine, pcp)) > 0)
;
-
- if (pcp->state != CAMEL_POP3_COMMAND_OK) {
- if (status == -1)
- camel_exception_setv (ex, CAMEL_EXCEPTION_SYSTEM,
- _("Unable to connect to POP server %s.\nError sending password: %s"),
- CAMEL_SERVICE (store)->url->host,
- errno ? g_strerror (errno) : _("Unknown error"));
- else
- camel_exception_setv (ex, CAMEL_EXCEPTION_SERVICE_CANT_AUTHENTICATE,
- _("Unable to connect to POP server %s.\nError sending password: %s"),
- CAMEL_SERVICE (store)->url->host, store->engine->line);
- }
- camel_pop3_engine_command_free(store->engine, pcp);
+ if (status == -1)
+ camel_exception_setv(ex, CAMEL_EXCEPTION_SYSTEM,
+ _("Unable to connect to POP server %s.\nError sending password: %s"),
+ CAMEL_SERVICE(store)->url->host,
+ errno?strerror(errno): _("Unknown error"));
+ else if (pcp->state != CAMEL_POP3_COMMAND_OK)
+ camel_exception_setv(ex, CAMEL_EXCEPTION_SERVICE_CANT_AUTHENTICATE,
+ _("Unable to connect to POP server %s.\nError sending password: %s"),
+ CAMEL_SERVICE(store)->url->host, store->engine->line);
+
+ camel_pop3_engine_command_free(store->engine, pcp);
+
if (pcu)
camel_pop3_engine_command_free(store->engine, pcu);
-
+
return status;
}
@@ -527,7 +526,7 @@ static gboolean
pop3_connect (CamelService *service, CamelException *ex)
{
char *errbuf = NULL;
- gboolean tryagain;
+ int status;
CamelPOP3Store *store = (CamelPOP3Store *)service;
if (store->cache == NULL) {
@@ -548,29 +547,31 @@ pop3_connect (CamelService *service, CamelException *ex)
if (!connect_to_server_wrapper (service, ex))
return FALSE;
- camel_exception_clear (ex);
do {
- if (camel_exception_is_set (ex)) {
- errbuf = g_strdup_printf ("%s\n\n", camel_exception_get_description (ex));
- camel_exception_clear (ex);
+ camel_exception_clear(ex);
+ status = pop3_try_authenticate(service, errbuf, ex);
+ g_free(errbuf);
+ errbuf = NULL;
+
+ if (camel_exception_is_set(ex)) {
+ errbuf = g_strdup_printf("%s\n\n", camel_exception_get_description(ex));
/* don't forget the password if we encountered an unknown error */
- if (camel_exception_get_id (ex) == CAMEL_EXCEPTION_SERVICE_CANT_AUTHENTICATE) {
+ if (camel_exception_get_id(ex) == CAMEL_EXCEPTION_SERVICE_CANT_AUTHENTICATE) {
/* Uncache the password before prompting again. */
- camel_session_forget_password (camel_service_get_session (service),
- service, "password", ex);
- g_free (service->url->passwd);
+ camel_session_forget_password(camel_service_get_session (service),
+ service, "password", NULL);
+ g_free(service->url->passwd);
service->url->passwd = NULL;
}
}
- tryagain = pop3_try_authenticate (service, errbuf, ex);
- g_free (errbuf);
- errbuf = NULL;
- } while (tryagain);
+ } while(status != -1 && ex->id == CAMEL_EXCEPTION_SERVICE_CANT_AUTHENTICATE);
+
+ g_free(errbuf);
- if (camel_exception_is_set (ex)) {
- camel_service_disconnect (service, TRUE, ex);
+ if (status == -1 || camel_exception_is_set(ex)) {
+ camel_service_disconnect(service, TRUE, ex);
return FALSE;
}