aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog9
-rw-r--r--mail/em-event.c19
-rw-r--r--mail/em-event.h19
-rw-r--r--mail/mail-send-recv.c12
4 files changed, 57 insertions, 2 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index 26cdbdeacd..37ecdd21f0 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,12 @@
+2007-07-04 Srinivasa Ragavan <sragavan@novell.com>
+
+ ** Added the hook for plugging into Send/Receive dialog for the
+ Evolution RSS plugin.
+
+ * em-event.c: (em_event_target_new_send_receive):
+ * em-event.h:
+ * mail-send-recv.c: (build_dialog), (mail_send_receive):
+
2007-07-03 simon.zheng <simon.zheng@sun.com>
** Fix for bug #453294
diff --git a/mail/em-event.c b/mail/em-event.c
index b139302a3d..eed4e32ebb 100644
--- a/mail/em-event.c
+++ b/mail/em-event.c
@@ -176,6 +176,19 @@ em_event_target_new_message(EMEvent *eme, CamelFolder *folder, CamelMimeMessage
return t;
}
+EMEventTargetSendReceive *
+em_event_target_new_send_receive(EMEvent *eme, GtkWidget *table, gpointer *data, int row, guint32 flags)
+{
+ EMEventTargetSendReceive *t = e_event_target_new(&eme->popup, EM_EVENT_TARGET_SEND_RECEIVE, sizeof(*t));
+
+ t->table = table;
+ t->data = data;
+ t->row = row;
+ t->target.mask = ~flags;
+
+ return t;
+}
+
/* ********************************************************************** */
static void *emeh_parent_class;
@@ -197,10 +210,16 @@ static const EEventHookTargetMask emeh_message_masks[] = {
{ 0 }
};
+static const EEventHookTargetMask emeh_send_receive_masks[] = {
+ { "sendreceive", EM_EVENT_SEND_RECEIVE },
+ { 0 }
+};
+
static const EEventHookTargetMap emeh_targets[] = {
{ "folder", EM_EVENT_TARGET_FOLDER, emeh_folder_masks },
{ "message", EM_EVENT_TARGET_MESSAGE, emeh_message_masks },
{ "composer", EM_EVENT_TARGET_COMPOSER, emeh_composer_masks},
+ { "sendreceive", EM_EVENT_TARGET_SEND_RECEIVE, emeh_send_receive_masks},
{ 0 }
};
diff --git a/mail/em-event.h b/mail/em-event.h
index 90bb23dca4..7ad3f693a9 100644
--- a/mail/em-event.h
+++ b/mail/em-event.h
@@ -35,6 +35,7 @@ extern "C" {
struct _CamelFolder;
struct _CamelMimeMessage;
struct _EMsgComposer;
+struct _GtkWidget;
typedef struct _EMEvent EMEvent;
typedef struct _EMEventClass EMEventClass;
@@ -44,6 +45,7 @@ enum _em_event_target_t {
EM_EVENT_TARGET_FOLDER,
EM_EVENT_TARGET_MESSAGE,
EM_EVENT_TARGET_COMPOSER,
+ EM_EVENT_TARGET_SEND_RECEIVE,
};
/* Flags that describe TARGET_FOLDER */
@@ -61,6 +63,11 @@ enum {
EM_EVENT_COMPOSER_SEND_OPTION = 1<< 0,
};
+/* Flags that describe TARGET_SEND_RECEIVE*/
+enum {
+ EM_EVENT_SEND_RECEIVE = 1<< 0,
+};
+
typedef struct _EMEventTargetFolder EMEventTargetFolder;
struct _EMEventTargetFolder {
@@ -87,6 +94,17 @@ struct _EMEventTargetComposer {
struct _EMsgComposer *composer;
};
+typedef struct _EMEventTargetSendReceive EMEventTargetSendReceive;
+
+struct _EMEventTargetSendReceive {
+ EEventTarget target;
+
+ struct _GtkWidget *table;
+ gpointer *data;
+ int row;
+};
+
+
typedef struct _EEventItem EMEventItem;
/* The object */
@@ -107,6 +125,7 @@ EMEvent *em_event_peek(void);
EMEventTargetFolder *em_event_target_new_folder(EMEvent *emp, const char *uri, guint32 flags);
EMEventTargetComposer *em_event_target_new_composer(EMEvent *emp, const struct _EMsgComposer *composer, guint32 flags);
EMEventTargetMessage *em_event_target_new_message(EMEvent *emp, struct _CamelFolder *folder, struct _CamelMimeMessage *message, const char *uid, guint32 flags);
+EMEventTargetSendReceive * em_event_target_new_send_receive(EMEvent *eme, struct _GtkWidget *table, gpointer *data, int row, guint32 flags);
/* ********************************************************************** */
diff --git a/mail/mail-send-recv.c b/mail/mail-send-recv.c
index dbaee11c61..c7fa00655f 100644
--- a/mail/mail-send-recv.c
+++ b/mail/mail-send-recv.c
@@ -56,6 +56,7 @@
#include "mail-ops.h"
#include "mail-send-recv.h"
#include "mail-folder-cache.h"
+#include "em-event.h"
#include <e-util/e-icon-factory.h>
#define d(x)
@@ -381,7 +382,8 @@ build_dialog (EAccountList *accounts, CamelFolder *outbox, const char *destinati
EAccount *account;
EIterator *iter;
GList *icon_list;
-
+ EMEventTargetSendReceive *target;
+
gd = (GtkDialog *)(send_recv_dialog = gtk_dialog_new_with_buttons(_("Send & Receive Mail"), NULL, GTK_DIALOG_NO_SEPARATOR, NULL));
gtk_window_set_modal ((GtkWindow *) gd, FALSE);
@@ -535,6 +537,10 @@ build_dialog (EAccountList *accounts, CamelFolder *outbox, const char *destinati
g_object_unref (iter);
+ /* Hook: If some one wants to hook on to the sendreceive dialog, this is the way to go. */
+ target = em_event_target_new_send_receive (em_event_peek(), table, data, row, EM_EVENT_SEND_RECEIVE);
+ e_event_emit (em_event_peek(), "mail.sendreceive", target);
+
if (outbox && destination) {
info = g_hash_table_lookup (data->active, SEND_URI_KEY);
if (info == NULL) {
@@ -936,7 +942,9 @@ mail_send_receive (void)
mail_get_store(info->uri, info->cancel, receive_update_got_store, info);
break;
default:
- g_assert_not_reached ();
+ /* Commented for pluggable hooks*/
+ /* g_assert_not_reached () */
+ break;
}
scan = scan->next;
}