while (mimeinfo != NULL) {
node = mimeview_append_part(mimeview, mimeinfo, parent);
- if (mimeinfo->children)
- mimeview_set_multipart_tree(mimeview, mimeinfo->children, node);
- mimeinfo = mimeinfo->next;
+ if (mimeinfo->node->children)
+ mimeview_set_multipart_tree(mimeview, (MimeInfo *) mimeinfo->node->children->data, node);
+ mimeinfo = mimeinfo->node->next != NULL ? (MimeInfo *) mimeinfo->node->next->data : NULL;
}
}
gchar *str[N_MIMEVIEW_COLS];
if (partinfo->type != MIMETYPE_UNKNOWN && partinfo->subtype) {
- snprintf(content_type, 64, "%s/%s", procmime_get_type_str(partinfo->type), partinfo->subtype);
+ g_snprintf(content_type, 64, "%s/%s", procmime_get_type_str(partinfo->type), partinfo->subtype);
} else {
- snprintf(content_type, 64, "UNKNOWN");
+ g_snprintf(content_type, 64, "UNKNOWN");
}
str[COL_MIMETYPE] = content_type;
icon_list_clear(mimeview);
}
+static void check_signature_cb(GtkWidget *widget, gpointer user_data);
+
+static void update_signature_noticeview(MimeView *mimeview, MimeInfo *mimeinfo)
+{
+ if (privacy_mimeinfo_is_signed(mimeinfo)) {
+ gchar *text = NULL, *button_text = NULL;
+ GtkSignalFunc func = NULL;
+
+ switch (privacy_mimeinfo_get_sig_status(mimeinfo)) {
+ case SIGNATURE_UNCHECKED:
+ text = _("This part of the message has been signed");
+ button_text = _("Check");
+ func = check_signature_cb;
+ break;
+ case SIGNATURE_OK:
+ case SIGNATURE_WARN:
+ text = _("Signature is ok");
+ break;
+ case SIGNATURE_INVALID:
+ text = _("The signature of this part is invalid");
+ break;
+ case SIGNATURE_CHECK_FAILED:
+ text = _("Checking the signature failed");
+ button_text = _("Check again");
+ func = check_signature_cb;
+ default:
+ break;
+ }
+ noticeview_set_text(mimeview->siginfoview, text);
+ noticeview_set_button_text(mimeview->siginfoview, button_text);
+ noticeview_set_button_press_callback(
+ mimeview->siginfoview,
+ func,
+ (gpointer) mimeview);
+ noticeview_show(mimeview->siginfoview);
+ } else {
+ noticeview_hide(mimeview->siginfoview);
+ }
+}
+
+static void check_signature_cb(GtkWidget *widget, gpointer user_data)
+{
+ MimeView *mimeview = (MimeView *) user_data;
+ MimeInfo *mimeinfo = mimeview_get_selected_part(mimeview);
+
+ privacy_mimeinfo_check_signature(mimeinfo);
+ update_signature_noticeview(mimeview, mimeinfo);
+}
+
static void mimeview_selected(GtkCTree *ctree, GtkCTreeNode *node, gint column,
MimeView *mimeview)
{
mimeview->textview->default_text = FALSE;
- if (privacy_mimeinfo_is_signed(partinfo)) {
- noticeview_set_text(mimeview->siginfoview, "Signed Part");
- noticeview_show(mimeview->siginfoview);
- } else {
- noticeview_hide(mimeview->siginfoview);
- }
+ update_signature_noticeview(mimeview, partinfo);
if (!mimeview_show_part(mimeview, partinfo)) {
switch (partinfo->type) {
dirname = filesel_select_file(_("Save as"), defname);
if (!dirname) return;
+ if (!is_dir_exist (dirname)) {
+ alertpanel_error(_("`%s' is not a directory."),
+ dirname);
+ g_free (dirname);
+ return;
+ }
+
+ { /* add a / after the dirname, in case the user didn't */
+ gchar *dirname_tmp = NULL;
+ int dirname_last_char = strlen (dirname) - 1;
+
+ if (dirname[dirname_last_char] != G_DIR_SEPARATOR) {
+ dirname_tmp = g_strconcat (dirname, G_DIR_SEPARATOR_S, NULL);
+ g_free (dirname);
+ dirname = dirname_tmp;
+ }
+ }
+
/* return to first children */
- if (!partinfo->parent->children) return; /* multipart container? */
- attachment = partinfo->parent->children->next;
+ if (partinfo->node->parent->children == NULL) return; /* multipart container? */
+ attachment = partinfo->node->parent->children->next != NULL ?
+ (MimeInfo *) partinfo->node->parent->children->next->data : NULL;
/* for each attachment, extract it in the selected dir. */
while (attachment != NULL) {
static guint subst_cnt = 1;
if ((G_ALERTDEFAULT != aval) || (procmime_get_part(buf, attachment) < 0))
alertpanel_error(_("Can't save the part of multipart message."));
- attachment = attachment->next;
+ attachment = attachment->node->next != NULL ? (MimeInfo *) attachment->node->next->data : NULL;
}
}
case GDK_n:
case GDK_N:
BREAK_ON_MODIFIER_KEY();
- if (icon_list_select_by_number(mimeview, num + 1))
+ if (icon_list_select_by_number(mimeview, num + 1)) {
KEY_PRESS_EVENT_STOP();
return TRUE;
+ }
break;
case GDK_p:
case GDK_P:
BREAK_ON_MODIFIER_KEY();
- if (icon_list_select_by_number(mimeview, num - 1))
+ if (icon_list_select_by_number(mimeview, num - 1)) {
KEY_PRESS_EVENT_STOP();
return TRUE;
+ }
break;
case GDK_y:
while (mimeinfo != NULL) {
if (mimeinfo->type != MIMETYPE_MULTIPART)
icon_list_append_icon(mimeview, mimeinfo);
- if (mimeinfo->children != NULL)
- icon_list_create(mimeview, mimeinfo->children);
- mimeinfo = mimeinfo->next;
+ if (mimeinfo->node->children != NULL)
+ icon_list_create(mimeview, (MimeInfo *) mimeinfo->node->children->data);
+ mimeinfo = mimeinfo->node->next != NULL ? (MimeInfo *) mimeinfo->node->next->data : NULL;
}
gtk_widget_size_request(mimeview->icon_vbox, &size);
width = size.width + 4;