recognise model/* mime type
[claws.git] / src / procmime.h
index 122a530de08f0ee687c9afec3ee2d61be3f3fb1a..ac734471a69e4d974d606e192dc56b9afd64a26d 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2009 Hiroyuki Yamamoto and the Claws Mail team
+ * Copyright (C) 1999-2012 Hiroyuki Yamamoto and the Claws Mail team
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
 #define __PROCMIME_H__
 
 #ifdef HAVE_CONFIG_H
-#  include "config.h"
+#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);
@@ -205,10 +202,6 @@ FILE *procmime_get_first_text_content      (MsgInfo        *msginfo);
 FILE *procmime_get_first_encrypted_text_content
                                        (MsgInfo        *msginfo);
 
-gboolean procmime_find_string          (MsgInfo        *msginfo,
-                                        const gchar    *str,
-                                        StrFindFunc     find_func);
-
 gchar *procmime_get_tmp_file_name      (MimeInfo       *mimeinfo);
 gchar *procmime_get_part_file_name     (MimeInfo       *mimeinfo);
 
@@ -237,6 +230,21 @@ gint procmime_write_mimeinfo(MimeInfo *mimeinfo, FILE *fp);
 
 void procmime_mimeparser_register(MimeParser *mimeparser);
 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
 }