diff options
author | hiro <hiro@ee746299-78ed-0310-b773-934348b2243d> | 2008-09-19 07:04:01 +0000 |
---|---|---|
committer | hiro <hiro@ee746299-78ed-0310-b773-934348b2243d> | 2008-09-19 07:04:01 +0000 |
commit | 226b7833e853fc2b65900f6d8c9cb0993e3af371 (patch) | |
tree | c0dba3d8bb8285481aab70f88b3c1bea221b9de2 | |
parent | 2a5d526422c62ec5da7102b5626f3c0992b508c2 (diff) |
remote mailbox: added stop button which stops retrieving of headers.
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@2036 ee746299-78ed-0310-b773-934348b2243d
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | ChangeLog.ja | 5 | ||||
-rw-r--r-- | libsylph/socket.c | 9 | ||||
-rw-r--r-- | src/rpop3.c | 73 |
4 files changed, 69 insertions, 23 deletions
@@ -1,3 +1,8 @@ +2008-09-19 + + * libsylph/socket.c: also handle G_IO_NVAL. + * src/rpop3.c: added stop button which stops retrieving of headers. + 2008-09-18 * src/rpop3.c: enabled cancellation on connection. diff --git a/ChangeLog.ja b/ChangeLog.ja index e6077da8..ea1caba7 100644 --- a/ChangeLog.ja +++ b/ChangeLog.ja @@ -1,3 +1,8 @@ +2008-09-19 + + * libsylph/socket.c: G_IO_NVAL も処理するようにした。 + * src/rpop3.c: ヘッダの取得を停止する「停止」ボタンを追加。 + 2008-09-18 * src/rpop3.c: 接続時のキャンセルを可能にした。 diff --git a/libsylph/socket.c b/libsylph/socket.c index 9efec203..55ae3cfd 100644 --- a/libsylph/socket.c +++ b/libsylph/socket.c @@ -922,7 +922,7 @@ static gboolean sock_connect_async_cb(GIOChannel *source, conn_data->channel = NULL; g_io_channel_unref(source); - if (condition & (G_IO_ERR | G_IO_HUP)) { + if (condition & (G_IO_ERR | G_IO_HUP | G_IO_NVAL)) { debug_print("sock_connect_async_cb: condition = %d\n", condition); fd_close(fd); @@ -939,6 +939,7 @@ static gboolean sock_connect_async_cb(GIOChannel *source, } if (val != 0) { + debug_print("getsockopt(SOL_SOCKET, SO_ERROR) returned error\n"); fd_close(fd); sock_connect_address_list_async(conn_data); return FALSE; @@ -1086,9 +1087,9 @@ static gint sock_connect_address_list_async(SockConnectData *conn_data) conn_data->cur_addr = conn_data->cur_addr->next; conn_data->channel = g_io_channel_unix_new(sock); - conn_data->io_tag = g_io_add_watch(conn_data->channel, - G_IO_OUT | G_IO_ERR | G_IO_HUP, - sock_connect_async_cb, conn_data); + conn_data->io_tag = g_io_add_watch + (conn_data->channel, G_IO_OUT | G_IO_ERR | G_IO_HUP | G_IO_NVAL, + sock_connect_async_cb, conn_data); return 0; } diff --git a/src/rpop3.c b/src/rpop3.c index e14adec7..93e8edf6 100644 --- a/src/rpop3.c +++ b/src/rpop3.c @@ -82,9 +82,11 @@ static struct RPop3Window { GtkWidget *recv_btn; GtkWidget *open_btn; GtkWidget *delete_btn; + GtkWidget *stop_btn; GtkWidget *close_btn; Pop3Session *session; + gboolean stop_load; gboolean cancelled; gboolean finished; GArray *delete_array; @@ -178,6 +180,8 @@ static void rpop3_open (GtkButton *button, gpointer data); static void rpop3_delete (GtkButton *button, gpointer data); +static void rpop3_stop (GtkButton *button, + gpointer data); static void rpop3_close (GtkButton *button, gpointer data); @@ -191,6 +195,8 @@ gint rpop3_account(PrefsAccount *account) return -1; if (inc_is_active()) return -1; + if (rpop3_window.window) + return -1; inc_lock(); @@ -198,6 +204,7 @@ gint rpop3_account(PrefsAccount *account) session = pop3_session_new(account); rpop3_window.session = POP3_SESSION(session); + rpop3_window.stop_load = FALSE; rpop3_window.cancelled = FALSE; rpop3_window.finished = FALSE; @@ -252,6 +259,7 @@ static void rpop3_window_create(PrefsAccount *account) GtkWidget *recv_btn; GtkWidget *open_btn; GtkWidget *delete_btn; + GtkWidget *stop_btn; GtkWidget *close_btn; gchar buf[BUFFSIZE]; @@ -340,6 +348,10 @@ static void rpop3_window_create(PrefsAccount *account) gtk_box_pack_start(GTK_BOX(hbbox), delete_btn, FALSE, FALSE, 0); gtk_widget_set_sensitive(delete_btn, FALSE); + stop_btn = gtk_button_new_from_stock(GTK_STOCK_STOP); + gtk_box_pack_start(GTK_BOX(hbbox), stop_btn, FALSE, FALSE, 0); + gtk_widget_set_sensitive(stop_btn, FALSE); + close_btn = gtk_button_new_from_stock(GTK_STOCK_CLOSE); gtk_box_pack_start(GTK_BOX(hbbox), close_btn, FALSE, FALSE, 0); @@ -349,6 +361,8 @@ static void rpop3_window_create(PrefsAccount *account) G_CALLBACK(rpop3_open), NULL); g_signal_connect(G_OBJECT(delete_btn), "clicked", G_CALLBACK(rpop3_delete), NULL); + g_signal_connect(G_OBJECT(stop_btn), "clicked", + G_CALLBACK(rpop3_stop), NULL); g_signal_connect(G_OBJECT(close_btn), "clicked", G_CALLBACK(rpop3_close), NULL); @@ -361,11 +375,14 @@ static void rpop3_window_create(PrefsAccount *account) rpop3_window.recv_btn = recv_btn; rpop3_window.open_btn = open_btn; rpop3_window.delete_btn = delete_btn; + rpop3_window.stop_btn = stop_btn; rpop3_window.close_btn = close_btn; } static gint rpop3_start(Session *session) { + SessionState state; + g_return_val_if_fail(session != NULL, -1); rpop3_status_label_set(_("Connecting to %s:%d ..."), @@ -384,10 +401,13 @@ static gint rpop3_start(Session *session) gtk_main_iteration(); } + state = session->state; + session_disconnect(session); + switch (POP3_SESSION(session)->error_val) { case PS_AUTHFAIL: - session_disconnect(session); manage_window_focus_in(rpop3_window.window, NULL, NULL); + rpop3_status_label_set(_("Authentication failed.")); if (POP3_SESSION(session)->error_msg) alertpanel_error(_("Authentication failed:\n%s"), POP3_SESSION(session)->error_msg); @@ -397,8 +417,8 @@ static gint rpop3_start(Session *session) case PS_SUCCESS: break; default: - session_disconnect(session); manage_window_focus_in(rpop3_window.window, NULL, NULL); + rpop3_status_label_set(_("Error occurred during POP3 session.")); if (POP3_SESSION(session)->error_msg) alertpanel_error (_("Error occurred during POP3 session:\n%s"), @@ -408,34 +428,38 @@ static gint rpop3_start(Session *session) return -1; } - switch (session->state) { + switch (state) { case SESSION_EOF: - session_disconnect(session); manage_window_focus_in(rpop3_window.window, NULL, NULL); + rpop3_status_label_set + (_("Connection closed by the remote host.")); alertpanel_error(_("Connection closed by the remote host.")); return -1; case SESSION_TIMEOUT: - session_disconnect(session); manage_window_focus_in(rpop3_window.window, NULL, NULL); + rpop3_status_label_set(_("Session timed out.")); alertpanel_error(_("Session timed out.")); return -1; case SESSION_ERROR: - session_disconnect(session); manage_window_focus_in(rpop3_window.window, NULL, NULL); - if (POP3_SESSION(session)->state == POP3_READY) - alertpanel_error(_("Can't connect to POP3 server: %s:%d"), - session->server, session->port); - else - alertpanel_error(_("Error occurred during POP3 session.")); + if (POP3_SESSION(session)->state == POP3_READY) { + rpop3_status_label_set + (_("Can't connect to POP3 server: %s:%d"), + session->server, session->port); + alertpanel_error + (_("Can't connect to POP3 server: %s:%d"), + session->server, session->port); + } else { + rpop3_status_label_set + (_("Error occurred during POP3 session.")); + alertpanel_error + (_("Error occurred during POP3 session.")); + } return -1; case SESSION_READY: - session_disconnect(session); debug_print("Session cancelled.\n"); return -1; - case SESSION_DISCONNECTED: - break; default: - session_disconnect(session); break; } @@ -515,7 +539,7 @@ static gint rpop3_top_recv(Pop3Session *session, FILE *fp, guint len) COL_DELETED, FALSE, -1); - rpop3_status_label_set(_("Retrieving message headers (%d / %d)"), + rpop3_status_label_set(_("Retrieving message headers (%d / %d) ..."), session->cur_msg, session->count); return PS_SUCCESS; @@ -774,8 +798,11 @@ static gint rpop3_session_recv_data_finished(Session *session, guchar *data, pop3_session->cur_msg = 1; if (rpop3_window.cancelled || pop3_session->count == 0) pop3_logout_send(rpop3_window.session); - else + else { + gtk_widget_set_sensitive(rpop3_window.stop_btn, + TRUE); rpop3_top_send(pop3_session); + } } else return -1; break; @@ -818,19 +845,22 @@ static gint rpop3_session_recv_data_as_file_finished(Session *session, if (rpop3_top_recv(pop3_session, fp, len) == PS_SUCCESS) { if (rpop3_window.cancelled) pop3_logout_send(rpop3_window.session); - else if (pop3_session->cur_msg < pop3_session->count) { + else if (!rpop3_window.stop_load && + (pop3_session->cur_msg < pop3_session->count)) { pop3_session->cur_msg++; rpop3_top_send(pop3_session); } else { rpop3_status_label_set (_("Retrieved %d message headers"), - pop3_session->count); + pop3_session->cur_msg); gtk_widget_set_sensitive (rpop3_window.recv_btn, TRUE); gtk_widget_set_sensitive (rpop3_window.open_btn, TRUE); gtk_widget_set_sensitive (rpop3_window.delete_btn, TRUE); + gtk_widget_set_sensitive + (rpop3_window.stop_btn, FALSE); pop3_session->state = POP3_IDLE; } } else @@ -990,6 +1020,11 @@ static void rpop3_delete(GtkButton *button, gpointer data) g_array_free(array, TRUE); } +static void rpop3_stop(GtkButton *button, gpointer data) +{ + rpop3_window.stop_load = TRUE; +} + static void rpop3_close(GtkButton *button, gpointer data) { rpop3_window.finished = TRUE; |