#include <modest-platform.h>
#include <modest-text-utils.h>
#include <tny-msg.h>
+#include <tny-camel-mem-stream.h>
+#include <modest-mail-operation.h>
+#include <modest-mail-operation-queue.h>
+#include <modest-runtime.h>
+
+#define GET_SIZE_BUFFER_SIZE 128
static GObjectClass *parent_class = NULL;
-typedef struct _ModestAttachmentViewPriv ModestAttachmentViewPriv;
+typedef struct _ModestAttachmentViewPrivate ModestAttachmentViewPrivate;
-struct _ModestAttachmentViewPriv
+struct _ModestAttachmentViewPrivate
{
TnyMimePart *mime_part;
guint64 size;
PangoLayout *layout_full_filename;
+ gboolean is_purged;
};
#define UNKNOWN_FILE_ICON "qgn_list_gene_unknown_file"
-#define GET_SIZE_BUFFER_SIZE 128
#define MODEST_ATTACHMENT_VIEW_GET_PRIVATE(o) \
- (G_TYPE_INSTANCE_GET_PRIVATE ((o), MODEST_TYPE_ATTACHMENT_VIEW, ModestAttachmentViewPriv))
+ (G_TYPE_INSTANCE_GET_PRIVATE ((o), MODEST_TYPE_ATTACHMENT_VIEW, ModestAttachmentViewPrivate))
/* TnyMimePartView functions */
static TnyMimePart *modest_attachment_view_get_part (TnyMimePartView *self);
-static gboolean get_size_idle_func (gpointer data);
static void update_filename_request (ModestAttachmentView *self);
+static gboolean
+idle_get_mime_part_size_cb (gpointer userdata)
+{
+ ModestAttachmentView *view = (ModestAttachmentView *) userdata;
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (view);
+ gchar *size_str;
+ gchar *label_text;
+ gdk_threads_enter ();
+
+ if (GTK_WIDGET_VISIBLE (view)) {
+ size_str = modest_text_utils_get_display_size (priv->size);
+ label_text = g_strdup_printf (" (%s)", size_str);
+ g_free (size_str);
+ gtk_label_set_text (GTK_LABEL (priv->size_view), label_text);
+ g_free (label_text);
+ }
+
+ gdk_threads_leave ();
+
+ g_object_unref (view);
+
+ return FALSE;
+}
+
+static gpointer
+get_mime_part_size_thread (gpointer thr_user_data)
+{
+ ModestAttachmentView *view = (ModestAttachmentView *) thr_user_data;
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (view);
+ gchar read_buffer[GET_SIZE_BUFFER_SIZE];
+ TnyStream *stream;
+ gssize readed_size;
+ gssize total = 0;
+
+ stream = tny_camel_mem_stream_new ();
+ tny_mime_part_decode_to_stream (priv->mime_part, stream);
+ tny_stream_reset (stream);
+ if (tny_stream_is_eos (stream)) {
+ tny_stream_close (stream);
+ stream = tny_mime_part_get_stream (priv->mime_part);
+ }
+
+ while (!tny_stream_is_eos (stream)) {
+ readed_size = tny_stream_read (stream, read_buffer, GET_SIZE_BUFFER_SIZE);
+ total += readed_size;
+ }
+
+ priv->size = total;
+
+ g_idle_add (idle_get_mime_part_size_cb, g_object_ref (view));
+
+ g_object_unref (stream);
+ g_object_unref (view);
+
+ return NULL;
+}
static TnyMimePart *
modest_attachment_view_get_part (TnyMimePartView *self)
static TnyMimePart *
modest_attachment_view_get_part_default (TnyMimePartView *self)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
if (priv->mime_part)
return TNY_MIME_PART (g_object_ref (priv->mime_part));
static void
update_filename_request (ModestAttachmentView *self)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
/* gint width, height; */
pango_layout_set_text (PANGO_LAYOUT (priv->layout_full_filename),
}
-static gboolean
-get_size_idle_func (gpointer data)
-{
- gdk_threads_enter ();
-
- ModestAttachmentView *self = (ModestAttachmentView *) data;
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
- gssize readed_size;
- gchar read_buffer[GET_SIZE_BUFFER_SIZE];
- gchar *size_string;
-
- if (priv->get_size_stream == NULL) {
- priv->get_size_stream = tny_mime_part_get_stream (priv->mime_part);
- }
-
- readed_size = tny_stream_read (priv->get_size_stream, read_buffer, GET_SIZE_BUFFER_SIZE);
- priv->size += readed_size;
-
- if (tny_stream_is_eos (priv->get_size_stream)) {
- gchar *display_size;
-
- display_size = modest_text_utils_get_display_size (priv->size);
- size_string = g_strdup_printf (" (%s)", display_size);
- g_free (display_size);
- gtk_label_set_text (GTK_LABEL (priv->size_view), size_string);
- g_free (size_string);
-
- g_object_unref (priv->get_size_stream);
-
- gtk_widget_queue_resize (priv->size_view);
- priv->get_size_stream = NULL;
- priv->get_size_idle_id = 0;
- }
-
- gdk_threads_leave ();
-
- return (priv->get_size_stream != NULL);
-}
-
static void
modest_attachment_view_set_part_default (TnyMimePartView *self, TnyMimePart *mime_part)
{
- ModestAttachmentViewPriv *priv = NULL;
- const gchar *filename = NULL;
+ ModestAttachmentViewPrivate *priv = NULL;
+ gchar *filename = NULL;
gchar *file_icon_name = NULL;
gboolean show_size = FALSE;
priv->mime_part = mime_part;
- if (priv->get_size_idle_id != 0) {
- g_source_remove (priv->get_size_idle_id);
- priv->get_size_idle_id = 0;
- }
-
- if (priv->get_size_stream != NULL) {
- g_object_unref (priv->get_size_stream);
- priv->get_size_stream = NULL;
- }
-
priv->size = 0;
-
- if (tny_mime_part_is_purged (mime_part)) {
- filename = _("TODO: purged file");
- file_icon_name = modest_platform_get_file_icon_name (NULL, NULL, NULL);
- } else if (TNY_IS_MSG (mime_part)) {
+ priv->is_purged = tny_mime_part_is_purged (mime_part);
+
+ if (TNY_IS_MSG (mime_part)) {
TnyHeader *header = tny_msg_get_header (TNY_MSG (mime_part));
if (TNY_IS_HEADER (header)) {
- filename = tny_header_get_subject (header);
- if (filename == NULL)
- filename = _("mail_va_no_subject");
- file_icon_name = modest_platform_get_file_icon_name (NULL, tny_mime_part_get_content_type (mime_part), NULL);
+ filename = g_strdup (tny_header_get_subject (header));
+ if (filename == NULL || filename[0] == '\0')
+ filename = g_strdup (_("mail_va_no_subject"));
+ if (priv->is_purged)
+ file_icon_name = modest_platform_get_file_icon_name (NULL, NULL, NULL);
+ else
+ file_icon_name =
+ modest_platform_get_file_icon_name (
+ NULL, tny_mime_part_get_content_type (mime_part), NULL);
g_object_unref (header);
}
} else {
- filename = tny_mime_part_get_filename (mime_part);
- file_icon_name = modest_platform_get_file_icon_name (filename,
- tny_mime_part_get_content_type (mime_part),
- NULL);
- show_size = TRUE;
+ filename = g_strdup (tny_mime_part_get_filename (mime_part));
+ if (priv->is_purged) {
+ file_icon_name = modest_platform_get_file_icon_name (NULL, NULL, NULL);
+ } else {
+ file_icon_name = modest_platform_get_file_icon_name (
+ filename, tny_mime_part_get_content_type (mime_part), NULL);
+ show_size = TRUE;
+ }
}
if (file_icon_name) {
gtk_image_set_from_icon_name (GTK_IMAGE (priv->icon), UNKNOWN_FILE_ICON, GTK_ICON_SIZE_MENU);
}
- gtk_label_set_text (GTK_LABEL (priv->filename_view), filename);
+ if (priv->is_purged) {
+ gchar * label_str = g_markup_printf_escaped(
+ "<span style='italic' foreground='grey'>%s</span>",
+ filename);
+ gtk_label_set_markup (GTK_LABEL (priv->filename_view), label_str);
+ g_free (label_str);
+ } else {
+ gtk_label_set_text (GTK_LABEL (priv->filename_view), filename);
+ }
+ g_free (filename);
update_filename_request (MODEST_ATTACHMENT_VIEW (self));
gtk_label_set_text (GTK_LABEL (priv->size_view), "");
- if (show_size)
- priv->get_size_idle_id = g_idle_add ((GSourceFunc) get_size_idle_func, (gpointer) self);
+ if (show_size) {
+ tny_camel_mem_stream_get_type ();
+ g_object_ref (self);
+ g_thread_create (get_mime_part_size_thread, self, FALSE, NULL);
+ }
gtk_widget_queue_draw (GTK_WIDGET (self));
}
static void
modest_attachment_view_clear_default (TnyMimePartView *self)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (self);
if (priv->mime_part != NULL) {
g_object_unref (priv->mime_part);
static void
modest_attachment_view_instance_init (GTypeInstance *instance, gpointer g_class)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (instance);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (instance);
PangoContext *context;
GtkWidget *box = NULL;
static void
modest_attachment_view_finalize (GObject *object)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (object);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (object);
if (priv->get_size_idle_id) {
g_source_remove (priv->get_size_idle_id);
static void
size_allocate (GtkWidget *widget, GtkAllocation *allocation)
{
- ModestAttachmentViewPriv *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (widget);
+ ModestAttachmentViewPrivate *priv = MODEST_ATTACHMENT_VIEW_GET_PRIVATE (widget);
gint width, width_diff;
GTK_WIDGET_CLASS (parent_class)->size_allocate (widget, allocation);
widget_class->size_allocate = size_allocate;
- g_type_class_add_private (object_class, sizeof (ModestAttachmentViewPriv));
+ g_type_class_add_private (object_class, sizeof (ModestAttachmentViewPrivate));
return;
}