[evolution-data-server/camel-socks-proxy] Change the imap4 store to use the new API
- From: Federico Mena Quintero <federico src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution-data-server/camel-socks-proxy] Change the imap4 store to use the new API
- Date: Mon, 12 Jul 2010 21:09:08 +0000 (UTC)
commit 1669b1b74cd824885c54ad0f5ae3c20613f91f45
Author: Federico Mena Quintero <federico novell com>
Date: Mon Jul 12 15:55:49 2010 -0500
Change the imap4 store to use the new API
Signed-off-by: Federico Mena Quintero <federico novell com>
camel/providers/imap4/camel-imap4-store.c | 67 ++++++++++++-----------------
1 files changed, 28 insertions(+), 39 deletions(-)
---
diff --git a/camel/providers/imap4/camel-imap4-store.c b/camel/providers/imap4/camel-imap4-store.c
index 002cc06..bcdd0fc 100644
--- a/camel/providers/imap4/camel-imap4-store.c
+++ b/camel/providers/imap4/camel-imap4-store.c
@@ -225,7 +225,7 @@ enum {
#endif
static gboolean
-connect_to_server (CamelIMAP4Engine *engine, struct addrinfo *ai, gint ssl_mode, CamelException *ex)
+connect_to_server (CamelIMAP4Engine *engine, const char *host, const char *serv, gint fallback_port, gint ssl_mode, CamelException *ex)
{
CamelService *service = engine->service;
CamelSession *session;
@@ -264,15 +264,21 @@ connect_to_server (CamelIMAP4Engine *engine, struct addrinfo *ai, gint ssl_mode,
g_free (socks_host);
}
- if (camel_tcp_stream_connect ((CamelTcpStream *) tcp_stream, ai) == -1) {
- if (errno == EINTR)
- camel_exception_set (ex, CAMEL_EXCEPTION_USER_CANCEL,
- _("Connection canceled"));
- else
- camel_exception_setv (ex, CAMEL_EXCEPTION_SERVICE_UNAVAILABLE,
- _("Could not connect to %s: %s"),
- service->url->host,
- g_strerror (errno));
+ if (camel_tcp_stream_connect ((CamelTcpStream *) tcp_stream, host, serv, fallback_port, ex) == -1) {
+ gint saved_errno;
+
+ saved_errno = errno;
+
+ if (!camel_exception_is_set (ex)) {
+ if (saved_errno == EINTR)
+ camel_exception_set (ex, CAMEL_EXCEPTION_USER_CANCEL,
+ _("Connection canceled"));
+ else
+ camel_exception_setv (ex, CAMEL_EXCEPTION_SERVICE_UNAVAILABLE,
+ _("Could not connect to %s: %s"),
+ host,
+ g_strerror (saved_errno));
+ }
camel_object_unref (tcp_stream);
@@ -352,24 +358,23 @@ connect_to_server (CamelIMAP4Engine *engine, struct addrinfo *ai, gint ssl_mode,
static struct {
gchar *value;
gchar *serv;
- gchar *port;
+ gint fallback_port;
gint mode;
} ssl_options[] = {
- { "", "imaps", "993", MODE_SSL }, /* really old (1.x) */
- { "always", "imaps", "993", MODE_SSL },
- { "when-possible", "imap", "143", MODE_TLS },
- { "never", "imap", "143", MODE_CLEAR },
- { NULL, "imap", "143", MODE_CLEAR },
+ { "", "imaps", 993, MODE_SSL }, /* really old (1.x) */
+ { "always", "imaps", 993, MODE_SSL },
+ { "when-possible", "imap", 143, MODE_TLS },
+ { "never", "imap", 143, MODE_CLEAR },
+ { NULL, "imap", 143, MODE_CLEAR },
};
static gboolean
connect_to_server_wrapper (CamelIMAP4Engine *engine, CamelException *ex)
{
CamelService *service = engine->service;
- struct addrinfo *ai, hints;
const gchar *ssl_mode;
- gint mode, ret, i;
- const gchar *port;
+ gint mode, i;
+ gint fallback_port;
gchar *serv;
if ((ssl_mode = camel_url_get_param (service->url, "use_ssl"))) {
@@ -378,36 +383,20 @@ connect_to_server_wrapper (CamelIMAP4Engine *engine, CamelException *ex)
break;
mode = ssl_options[i].mode;
serv = ssl_options[i].serv;
- port = ssl_options[i].port;
+ fallback_port = ssl_options[i].fallback_port;
} else {
mode = MODE_CLEAR;
serv = "imap";
- port = "143";
+ fallback_port = 143;
}
if (service->url->port) {
serv = g_alloca (16);
sprintf (serv, "%d", service->url->port);
- port = NULL;
- }
-
- memset (&hints, 0, sizeof (hints));
- hints.ai_socktype = SOCK_STREAM;
- hints.ai_family = PF_UNSPEC;
- ai = camel_getaddrinfo (service->url->host, serv, &hints, ex);
- if (ai == NULL && port != NULL && camel_exception_get_id(ex) != CAMEL_EXCEPTION_USER_CANCEL) {
- camel_exception_clear (ex);
- ai = camel_getaddrinfo (service->url->host, port, &hints, ex);
+ fallback_port = 0;
}
- if (ai == NULL)
- return FALSE;
-
- ret = connect_to_server (engine, ai, mode, ex);
-
- camel_freeaddrinfo (ai);
-
- return ret;
+ return connect_to_server (engine, service->url->host, serv, fallback_port, mode, ex);
}
static gint
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]