[evolution] EMEventTargetFolder: Add an EAccount member.



commit 5fcf41925becbac39447b315097b062de2bfd0a1
Author: Matthew Barnes <mbarnes redhat com>
Date:   Mon May 2 14:21:21 2011 -0400

    EMEventTargetFolder: Add an EAccount member.
    
    The mail-notification plugin can use the EAccount member directly
    instead of searching for it by URI.

 mail/e-mail-backend.c                         |    7 ++++++-
 mail/em-event.c                               |    7 +++++++
 mail/em-event.h                               |    2 ++
 plugins/mail-notification/mail-notification.c |   20 ++++++++------------
 4 files changed, 23 insertions(+), 13 deletions(-)
---
diff --git a/mail/e-mail-backend.c b/mail/e-mail-backend.c
index dd8f69a..7ccfa72 100644
--- a/mail/e-mail-backend.c
+++ b/mail/e-mail-backend.c
@@ -361,6 +361,8 @@ mail_backend_folder_changed_cb (MailFolderCache *folder_cache,
 	EMEvent *event = em_event_peek ();
 	EMEventTargetFolder *target;
 	EMFolderTreeModel *model;
+	EAccount *account;
+	const gchar *uid;
 	gint folder_type;
 	gint flags = 0;
 
@@ -370,8 +372,11 @@ mail_backend_folder_changed_cb (MailFolderCache *folder_cache,
 				folder_cache, folder, &flags))
 			g_return_if_reached ();
 
+	uid = camel_service_get_uid (CAMEL_SERVICE (store));
+	account = e_get_account_by_uid (uid);
+
 	target = em_event_target_new_folder (
-		event, folder_uri, new_messages,
+		event, account, folder_uri, new_messages,
 		msg_uid, msg_sender, msg_subject);
 
 	folder_type = (flags & CAMEL_FOLDER_TYPE_MASK);
diff --git a/mail/em-event.c b/mail/em-event.c
index 084c857..a1b0442 100644
--- a/mail/em-event.c
+++ b/mail/em-event.c
@@ -42,6 +42,8 @@ eme_target_free (EEvent *ep, EEventTarget *t)
 	switch (t->type) {
 	case EM_EVENT_TARGET_FOLDER: {
 		EMEventTargetFolder *s = (EMEventTargetFolder *)t;
+		if (s->account != NULL)
+			g_object_unref (s->account);
 		g_free (s->name);
 		g_free (s->uri);
 		g_free (s->msg_uid);
@@ -108,6 +110,7 @@ em_event_peek (void)
 
 EMEventTargetFolder *
 em_event_target_new_folder (EMEvent *eme,
+                            EAccount *account,
                             const gchar *uri,
                             guint new,
                             const gchar *msg_uid,
@@ -120,6 +123,10 @@ em_event_target_new_folder (EMEvent *eme,
 	t = e_event_target_new (
 		&eme->popup, EM_EVENT_TARGET_FOLDER, sizeof (*t));
 
+	if (E_IS_ACCOUNT (account))
+		t->account = g_object_ref (account);
+	else
+		t->account = NULL;
 	t->uri = g_strdup (uri);
 	t->target.mask = ~flags;
 	t->new = new;
diff --git a/mail/em-event.h b/mail/em-event.h
index 34441c5..644ba21 100644
--- a/mail/em-event.h
+++ b/mail/em-event.h
@@ -74,6 +74,7 @@ typedef struct _EMEventTargetFolder EMEventTargetFolder;
 
 struct _EMEventTargetFolder {
 	EEventTarget target;
+	EAccount *account;
 	gchar *uri;
 	guint new;
 	gboolean is_inbox;
@@ -136,6 +137,7 @@ GType		em_event_get_type		(void);
 EMEvent *	em_event_peek			(void);
 EMEventTargetFolder *
 		em_event_target_new_folder	(EMEvent *emp,
+						 EAccount *account,
 						 const gchar *uri,
 						 guint32 count_new_msgs,
 						 const gchar *msg_uid,
diff --git a/plugins/mail-notification/mail-notification.c b/plugins/mail-notification/mail-notification.c
index 5cde1fb..9f236c0 100644
--- a/plugins/mail-notification/mail-notification.c
+++ b/plugins/mail-notification/mail-notification.c
@@ -379,16 +379,13 @@ new_notify_status (EMEventTargetFolder *t)
 	gchar *msg;
 
 	if (!status_count) {
-		EAccount *account;
-		gchar *name = t->name;
+		gchar *folder_name;
 
-		account = e_get_account_by_source_url (t->uri);
-
-		if (account != NULL) {
-			name = g_strdup_printf (
-				"%s/%s", e_account_get_string (
-				account, E_ACCOUNT_NAME), name);
-		}
+		if (t->account != NULL)
+			folder_name = g_strdup_printf (
+				"%s/%s", t->account->name, t->name);
+		else
+			folder_name = g_strdup (t->name);
 
 		status_count = t->new;
 
@@ -397,10 +394,9 @@ new_notify_status (EMEventTargetFolder *t)
 		msg = g_strdup_printf (ngettext (
 			"You have received %d new message\nin %s.",
 			"You have received %d new messages\nin %s.",
-			status_count), status_count, name);
+			status_count), status_count, folder_name);
 
-		if (name != t->name)
-			g_free (name);
+		g_free (folder_name);
 
 		if (t->msg_sender) {
 			gchar *tmp, *str;



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]