[evolution/webkit: 109/154] Port TNEF attachments plugin to the new	EMFormat API
- From: Dan VrÃtil <dvratil src gnome org>
- To: commits-list gnome org
- Cc: 
- Subject: [evolution/webkit: 109/154] Port TNEF attachments plugin to the new	EMFormat API
- Date: Tue, 14 Feb 2012 14:10:46 +0000 (UTC)
commit 5772835e3e14648ce99ace51fc67e02fed6547e3
Author: Dan VrÃtil <dvratil redhat com>
Date:   Mon Jan 9 10:41:16 2012 +0100
    Port TNEF attachments plugin to the new EMFormat API
    
    (I somehow missed this plugin when porting other plugins long time ago)
 plugins/tnef-attachments/tnef-plugin.c |   62 +++++++++++++++++---------------
 1 files changed, 33 insertions(+), 29 deletions(-)
---
diff --git a/plugins/tnef-attachments/tnef-plugin.c b/plugins/tnef-attachments/tnef-plugin.c
index 5ef2f27..761a41b 100644
--- a/plugins/tnef-attachments/tnef-plugin.c
+++ b/plugins/tnef-attachments/tnef-plugin.c
@@ -19,6 +19,7 @@
  *
  */
 
+
 #ifdef HAVE_CONFIG_H
 #include <config.h>
 #endif
@@ -92,6 +93,7 @@ org_gnome_format_tnef (gpointer ep,
 	CamelMultipart *mp;
 	CamelMimePart *mainpart;
 	CamelDataWrapper *content;
+        const EMFormatHandler *handler;
 	gint len;
 	TNEFStruct tnef;
 
@@ -102,20 +104,26 @@ org_gnome_format_tnef (gpointer ep,
 	name = g_build_filename(tmpdir, ".evo-attachment.tnef", NULL);
 
 	out = camel_stream_fs_new_with_name (name, O_RDWR | O_CREAT, 0666, NULL);
-	if (out == NULL)
-	    goto fail;
+	if (out == NULL) {
+            g_free (name);
+	    return;
+        }
 	content = camel_medium_get_content ((CamelMedium *) t->part);
-	if (content == NULL)
-		goto fail;
+	if (content == NULL) {
+                g_free (name);
+                g_object_unref (out);
+		return;
+        }
 	if (camel_data_wrapper_decode_to_stream_sync (content, out, NULL, NULL) == -1
 	    || camel_stream_close (out, NULL, NULL) == -1) {
 		g_object_unref (out);
-		goto fail;
+                g_free (name);
+		return;
 	}
 	g_object_unref (out);
 
 	/* Extracting the winmail.dat */
-	TNEFInitialize (&tnef);
+        TNEFInitialize (&tnef);
 	tnef.Debug = verbose;
 	if (TNEFParseFile (name, &tnef) == -1) {
             printf("ERROR processing file\n");
@@ -126,8 +134,11 @@ org_gnome_format_tnef (gpointer ep,
 	/* Extraction done */
 
 	dir = opendir (tmpdir);
-	if (dir == NULL)
-	    goto fail;
+	if (dir == NULL) {
+            g_object_unref (out);
+            g_free (name);
+	    return;
+        }
 
 	mainpart = camel_mime_part_new ();
 
@@ -177,33 +188,26 @@ org_gnome_format_tnef (gpointer ep,
 
 	closedir (dir);
 
-	len = t->format->part_id->len;
-	g_string_append_printf(t->format->part_id, ".tnef");
-
-	if (camel_multipart_get_number (mp) > 0)
-		/* FIXME Not passing a GCancellable here. */
-		em_format_part_as (
-			t->format, t->stream, mainpart,
-			"multipart/mixed", NULL);
-	else if (t->item->handler.old)
-		/* FIXME Not passing a GCancellable here. */
-		t->item->handler.old->handler (
-			t->format, t->stream, t->part,
-			t->item->handler.old, NULL, FALSE);
+	len = t->part_id->len;
+	g_string_append_printf(t->part_id, ".tnef");
+
+	if (camel_multipart_get_number (mp) > 0) {
+                handler = em_format_find_handler (t->format, "multiplart/mixed");
+                /* FIXME Not passing a GCancellable here. */
+                if (handler && handler->parse_func) {
+                        CamelMimePart *part = camel_mime_part_new ();
+                        camel_medium_set_content ((CamelMedium *) part,
+                                CAMEL_DATA_WRAPPER (mp));
+                        handler->parse_func (t->format, part, t->part_id, t->info, NULL);
+                        g_object_unref (part);
+                }
+        }
 
-	g_string_truncate (t->format->part_id, len);
+	g_string_truncate (t->part_id, len);
 
 	g_object_unref (mp);
 	g_object_unref (mainpart);
 
-	goto ok;
- fail:
-	if (t->item->handler.old)
-		/* FIXME Not passing a GCancellable here. */
-		t->item->handler.old->handler (
-			t->format, t->stream, t->part,
-			t->item->handler.old, NULL, FALSE);
- ok:
 	g_free (name);
 	g_free (tmpdir);
 }
[
Date Prev][
Date Next]   [
Thread Prev][
Thread Next]   
[
Thread Index]
[
Date Index]
[
Author Index]