[evolution/webkit: 87/154] Add preparse() virtual method to EMFormat
- From: Dan VrÃtil <dvratil src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/webkit: 87/154] Add preparse() virtual method to EMFormat
- Date: Tue, 14 Feb 2012 14:08:55 +0000 (UTC)
commit 04497056f4983ffa71f3959c9b587b5ab716d48e
Author: Dan VrÃtil <dvratil redhat com>
Date: Mon Dec 19 19:16:02 2011 +0100
Add preparse() virtual method to EMFormat
This method is called when folder and CamelMimeMessage are set in em_format_parse(), but before
the actual parsing begins. It allows parsers to initialize things that couldn't be
initialized without knowledge of the message and/or folder
em-format/em-format.c | 29 +++++++++++++++++------------
em-format/em-format.h | 2 ++
mail/em-format-html.c | 31 +++++++++++++++++++++++--------
3 files changed, 42 insertions(+), 20 deletions(-)
---
diff --git a/em-format/em-format.c b/em-format/em-format.c
index 36b5a2b..2d8bc28 100644
--- a/em-format/em-format.c
+++ b/em-format/em-format.c
@@ -1179,6 +1179,7 @@ emf_is_inline (EMFormat *emf,
return (handle->flags & EM_FORMAT_HANDLER_INLINE) != 0;
}
+
/**************************************************************************/
static EMFormatHandler type_handlers[] = {
@@ -1350,31 +1351,31 @@ em_format_finalize (GObject *object)
}
static void
-em_format_base_init (EMFormatClass *class)
+em_format_base_init (EMFormatClass *klass)
{
gint i;
- class->type_handlers = g_hash_table_new (g_str_hash, g_str_equal);
+ klass->type_handlers = g_hash_table_new (g_str_hash, g_str_equal);
for (i = 0; i < G_N_ELEMENTS (type_handlers); i++) {
- g_hash_table_insert (class->type_handlers,
+ g_hash_table_insert (klass->type_handlers,
type_handlers[i].mime_type,
&type_handlers[i]);
}
}
static void
-em_format_class_init (EMFormatClass *class)
+em_format_class_init (EMFormatClass *klass)
{
GObjectClass *object_class;
- parent_class = g_type_class_peek_parent (class);
+ parent_class = g_type_class_peek_parent (klass);
- g_type_class_add_private (class, sizeof (EMFormatPrivate));
+ g_type_class_add_private (klass, sizeof (EMFormatPrivate));
- class->is_inline = emf_is_inline;
+ klass->is_inline = emf_is_inline;
- object_class = G_OBJECT_CLASS (class);
+ object_class = G_OBJECT_CLASS (klass);
object_class->finalize = em_format_finalize;
object_class->get_property = em_format_get_property;
object_class->set_property = em_format_set_property;
@@ -1864,6 +1865,10 @@ em_format_parse (EMFormat *emf,
emf->folder = g_object_ref (folder);
}
+ /* Before the actual parsing starts, let child classes prepare themselves. */
+ if (EM_FORMAT_GET_CLASS (emf)->preparse)
+ EM_FORMAT_GET_CLASS (emf)->preparse(emf);
+
part_id = g_string_new (".message");
/* Create a special PURI with entire message */
@@ -2002,17 +2007,17 @@ em_format_is_inline (EMFormat *emf,
CamelMimePart *part,
const EMFormatHandler *handler)
{
- EMFormatClass *class;
+ EMFormatClass *klass;
g_return_val_if_fail (EM_IS_FORMAT (emf), FALSE);
g_return_val_if_fail (part_id && *part_id, FALSE);
g_return_val_if_fail (CAMEL_IS_MIME_PART (part), FALSE);
g_return_val_if_fail (handler, FALSE);
- class = EM_FORMAT_GET_CLASS (emf);
- g_return_val_if_fail (class->is_inline != NULL, FALSE);
+ klass = EM_FORMAT_GET_CLASS (emf);
+ g_return_val_if_fail (klass->is_inline != NULL, FALSE);
- return class->is_inline (emf, part_id, part, handler);
+ return klass->is_inline (emf, part_id, part, handler);
}
diff --git a/em-format/em-format.h b/em-format/em-format.h
index 221f6d1..d62d688 100644
--- a/em-format/em-format.h
+++ b/em-format/em-format.h
@@ -187,6 +187,8 @@ struct _EMFormatClass {
const gchar *part_id,
CamelMimePart *part,
const EMFormatHandler *handler);
+
+ void (*preparse) (EMFormat *emf);
};
EMFormat* em_format_new (void);
diff --git a/mail/em-format-html.c b/mail/em-format-html.c
index f73d184..bc78e18 100644
--- a/mail/em-format-html.c
+++ b/mail/em-format-html.c
@@ -78,7 +78,7 @@ struct _EMFormatHTMLPrivate {
GdkColor colors[EM_FORMAT_HTML_NUM_COLOR_TYPES];
EMailImageLoadingPolicy image_loading_policy;
- guint load_images_now : 1;
+ guint can_load_images : 1;
guint only_local_photos : 1;
guint show_sender_photo : 1;
guint show_real_date : 1;
@@ -1308,20 +1308,35 @@ efh_write_attachment (EMFormat *emf,
}
static void
-efh_base_init (EMFormatHTMLClass *class)
+efh_preparse (EMFormat *emf)
{
- efh_builtin_init (class);
+ CamelInternetAddress *addr;
+
+ EMFormatHTML *efh = EM_FORMAT_HTML (emf);
+
+ addr = camel_mime_message_get_from (emf->message);
+ efh->priv->can_load_images = em_utils_in_addressbook (addr, FALSE);
}
static void
-efh_class_init (EMFormatHTMLClass *class)
+efh_base_init (EMFormatHTMLClass *klass)
+{
+ efh_builtin_init (klass);
+}
+
+static void
+efh_class_init (EMFormatHTMLClass *klass)
{
GObjectClass *object_class;
+ EMFormatClass *emf_class;
+
+ parent_class = g_type_class_peek_parent (klass);
+ g_type_class_add_private (klass, sizeof (EMFormatHTMLPrivate));
- parent_class = g_type_class_peek_parent (class);
- g_type_class_add_private (class, sizeof (EMFormatHTMLPrivate));
+ emf_class = EM_FORMAT_CLASS (klass);
+ emf_class->preparse = efh_preparse;
- object_class = G_OBJECT_CLASS (class);
+ object_class = G_OBJECT_CLASS (klass);
object_class->set_property = efh_set_property;
object_class->get_property = efh_get_property;
object_class->finalize = efh_finalize;
@@ -1446,7 +1461,7 @@ efh_class_init (EMFormatHTMLClass *class)
static void
efh_init (EMFormatHTML *efh,
- EMFormatHTMLClass *class)
+ EMFormatHTMLClass *klass)
{
GdkColor *color;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]