/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2005 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2012 Hiroyuki Yamamoto and the Claws Mail team
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
+ * the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
*/
#include "defs.h"
#include <glib.h>
#include <glib/gi18n.h>
#include <gdk/gdkkeysyms.h>
-#include <gtk/gtkwidget.h>
-#include <gtk/gtkwindow.h>
-#include <gtk/gtksignal.h>
-#include <gtk/gtkscrolledwindow.h>
-#include <gtk/gtktext.h>
-#include <gtk/gtkstyle.h>
+#include <gtk/gtk.h>
#include <stdio.h>
#include <stdlib.h>
#include "utils.h"
#include "gtkutils.h"
#include "prefs_common.h"
+#include "file-utils.h"
static void source_window_size_alloc_cb (GtkWidget *widget,
GtkAllocation *allocation);
static gboolean key_pressed (GtkWidget *widget,
GdkEventKey *event,
SourceWindow *sourcewin);
+static void source_window_append (SourceWindow *sourcewin,
+ const gchar *str);
+static void source_window_destroy (SourceWindow *sourcewin);
static void source_window_init()
{
debug_print("Creating source window...\n");
sourcewin = g_new0(SourceWindow, 1);
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
+ window = gtkut_window_new(GTK_WINDOW_TOPLEVEL, "sourcewindow");
gtk_window_set_title(GTK_WINDOW(window), _("Source of the message"));
gtk_window_set_resizable(GTK_WINDOW(window), TRUE);
+ gtk_window_set_type_hint(GTK_WINDOW(window), GDK_WINDOW_TYPE_HINT_DIALOG);
gtk_widget_set_size_request(window, prefs_common.sourcewin_width,
prefs_common.sourcewin_height);
gtk_widget_show_all(sourcewin->window);
}
-void source_window_destroy(SourceWindow *sourcewin)
+static void source_window_destroy(SourceWindow *sourcewin)
{
+ if (sourcewin->updating) {
+ debug_print("deferring destroy\n");
+ sourcewin->deferred_destroy = TRUE;
+ return;
+ }
gtk_widget_destroy(sourcewin->window);
g_free(sourcewin);
}
FILE *fp;
gchar buf[BUFFSIZE];
- g_return_if_fail(msginfo != NULL);
+ cm_return_if_fail(msginfo != NULL);
+ sourcewin->updating = TRUE;
file = procmsg_get_message_file(msginfo);
- g_return_if_fail(file != NULL);
+ sourcewin->updating = FALSE;
+
+ if (sourcewin->deferred_destroy) {
+ g_free(file);
+ source_window_destroy(sourcewin);
+ return;
+ }
- if ((fp = g_fopen(file, "rb")) == NULL) {
- FILE_OP_ERROR(file, "fopen");
+ cm_return_if_fail(file != NULL);
+
+ if ((fp = claws_fopen(file, "rb")) == NULL) {
+ FILE_OP_ERROR(file, "claws_fopen");
g_free(file);
return;
}
g_free(title);
g_free(file);
- while (fgets(buf, sizeof(buf), fp) != NULL)
+ while (claws_fgets(buf, sizeof(buf), fp) != NULL)
source_window_append(sourcewin, buf);
- fclose(fp);
+ claws_fclose(fp);
}
-void source_window_append(SourceWindow *sourcewin, const gchar *str)
+static void source_window_append(SourceWindow *sourcewin, const gchar *str)
{
GtkTextView *text = GTK_TEXT_VIEW(sourcewin->text);
GtkTextBuffer *buffer = gtk_text_view_get_buffer(text);
static void source_window_size_alloc_cb(GtkWidget *widget,
GtkAllocation *allocation)
{
- g_return_if_fail(allocation != NULL);
+ cm_return_if_fail(allocation != NULL);
prefs_common.sourcewin_width = allocation->width;
prefs_common.sourcewin_height = allocation->height;
static gboolean key_pressed(GtkWidget *widget, GdkEventKey *event,
SourceWindow *sourcewin)
{
-
if (!event || !sourcewin) return FALSE;
-
+
switch (event->keyval) {
- case GDK_A:
- case GDK_a:
- if ((event->state & GDK_CONTROL_MASK) != 0)
- gtk_editable_select_region(GTK_EDITABLE(sourcewin->text), 0, -1);
- break;
- case GDK_W:
- case GDK_w:
+ case GDK_KEY_W:
+ case GDK_KEY_w:
if ((event->state & GDK_CONTROL_MASK) != 0)
gtk_widget_destroy(sourcewin->window);
break;
- case GDK_Escape:
+ case GDK_KEY_Escape:
source_window_destroy(sourcewin);
return TRUE;
break;