aboutsummaryrefslogtreecommitdiffstats
path: root/em-format
diff options
context:
space:
mode:
Diffstat (limited to 'em-format')
-rw-r--r--em-format/e-mail-parser.c191
1 files changed, 95 insertions, 96 deletions
diff --git a/em-format/e-mail-parser.c b/em-format/e-mail-parser.c
index 84327c8559..6e0791e0d9 100644
--- a/em-format/e-mail-parser.c
+++ b/em-format/e-mail-parser.c
@@ -34,7 +34,11 @@
#include <string.h>
-static gpointer parent_class = 0;
+#define E_MAIL_PARSER_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_MAIL_PARSER, EMailParserPrivate))
+
+#define d(x)
struct _EMailParserPrivate {
GMutex mutex;
@@ -44,24 +48,20 @@ struct _EMailParserPrivate {
CamelSession *session;
};
-#define E_MAIL_PARSER_GET_PRIVATE(obj) \
- (G_TYPE_INSTANCE_GET_PRIVATE \
- ((obj), E_TYPE_MAIL_PARSER, EMailParserPrivate))
-
-#define d(x)
-
enum {
PROP_0,
PROP_SESSION
};
-static GSList *
+static gpointer parent_class;
+
+static void
mail_parser_run (EMailParser *parser,
- CamelMimeMessage *message,
+ EMailPartList *part_list,
GCancellable *cancellable)
{
- GSList *parts;
EMailExtensionRegistry *reg;
+ EMailPart *part;
GQueue *parsers;
GList *iter;
GString *part_id;
@@ -69,18 +69,17 @@ mail_parser_run (EMailParser *parser,
reg = e_mail_parser_get_extension_registry (parser);
parsers = e_mail_extension_registry_get_for_mime_type (
- reg, "application/vnd.evolution.message");
+ reg, "application/vnd.evolution.message");
- if (!parsers)
+ if (parsers == NULL)
parsers = e_mail_extension_registry_get_for_mime_type (
reg, "message/*");
- /* parsers == NULL means, that the internal Evolution parser extensions
- * were not loaded. Something is terribly wrong. */
- g_return_val_if_fail (parsers != NULL, NULL);
+ /* parsers == NULL means, that the internal Evolution parser
+ * extensions were not loaded. Something is terribly wrong. */
+ g_return_if_fail (parsers != NULL);
part_id = g_string_new (".message");
- parts = NULL;
for (iter = parsers->head; iter; iter = iter->next) {
@@ -93,36 +92,30 @@ mail_parser_run (EMailParser *parser,
if (!extension)
continue;
- parts = e_mail_parser_extension_parse (
- extension, parser, CAMEL_MIME_PART (message),
+ part_list->list = e_mail_parser_extension_parse (
+ extension, parser,
+ CAMEL_MIME_PART (part_list->message),
part_id, cancellable);
- if (parts != NULL)
+ if (part_list->list != NULL)
break;
}
- parts = g_slist_prepend (
- parts,
- e_mail_part_new (CAMEL_MIME_PART (message), ".message"));
+ part = e_mail_part_new (
+ CAMEL_MIME_PART (part_list->message), ".message");
+ part_list->list = g_slist_prepend (part_list->list, part);
g_string_free (part_id, TRUE);
-
- return parts;
}
static void
mail_parser_set_session (EMailParser *parser,
CamelSession *session)
{
- g_return_if_fail (E_IS_MAIL_PARSER (parser));
g_return_if_fail (CAMEL_IS_SESSION (session));
+ g_return_if_fail (parser->priv->session == NULL);
- g_object_ref (session);
-
- if (parser->priv->session)
- g_object_unref (parser->priv->session);
-
- parser->priv->session = session;
+ parser->priv->session = g_object_ref (session);
}
static void
@@ -131,12 +124,10 @@ e_mail_parser_set_property (GObject *object,
const GValue *value,
GParamSpec *pspec)
{
- EMailParser *parser = E_MAIL_PARSER (object);
-
switch (property_id) {
case PROP_SESSION:
mail_parser_set_session (
- parser,
+ E_MAIL_PARSER (object),
g_value_get_object (value));
return;
}
@@ -150,13 +141,12 @@ e_mail_parser_get_property (GObject *object,
GValue *value,
GParamSpec *pspec)
{
- EMailParser *parser = E_MAIL_PARSER (object);
-
switch (property_id) {
case PROP_SESSION:
g_value_set_object (
value,
- e_mail_parser_get_session (parser));
+ e_mail_parser_get_session (
+ E_MAIL_PARSER (object)));
return;
}
@@ -168,19 +158,13 @@ e_mail_parser_finalize (GObject *object)
{
EMailParserPrivate *priv;
- priv = E_MAIL_PARSER (object)->priv;
+ priv = E_MAIL_PARSER_GET_PRIVATE (object);
g_mutex_clear (&priv->mutex);
+ /* Chain up to parent's finalize() method. */
G_OBJECT_CLASS (parent_class)->finalize (object);
}
-static void
-e_mail_parser_init (EMailParser *parser)
-{
- parser->priv = E_MAIL_PARSER_GET_PRIVATE (parser);
-
- g_mutex_init (&parser->priv->mutex);
-}
static void
e_mail_parser_base_init (EMailParserClass *class)
@@ -225,6 +209,14 @@ e_mail_parser_class_init (EMailParserClass *class)
G_PARAM_CONSTRUCT_ONLY));
}
+static void
+e_mail_parser_init (EMailParser *parser)
+{
+ parser->priv = E_MAIL_PARSER_GET_PRIVATE (parser);
+
+ g_mutex_init (&parser->priv->mutex);
+}
+
GType
e_mail_parser_get_type (void)
{
@@ -255,6 +247,8 @@ e_mail_parser_get_type (void)
EMailParser *
e_mail_parser_new (CamelSession *session)
{
+ g_return_val_if_fail (CAMEL_IS_SESSION (session), NULL);
+
return g_object_new (
E_TYPE_MAIL_PARSER,
"session", session, NULL);
@@ -283,22 +277,20 @@ e_mail_parser_parse_sync (EMailParser *parser,
CamelMimeMessage *message,
GCancellable *cancellable)
{
- EMailPartList *parts_list;
+ EMailPartList *part_list;
g_return_val_if_fail (E_IS_MAIL_PARSER (parser), NULL);
g_return_val_if_fail (CAMEL_IS_MIME_MESSAGE (message), NULL);
- parts_list = e_mail_part_list_new ();
-
- if (folder)
- parts_list->folder = g_object_ref (folder);
+ part_list = e_mail_part_list_new ();
- if (message_uid)
- parts_list->message_uid = g_strdup (message_uid);
+ if (folder != NULL)
+ part_list->folder = g_object_ref (folder);
- parts_list->message = g_object_ref (message);
+ part_list->message_uid = g_strdup (message_uid);
+ part_list->message = g_object_ref (message);
- parts_list->list = mail_parser_run (parser, message, cancellable);
+ mail_parser_run (parser, part_list, cancellable);
if (camel_debug_start ("emformat:parser")) {
GSList *iter;
@@ -307,11 +299,12 @@ e_mail_parser_parse_sync (EMailParser *parser,
"%s finished with EMailPartList:\n",
G_OBJECT_TYPE_NAME (parser));
- for (iter = parts_list->list; iter; iter = iter->next) {
+ for (iter = part_list->list; iter; iter = iter->next) {
EMailPart *part = iter->data;
if (!part) continue;
printf (
- " id: %s | cid: %s | mime_type: %s | is_hidden: %d | is_attachment: %d\n",
+ " id: %s | cid: %s | mime_type: %s | "
+ "is_hidden: %d | is_attachment: %d\n",
part->id, part->cid, part->mime_type,
part->is_hidden ? 1 : 0,
part->is_attachment ? 1 : 0);
@@ -320,22 +313,21 @@ e_mail_parser_parse_sync (EMailParser *parser,
camel_debug_end ();
}
- return parts_list;
+ return part_list;
}
static void
-mail_parser_prepare_async (GSimpleAsyncResult *res,
- GObject *object,
- GCancellable *cancellable)
+mail_parser_parse_thread (GSimpleAsyncResult *simple,
+ GObject *source_object,
+ GCancellable *cancellable)
{
- CamelMimeMessage *message;
- GSList *list;
-
- message = g_object_get_data (G_OBJECT (res), "message");
+ EMailPartList *part_list;
- list = mail_parser_run (E_MAIL_PARSER (object), message, cancellable);
+ part_list = g_simple_async_result_get_op_res_gpointer (simple);
- g_simple_async_result_set_op_res_gpointer (res, list, NULL);
+ mail_parser_run (
+ E_MAIL_PARSER (source_object),
+ part_list, cancellable);
}
/**
@@ -346,7 +338,7 @@ mail_parser_prepare_async (GSimpleAsyncResult *res,
* @cancellable: (allow-none) a #GCancellable
* @user_data: (allow-none) user data passed to the callback
*
- * Asynchronous version of #e_mail_parser_parse_sync().
+ * Asynchronous version of e_mail_parser_parse_sync().
*/
void
e_mail_parser_parse (EMailParser *parser,
@@ -357,24 +349,32 @@ e_mail_parser_parse (EMailParser *parser,
GCancellable *cancellable,
gpointer user_data)
{
- GSimpleAsyncResult *result;
+ GSimpleAsyncResult *simple;
+ EMailPartList *part_list;
g_return_if_fail (E_IS_MAIL_PARSER (parser));
g_return_if_fail (CAMEL_IS_MIME_MESSAGE (message));
- result = g_simple_async_result_new (
+ part_list = e_mail_part_list_new ();
+ part_list->message = g_object_ref (message);
+ part_list->message_uid = g_strdup (message_uid);
+ if (folder != NULL)
+ part_list->folder = g_object_ref (folder);
+
+ simple = g_simple_async_result_new (
G_OBJECT (parser), callback,
user_data, e_mail_parser_parse);
- g_object_set_data (G_OBJECT (result), "message", g_object_ref (message));
+ g_simple_async_result_set_check_cancellable (simple, cancellable);
- if (folder)
- g_object_set_data (G_OBJECT (result), "folder", g_object_ref (folder));
- if (message_uid)
- g_object_set_data (G_OBJECT (result), "message_uid", g_strdup (message_uid));
+ g_simple_async_result_set_op_res_gpointer (
+ simple, part_list, (GDestroyNotify) g_object_unref);
g_simple_async_result_run_in_thread (
- result, mail_parser_prepare_async, G_PRIORITY_DEFAULT, cancellable);
+ simple, mail_parser_parse_thread,
+ G_PRIORITY_DEFAULT, cancellable);
+
+ g_object_unref (simple);
}
EMailPartList *
@@ -382,30 +382,29 @@ e_mail_parser_parse_finish (EMailParser *parser,
GAsyncResult *result,
GError **error)
{
- EMailPartList *parts_list;
-
- parts_list = e_mail_part_list_new ();
+ GSimpleAsyncResult *simple;
+ EMailPartList *part_list;
- /* The data were ref'ed or copied in e_mail_parser_parse_async */
- parts_list->message = g_object_get_data (G_OBJECT (result), "message");
- parts_list->folder = g_object_get_data (G_OBJECT (result), "folder");
- parts_list->message_uid = g_object_get_data (G_OBJECT (result), "message_uid");
+ g_return_val_if_fail (
+ g_simple_async_result_is_valid (
+ result, G_OBJECT (parser), e_mail_parser_parse), NULL);
- parts_list->list = g_simple_async_result_get_op_res_gpointer (
- G_SIMPLE_ASYNC_RESULT (result));
+ simple = G_SIMPLE_ASYNC_RESULT (result);
+ part_list = g_simple_async_result_get_op_res_gpointer (simple);
if (camel_debug_start ("emformat:parser")) {
GSList *iter;
printf (
"%s finished with EMailPartList:\n",
- G_OBJECT_TYPE_NAME (parser));
+ G_OBJECT_TYPE_NAME (parser));
- for (iter = parts_list->list; iter; iter = iter->next) {
+ for (iter = part_list->list; iter; iter = iter->next) {
EMailPart *part = iter->data;
if (!part) continue;
printf (
- " id: %s | cid: %s | mime_type: %s | is_hidden: %d | is_attachment: %d\n",
+ " id: %s | cid: %s | mime_type: %s | "
+ "is_hidden: %d | is_attachment: %d\n",
part->id, part->cid, part->mime_type,
part->is_hidden ? 1 : 0,
part->is_attachment ? 1 : 0);
@@ -414,7 +413,7 @@ e_mail_parser_parse_finish (EMailParser *parser,
camel_debug_end ();
}
- return parts_list;
+ return g_object_ref (part_list);
}
GSList *
@@ -438,7 +437,7 @@ e_mail_parser_parse_part (EMailParser *parser,
}
list = e_mail_parser_parse_part_as (
- parser, part, part_id, mime_type, cancellable);
+ parser, part, part_id, mime_type, cancellable);
if (ct) {
g_free (mime_type);
@@ -482,7 +481,7 @@ e_mail_parser_parse_part_as (EMailParser *parser,
if (!parsers) {
return e_mail_parser_wrap_as_attachment (
- parser, part, NULL, part_id, cancellable);
+ parser, part, NULL, part_id, cancellable);
}
for (iter = parsers->head; iter; iter = iter->next) {
@@ -493,7 +492,7 @@ e_mail_parser_parse_part_as (EMailParser *parser,
continue;
part_list = e_mail_parser_extension_parse (
- extension, parser, part, part_id, cancellable);
+ extension, parser, part, part_id, cancellable);
if (part_list)
break;
@@ -596,7 +595,7 @@ e_mail_parser_wrap_as_attachment (EMailParser *parser,
reg = e_mail_parser_get_extension_registry (parser);
extensions = e_mail_extension_registry_get_for_mime_type (
- reg, mime_type);
+ reg, mime_type);
if (camel_content_type_is (ct, "text", "*") ||
camel_content_type_is (ct, "message", "*"))
@@ -613,7 +612,7 @@ e_mail_parser_wrap_as_attachment (EMailParser *parser,
reg = e_mail_parser_get_extension_registry (parser);
extensions = e_mail_extension_registry_get_for_mime_type (
- reg, snoop_mime_type);
+ reg, snoop_mime_type);
if (!extensions) {
extensions = e_mail_extension_registry_get_fallback (
@@ -625,12 +624,12 @@ e_mail_parser_wrap_as_attachment (EMailParser *parser,
g_string_append (part_id, ".attachment");
empa = (EMailPartAttachment *) e_mail_part_subclass_new (
- part, part_id->str, sizeof (EMailPartAttachment),
- (GFreeFunc) e_mail_part_attachment_free);
+ part, part_id->str, sizeof (EMailPartAttachment),
+ (GFreeFunc) e_mail_part_attachment_free);
empa->parent.mime_type = g_strdup ("application/vnd.evolution.attachment");
empa->parent.is_attachment = TRUE;
empa->shown = extensions && (!g_queue_is_empty (extensions) &&
- e_mail_part_is_inline (part, extensions));
+ e_mail_part_is_inline (part, extensions));
empa->snoop_mime_type = snoop_mime_type;
empa->attachment = e_attachment_new ();
empa->attachment_view_part_id = parts ? g_strdup (E_MAIL_PART (parts->data)->id) : NULL;