recognise model/* mime type
[claws.git] / src / procmime.h
index e5723e2cfae5f171a56c1a95712bcc7508e21ae5..ac734471a69e4d974d606e192dc56b9afd64a26d 100644 (file)
 #include "claws-features.h"
 #endif
 
-typedef struct _MimeType       MimeType;
-typedef struct _MimeInfo       MimeInfo;
-typedef struct _MimeParser     MimeParser;
+#include <gio/gio.h>
 
-#include "procmsg.h"
 #include "utils.h"
-
+#include "proctypes.h"
 typedef enum
 {
        ENC_7BIT,
@@ -51,6 +48,7 @@ typedef enum
        MIMETYPE_APPLICATION,
        MIMETYPE_MESSAGE,
        MIMETYPE_MULTIPART,
+       MIMETYPE_MODEL,
        MIMETYPE_UNKNOWN
 } MimeMediaType;
 
@@ -71,8 +69,7 @@ typedef enum
 #include <glib.h>
 #include <stdio.h>
 
-#include "procmsg.h"
-#include "privacy.h"
+struct _PrivacyData;
 
 struct _MimeType
 {
@@ -150,7 +147,7 @@ struct _MimeInfo
        GHashTable      *dispositionparameters;
 
        /* Privacy */
-       PrivacyData     *privacy;
+       struct _PrivacyData     *privacy;
 
        gboolean         broken;
 };
@@ -165,7 +162,7 @@ extern "C" {
 /* MimeInfo handling */
 
 MimeInfo *procmime_mimeinfo_new                (void);
-void procmime_mimeinfo_free_all                (MimeInfo       *mimeinfo);
+void procmime_mimeinfo_free_all                (MimeInfo       **mimeinfo_ptr);
 
 MimeInfo *procmime_mimeinfo_insert     (MimeInfo       *parent,
                                         MimeInfo       *mimeinfo);
@@ -236,6 +233,19 @@ void procmime_mimeparser_unregister(MimeParser *mimeparser);
 FILE *procmime_get_text_content(MimeInfo *mimeinfo);
 FILE *procmime_get_binary_content(MimeInfo *mimeinfo);
 
+/* scans mimeinfo contents, calling scan_callback() once per line.
+ * return TRUE and scan is aborted if scan_callback returns TRUE.
+ * return TRUE on error.
+ * return FALSE if scan completed and scan_callback never returned TRUE.
+ */
+gboolean procmime_scan_text_content(MimeInfo *mimeinfo,
+               gboolean (*scan_callback)(const gchar *str, gpointer cb_data),
+               gpointer cb_data);
+void *procmime_get_part_as_string(MimeInfo *mimeinfo,
+               gboolean null_terminate);
+GInputStream *procmime_get_part_as_inputstream(MimeInfo *mimeinfo,
+               GError **error);
+
 #ifdef __cplusplus
 }
 #endif /* __cplusplus */