aboutsummaryrefslogtreecommitdiffstats
path: root/em-format
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2013-05-26 03:36:42 +0800
committerMatthew Barnes <mbarnes@redhat.com>2013-06-08 12:25:11 +0800
commitc5313b3614bbcb912b4a81a1ffe75911b60ad580 (patch)
tree5fa2ce0980565db6992ae43efa84111dba34839f /em-format
parentbcfd1a92572941ebbcc503bb11461506a05416dc (diff)
downloadgsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.tar
gsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.tar.gz
gsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.tar.bz2
gsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.tar.lz
gsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.tar.xz
gsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.tar.zst
gsoc2013-evolution-c5313b3614bbcb912b4a81a1ffe75911b60ad580.zip
EMailPartHeaders: Add a "default-headers" property.
This will replace the headers API in EMailFormatter. Need a more permanent place for headers since EMailFormatter is too disposable. Also add an ESettingsMailPartHeaders class, which binds the new property to the "show-headers" setting with a suitable mapping function to filter out disabled header names.
Diffstat (limited to 'em-format')
-rw-r--r--em-format/e-mail-part-headers.c135
-rw-r--r--em-format/e-mail-part-headers.h9
2 files changed, 142 insertions, 2 deletions
diff --git a/em-format/e-mail-part-headers.c b/em-format/e-mail-part-headers.c
index d1398f993f..5a74376db8 100644
--- a/em-format/e-mail-part-headers.c
+++ b/em-format/e-mail-part-headers.c
@@ -18,11 +18,91 @@
#include "e-mail-part-headers.h"
+#include <config.h>
+#include <glib/gi18n-lib.h>
+
+#define E_MAIL_PART_HEADERS_GET_PRIVATE(obj) \
+ (G_TYPE_INSTANCE_GET_PRIVATE \
+ ((obj), E_TYPE_MAIL_PART_HEADERS, EMailPartHeadersPrivate))
+
+struct _EMailPartHeadersPrivate {
+ GMutex property_lock;
+ gchar **default_headers;
+};
+
+enum {
+ PROP_0,
+ PROP_DEFAULT_HEADERS
+};
+
G_DEFINE_TYPE (
EMailPartHeaders,
e_mail_part_headers,
E_TYPE_MAIL_PART)
+static const gchar *basic_headers[] = {
+ N_("From"),
+ N_("Reply-To"),
+ N_("To"),
+ N_("Cc"),
+ N_("Bcc"),
+ N_("Subject"),
+ N_("Date"),
+ N_("Newsgroups"),
+ N_("Face"),
+ NULL
+};
+
+static void
+mail_part_headers_set_property (GObject *object,
+ guint property_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ switch (property_id) {
+ case PROP_DEFAULT_HEADERS:
+ e_mail_part_headers_set_default_headers (
+ E_MAIL_PART_HEADERS (object),
+ g_value_get_boxed (value));
+ return;
+ }
+
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+}
+
+static void
+mail_part_headers_get_property (GObject *object,
+ guint property_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ switch (property_id) {
+ case PROP_DEFAULT_HEADERS:
+ g_value_take_boxed (
+ value,
+ e_mail_part_headers_dup_default_headers (
+ E_MAIL_PART_HEADERS (object)));
+ return;
+ }
+
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+}
+
+static void
+mail_part_headers_finalize (GObject *object)
+{
+ EMailPartHeadersPrivate *priv;
+
+ priv = E_MAIL_PART_HEADERS_GET_PRIVATE (object);
+
+ g_mutex_clear (&priv->property_lock);
+
+ g_strfreev (priv->default_headers);
+
+ /* Chain up to parent's finalize() method. */
+ G_OBJECT_CLASS (e_mail_part_headers_parent_class)->finalize (object);
+}
+
static void
mail_part_headers_constructed (GObject *object)
{
@@ -70,16 +150,36 @@ e_mail_part_headers_class_init (EMailPartHeadersClass *class)
GObjectClass *object_class;
EMailPartClass *mail_part_class;
+ g_type_class_add_private (class, sizeof (EMailPartHeadersPrivate));
+
object_class = G_OBJECT_CLASS (class);
+ object_class->set_property = mail_part_headers_set_property;
+ object_class->get_property = mail_part_headers_get_property;
+ object_class->finalize = mail_part_headers_finalize;
object_class->constructed = mail_part_headers_constructed;
mail_part_class = E_MAIL_PART_CLASS (class);
mail_part_class->bind_dom_element = mail_part_headers_bind_dom_element;
+
+ g_object_class_install_property (
+ object_class,
+ PROP_DEFAULT_HEADERS,
+ g_param_spec_boxed (
+ "default-headers",
+ "Default Headers",
+ "Headers to display by default",
+ G_TYPE_STRV,
+ G_PARAM_READWRITE |
+ G_PARAM_CONSTRUCT |
+ G_PARAM_STATIC_STRINGS));
}
static void
e_mail_part_headers_init (EMailPartHeaders *part)
{
+ part->priv = E_MAIL_PART_HEADERS_GET_PRIVATE (part);
+
+ g_mutex_init (&part->priv->property_lock);
}
EMailPart *
@@ -93,3 +193,38 @@ e_mail_part_headers_new (CamelMimePart *mime_part,
"id", id, "mime-part", mime_part, NULL);
}
+gchar **
+e_mail_part_headers_dup_default_headers (EMailPartHeaders *part)
+{
+ gchar **default_headers;
+
+ g_return_val_if_fail (E_IS_MAIL_PART_HEADERS (part), NULL);
+
+ g_mutex_lock (&part->priv->property_lock);
+
+ default_headers = g_strdupv (part->priv->default_headers);
+
+ g_mutex_unlock (&part->priv->property_lock);
+
+ return default_headers;
+}
+
+void
+e_mail_part_headers_set_default_headers (EMailPartHeaders *part,
+ const gchar * const *default_headers)
+{
+ g_return_if_fail (E_IS_MAIL_PART_HEADERS (part));
+
+ if (default_headers == NULL)
+ default_headers = basic_headers;
+
+ g_mutex_lock (&part->priv->property_lock);
+
+ g_strfreev (part->priv->default_headers);
+ part->priv->default_headers = g_strdupv ((gchar **) default_headers);
+
+ g_mutex_unlock (&part->priv->property_lock);
+
+ g_object_notify (G_OBJECT (part), "default-headers");
+}
+
diff --git a/em-format/e-mail-part-headers.h b/em-format/e-mail-part-headers.h
index fb0e0eb5d7..c302637dc5 100644
--- a/em-format/e-mail-part-headers.h
+++ b/em-format/e-mail-part-headers.h
@@ -32,10 +32,10 @@
((cls), E_TYPE_MAIL_PART_HEADERS, EMailPartHeadersClass))
#define E_IS_MAIL_PART_HEADERS(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE \
- ((cls), E_TYPE_MAIL_PART_HEADERS))
+ ((obj), E_TYPE_MAIL_PART_HEADERS))
#define E_IS_MAIL_PART_HEADERS_CLASS(cls) \
(G_TYPE_CHECK_CLASS_TYPE \
- ((obj), E_TYPE_MAIL_PART_HEADERS))
+ ((cls), E_TYPE_MAIL_PART_HEADERS))
#define E_MAIL_PART_HEADERS_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_CLASS \
((obj), E_TYPE_MAIL_PART_HEADERS, EMailPartHeadersClass))
@@ -61,6 +61,11 @@ struct _EMailPartHeadersClass {
GType e_mail_part_headers_get_type (void) G_GNUC_CONST;
EMailPart * e_mail_part_headers_new (CamelMimePart *mime_part,
const gchar *id);
+gchar ** e_mail_part_headers_dup_default_headers
+ (EMailPartHeaders *part);
+void e_mail_part_headers_set_default_headers
+ (EMailPartHeaders *part,
+ const gchar * const *default_headers);
G_END_DECLS