diff options
author | Not Zed <NotZed@Ximian.com> | 2002-07-17 20:17:52 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2002-07-17 20:17:52 +0800 |
commit | a2affe7e4dbec98b1080f9650123c33cdfb4005d (patch) | |
tree | 5403f80ac8bca13a977716b9823307a722c6b529 /camel/providers/pop3 | |
parent | 3556d21a8e198b9ffbae74501a10bfe224d31cab (diff) | |
download | gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar.gz gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar.bz2 gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar.lz gsoc2013-evolution-a2affe7e4dbec98b1080f9650123c33cdfb4005d.tar.xz 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')
-rw-r--r-- | camel/providers/pop3/camel-pop3-store.c | 63 |
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; } |