/* * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) version 3. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with the program; if not, see * * * Authors: * Michael Zucchi * * Copyright (C) 1999-2008 Novell, Inc. (www.novell.com) * */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include "em-event.h" #include "composer/e-msg-composer.h" static EMEvent *em_event; G_DEFINE_TYPE (EMEvent, em_event, E_TYPE_EVENT) static void eme_target_free (EEvent *ep, EEventTarget *t) { switch (t->type) { case EM_EVENT_TARGET_FOLDER: { EMEventTargetFolder *s = (EMEventTargetFolder *) t; if (s->store != NULL) g_object_unref (s->store); g_free (s->folder_name); g_free (s->display_name); g_free (s->msg_uid); g_free (s->msg_sender); g_free (s->msg_subject); break; } case EM_EVENT_TARGET_MESSAGE: { EMEventTargetMessage *s = (EMEventTargetMessage *) t; if (s->folder) g_object_unref (s->folder); if (s->message) g_object_unref (s->message); g_free (s->uid); if (s->composer) g_object_unref (s->composer); break; } case EM_EVENT_TARGET_COMPOSER : { EMEventTargetComposer *s = (EMEventTargetComposer *) t; if (s->composer) g_object_unref (s->composer); break; } } /* Chain up to parent's target_free() method. */ E_EVENT_CLASS (em_event_parent_class)->target_free (ep, t); } static void em_event_class_init (EMEventClass *class) { EEventClass *event_class; event_class = E_EVENT_CLASS (class); event_class->target_free = eme_target_free; } static void em_event_init (EMEvent *event) { } /** * em_event_peek: * @void: * * Get the singular instance of the mail event handler. * * Return value: **/ EMEvent * em_event_peek (void) { if (em_event == NULL) { em_event = g_object_new (EM_TYPE_EVENT, NULL); e_event_construct ( &em_event->popup, "org.gnome.evolution.mail.events"); } return em_event; } EMEventTargetFolder * em_event_target_new_folder (EMEvent *eme, CamelStore *store, const gchar *folder_name, guint new, const gchar *msg_uid, const gchar *msg_sender, const gchar *msg_subject) { EMEventTargetFolder *t; guint32 flags = new ? EM_EVENT_FOLDER_NEWMAIL : 0; g_return_val_if_fail (CAMEL_IS_STORE (store), NULL); g_return_val_if_fail (folder_name != NULL, NULL); t = e_event_target_new ( &eme->popup, EM_EVENT_TARGET_FOLDER, sizeof (*t)); t->store = g_object_ref (store); t->folder_name = g_strdup (folder_name); t->target.mask = ~flags; t->new = new; t->msg_uid = g_strdup (msg_uid); t->msg_sender = g_strdup (msg_sender); t->msg_subject = g_strdup (msg_subject); return t; } EMEventTargetComposer * em_event_target_new_composer (EMEvent *eme, EMsgComposer *composer, guint32 flags) { EMEventTargetComposer *t; t = e_event_target_new ( &eme->popup, EM_EVENT_TARGET_COMPOSER, sizeof (*t)); t->composer = g_object_ref (composer); t->target.mask = ~flags; return t; } EMEventTargetMessage * em_event_target_new_message (EMEvent *eme, CamelFolder *folder, CamelMimeMessage *message, const gchar *uid, guint32 flags, EMsgComposer *composer) { EMEventTargetMessage *t; t = e_event_target_new ( &eme->popup, EM_EVENT_TARGET_MESSAGE, sizeof (*t)); t->uid = g_strdup (uid); t->folder = folder; if (folder) g_object_ref (folder); t->message = message; if (message) g_object_ref (message); t->target.mask = ~flags; if (composer) t->composer = g_object_ref (G_OBJECT (composer)); return t; } EMEventTargetSendReceive * em_event_target_new_send_receive (EMEvent *eme, GtkWidget *grid, gpointer data, gint row, guint32 flags) { EMEventTargetSendReceive *t; t = e_event_target_new ( &eme->popup, EM_EVENT_TARGET_SEND_RECEIVE, sizeof (*t)); t->grid = grid; t->data = data; t->row = row; t->target.mask = ~flags; return t; } EMEventTargetCustomIcon * em_event_target_new_custom_icon (EMEvent *eme, GtkTreeStore *store, GtkTreeIter *iter, const gchar *folder_name, guint32 flags) { EMEventTargetCustomIcon *t; t = e_event_target_new ( &eme->popup, EM_EVENT_TARGET_CUSTOM_ICON, sizeof (*t)); t->store = store; t->iter = iter; t->folder_name = folder_name; t->target.mask = ~flags; return t; }