diff options
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | ChangeLog.ja | 5 | ||||
-rw-r--r-- | libsylph/pop.c | 8 | ||||
-rw-r--r-- | src/rpop3.c | 138 |
4 files changed, 133 insertions, 23 deletions
@@ -1,5 +1,10 @@ 2008-09-17 + * libsylph/pop.c + src/rpop3.c: modified column width. Implemented message display. + +2008-09-17 + * libsylph/pop.[ch]: made some functions non-static. pop3_session_new(): set server, port, userid and password. * src/inc.c: sync with the libsylph/pop.[ch] change. diff --git a/ChangeLog.ja b/ChangeLog.ja index a3abf1bc..c7d58b60 100644 --- a/ChangeLog.ja +++ b/ChangeLog.ja @@ -1,5 +1,10 @@ 2008-09-17 + * libsylph/pop.c + src/rpop3.c: カラム幅を調整。メッセージの表示を実装。 + +2008-09-17 + * libsylph/pop.[ch]: 一部の関数を static でなくした。 pop3_session_new(): サーバ、ポート、ユーザ ID 、パスワードをセット するようにした。 diff --git a/libsylph/pop.c b/libsylph/pop.c index 872cfc01..25774cbd 100644 --- a/libsylph/pop.c +++ b/libsylph/pop.c @@ -76,9 +76,9 @@ void pop3_gen_send (Pop3Session *session, static void pop3_session_destroy (Session *session); -static gint pop3_write_msg_to_file (const gchar *file, - FILE *src_fp, - guint len); +gint pop3_write_msg_to_file (const gchar *file, + FILE *src_fp, + guint len); static Pop3State pop3_lookup_next (Pop3Session *session); @@ -561,7 +561,7 @@ gint pop3_write_uidl_list(Pop3Session *session) return 0; } -static gint pop3_write_msg_to_file(const gchar *file, FILE *src_fp, guint len) +gint pop3_write_msg_to_file(const gchar *file, FILE *src_fp, guint len) { FILE *fp; gchar buf[BUFFSIZE]; diff --git a/src/rpop3.c b/src/rpop3.c index 25045ef5..78048fdd 100644 --- a/src/rpop3.c +++ b/src/rpop3.c @@ -116,13 +116,15 @@ gint pop3_retr_send (Pop3Session *session); gint pop3_retr_recv (Pop3Session *session, FILE *fp, guint len); -gint pop3_delete_send (Pop3Session *session); -gint pop3_delete_recv (Pop3Session *session); gint pop3_logout_send (Pop3Session *session); void pop3_gen_send (Pop3Session *session, const gchar *format, ...); +gint pop3_write_msg_to_file (const gchar *file, + FILE *src_fp, + guint len); + Pop3ErrorValue pop3_ok (Pop3Session *session, const gchar *msg); @@ -135,6 +137,12 @@ static gint rpop3_top_send (Pop3Session *session); static gint rpop3_top_recv (Pop3Session *session, FILE *fp, guint len); +static gint rpop3_retr_send (Pop3Session *session); +static gint rpop3_retr_recv (Pop3Session *session, + FILE *fp, + guint len); +static gint rpop3_delete_send (Pop3Session *session); +static gint rpop3_delete_recv (Pop3Session *session); static gint rpop3_session_recv_msg (Session *session, const gchar *msg); @@ -153,6 +161,11 @@ static gboolean key_pressed (GtkWidget *widget, GdkEventKey *event, gpointer data); +static void rpop3_row_activated (GtkTreeView *treeview, + GtkTreePath *path, + GtkTreeViewColumn *column, + gpointer data); + static void rpop3_open (GtkButton *button, gpointer data); static void rpop3_delete (GtkButton *button, @@ -266,30 +279,33 @@ static void rpop3_window_create(PrefsAccount *account) gtk_container_add(GTK_CONTAINER(scrwin), treeview); -#define APPEND_COLUMN(label, col, width) \ -{ \ - renderer = gtk_cell_renderer_text_new(); \ - column = gtk_tree_view_column_new_with_attributes \ - (label, renderer, "text", col, \ - "strikethrough", COL_DELETED, NULL); \ - gtk_tree_view_column_set_resizable(column, TRUE); \ - if (width) { \ - gtk_tree_view_column_set_sizing \ - (column, GTK_TREE_VIEW_COLUMN_FIXED); \ - gtk_tree_view_column_set_fixed_width(column, width); \ - } \ - gtk_tree_view_column_set_sort_column_id(column, col); \ - gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); \ +#define APPEND_COLUMN(label, col, width) \ +{ \ + renderer = gtk_cell_renderer_text_new(); \ + column = gtk_tree_view_column_new_with_attributes \ + (label, renderer, "text", col, \ + "strikethrough", COL_DELETED, NULL); \ + gtk_tree_view_column_set_resizable(column, TRUE); \ + if (width) { \ + gtk_tree_view_column_set_sizing \ + (column, GTK_TREE_VIEW_COLUMN_FIXED); \ + gtk_tree_view_column_set_fixed_width(column, width); \ + } \ + gtk_tree_view_column_set_sort_column_id(column, col); \ + gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column); \ } APPEND_COLUMN(_("No."), COL_NUMBER, 0); APPEND_COLUMN(_("Subject"), COL_SUBJECT, 200); - APPEND_COLUMN(_("From"), COL_FROM, 160); - APPEND_COLUMN(_("Date"), COL_DATE, 140); + APPEND_COLUMN(_("From"), COL_FROM, 152); + APPEND_COLUMN(_("Date"), COL_DATE, 0); APPEND_COLUMN(_("Size"), COL_SIZE, 0); gtk_widget_show_all(scrwin); + g_signal_connect(G_OBJECT(treeview), "row-activated", + G_CALLBACK(rpop3_row_activated), NULL); + hbox = gtk_hbox_new(FALSE, 8); gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0); @@ -428,6 +444,50 @@ static gint rpop3_top_recv(Pop3Session *session, FILE *fp, guint len) return PS_SUCCESS; } +static gint rpop3_retr_send(Pop3Session *session) +{ + session->state = POP3_RETR; + pop3_gen_send(session, "RETR %d", session->cur_msg); + return PS_SUCCESS; +} + +static void msgview_destroy_cb(GtkWidget *widget, gpointer data) +{ + gchar *file = (gchar *)data; + + if (file) { + debug_print("msgview_destroy_cb(): removing temporary file: %s\n", file); + g_unlink(file); + g_free(file); + } +} + +static gint rpop3_retr_recv(Pop3Session *session, FILE *fp, guint len) +{ + gchar *file; + MsgInfo *msginfo; + MsgFlags flags = {0, 0}; + MessageView *msgview; + + file = get_tmp_file(); + if (pop3_write_msg_to_file(file, fp, len) < 0) { + g_free(file); + session->error_val = PS_IOERR; + return -1; + } + + msginfo = procheader_parse_file(file, flags, FALSE); + msginfo->file_path = g_strdup(file); + + msgview = messageview_create_with_new_window(); + messageview_show(msgview, msginfo, FALSE); + + g_signal_connect(G_OBJECT(msgview->window), "destroy", + G_CALLBACK(msgview_destroy_cb), file); + + return PS_SUCCESS; +} + static gint rpop3_delete_send(Pop3Session *session) { g_return_val_if_fail(rpop3_window.delete_array != NULL, -1); @@ -624,8 +684,11 @@ static gint rpop3_session_recv_data_as_file_finished(Session *session, switch (pop3_session->state) { case POP3_RETR_RECV: - if (pop3_retr_recv(pop3_session, fp, len) < 0) + if (rpop3_retr_recv(pop3_session, fp, len) < 0) return -1; + rpop3_status_label_set(_("Opened message %d"), + pop3_session->cur_msg); + pop3_session->state = POP3_IDLE; break; case POP3_TOP_RECV: if (rpop3_top_recv(pop3_session, fp, len) == PS_SUCCESS) { @@ -667,8 +730,45 @@ static gboolean key_pressed(GtkWidget *widget, GdkEventKey *event, return FALSE; } +static void rpop3_row_activated(GtkTreeView *treeview, GtkTreePath *path, + GtkTreeViewColumn *column, gpointer data) +{ + gtk_button_clicked(GTK_BUTTON(rpop3_window.open_btn)); +} + static void rpop3_open(GtkButton *button, gpointer data) { + GtkTreeModel *model = GTK_TREE_MODEL(rpop3_window.store); + GtkTreeSelection *selection; + GtkTreeIter iter; + GList *rows, *cur; + gint num; + gboolean deleted; + + if (rpop3_window.session->state != POP3_IDLE) + return; + + selection = gtk_tree_view_get_selection + (GTK_TREE_VIEW(rpop3_window.treeview)); + + rows = gtk_tree_selection_get_selected_rows(selection, NULL); + + for (cur = rows; cur != NULL; cur = cur->next) { + gtk_tree_model_get_iter(model, &iter, (GtkTreePath *)cur->data); + gtk_tree_model_get(model, &iter, COL_NUMBER, &num, + COL_DELETED, &deleted, -1); + if (!deleted) { + debug_print("rpop3_open(): opening message %d\n", num); + rpop3_status_label_set(_("Retrieving message %d ..."), + num); + rpop3_window.session->cur_msg = num; + rpop3_retr_send(rpop3_window.session); + break; + } + } + + g_list_foreach(rows, (GFunc)gtk_tree_path_free, NULL); + g_list_free(rows); } static void rpop3_delete(GtkButton *button, gpointer data) |