remove gtk_window_set_wmclass()
[claws.git] / src / sourcewindow.c
index bec50ce226018c217afebf182d87c29483ce4cc0..4c8b1c6285694a7760ee9d7bd277dc97f464d534 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2001 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2003 Hiroyuki Yamamoto
  *
  * 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
 #include "gtkutils.h"
 #include "prefs_common.h"
 
+static void source_window_size_alloc_cb        (GtkWidget      *widget,
+                                        GtkAllocation  *allocation);
 static void source_window_destroy_cb   (GtkWidget      *widget,
                                         SourceWindow   *sourcewin);
-static void key_pressed                        (GtkWidget      *widget,
+static gboolean key_pressed            (GtkWidget      *widget,
                                         GdkEventKey    *event,
                                         SourceWindow   *sourcewin);
 
-static GdkFont *msgfont = NULL;
-
 static void source_window_init()
 {
-       if (!msgfont && prefs_common.textfont)
-               msgfont = gtkut_font_load(prefs_common.textfont);
 }
 
 SourceWindow *source_window_create(void)
@@ -56,20 +54,24 @@ SourceWindow *source_window_create(void)
        GtkWidget *window;
        GtkWidget *scrolledwin;
        GtkWidget *text;
+       static PangoFontDescription *font_desc = NULL;
 
        debug_print("Creating source window...\n");
        sourcewin = g_new0(SourceWindow, 1);
 
        window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
        gtk_window_set_title(GTK_WINDOW(window), _("Source of the message"));
-       gtk_window_set_wmclass(GTK_WINDOW(window), "source_window", "Sylpheed");
-       gtk_window_set_policy(GTK_WINDOW(window), TRUE, TRUE, FALSE);
-       gtk_widget_set_usize(window, 600, 500);
-       gtk_signal_connect(GTK_OBJECT(window), "destroy",
-                          GTK_SIGNAL_FUNC(source_window_destroy_cb),
-                          sourcewin);
-       gtk_signal_connect(GTK_OBJECT(window), "key_press_event",
-                          GTK_SIGNAL_FUNC(key_pressed), sourcewin);
+       gtk_window_set_resizable(GTK_WINDOW(window), TRUE);
+       gtk_widget_set_size_request(window, prefs_common.sourcewin_width,
+                                   prefs_common.sourcewin_height);
+       g_signal_connect(G_OBJECT(window), "size_allocate",
+                        G_CALLBACK(source_window_size_alloc_cb),
+                        sourcewin);
+       g_signal_connect(G_OBJECT(window), "destroy",
+                        G_CALLBACK(source_window_destroy_cb),
+                        sourcewin);
+       g_signal_connect(G_OBJECT(window), "key_press_event",
+                        G_CALLBACK(key_pressed), sourcewin);
        gtk_widget_realize(window);
 
        scrolledwin = gtk_scrolled_window_new(NULL, NULL);
@@ -78,10 +80,13 @@ SourceWindow *source_window_create(void)
        gtk_container_add(GTK_CONTAINER(window), scrolledwin);
        gtk_widget_show(scrolledwin);
 
-       text = gtk_text_new(gtk_scrolled_window_get_hadjustment
-                           (GTK_SCROLLED_WINDOW(scrolledwin)),
-                           gtk_scrolled_window_get_vadjustment
-                           (GTK_SCROLLED_WINDOW(scrolledwin)));
+       text = gtk_text_view_new();
+       gtk_text_view_set_editable(GTK_TEXT_VIEW(text), FALSE);
+       if (!font_desc && prefs_common.textfont)
+               font_desc = pango_font_description_from_string
+                                       (prefs_common.textfont);
+       if (font_desc)
+               gtk_widget_modify_font(text, font_desc);
        gtk_container_add(GTK_CONTAINER(scrolledwin), text);
        gtk_widget_show(text);
 
@@ -129,20 +134,47 @@ void source_window_show_msg(SourceWindow *sourcewin, MsgInfo *msginfo)
        g_free(title);
        g_free(file);
 
-       gtk_text_freeze(GTK_TEXT(sourcewin->text));
-
        while (fgets(buf, sizeof(buf), fp) != NULL)
                source_window_append(sourcewin, buf);
 
-       gtk_text_thaw(GTK_TEXT(sourcewin->text));
-
        fclose(fp);
 }
 
 void source_window_append(SourceWindow *sourcewin, const gchar *str)
 {
-       gtk_text_insert(GTK_TEXT(sourcewin->text), msgfont, NULL, NULL,
-                       str, -1);
+       GtkTextView *text = GTK_TEXT_VIEW(sourcewin->text);
+       GtkTextBuffer *buffer = gtk_text_view_get_buffer(text);
+       GtkTextIter iter;
+       gchar *out;
+       gint len;
+
+       len = strlen(str) + 1;
+       Xalloca(out, len, return);
+       
+       conv_localetodisp(out, len, str);
+       if (!g_utf8_validate(out, -1, NULL)) {
+               gchar *buf;
+               gint buflen;
+               const gchar *src_codeset, *dest_codeset;
+               src_codeset = conv_get_current_charset_str();
+               dest_codeset = CS_UTF_8;
+               buf = conv_codeset_strdup(out, src_codeset, dest_codeset);
+               gtk_text_buffer_get_iter_at_offset(buffer, &iter, -1);
+               gtk_text_buffer_insert(buffer, &iter, buf, -1);
+               g_free(buf);
+       } else {
+               gtk_text_buffer_get_iter_at_offset(buffer, &iter, -1);
+               gtk_text_buffer_insert(buffer, &iter, out, -1);
+       }
+}
+
+static void source_window_size_alloc_cb(GtkWidget *widget,
+                                       GtkAllocation *allocation)
+{
+       g_return_if_fail(allocation != NULL);
+
+       prefs_common.sourcewin_width  = allocation->width;
+       prefs_common.sourcewin_height = allocation->height;
 }
 
 static void source_window_destroy_cb(GtkWidget *widget,
@@ -151,9 +183,27 @@ static void source_window_destroy_cb(GtkWidget *widget,
        source_window_destroy(sourcewin);
 }
 
-static void key_pressed(GtkWidget *widget, GdkEventKey *event,
-                       SourceWindow *sourcewin)
+static gboolean key_pressed(GtkWidget *widget, GdkEventKey *event,
+                           SourceWindow *sourcewin)
 {
-       if (event && event->keyval == GDK_Escape)
+
+       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:
+               if ((event->state & GDK_CONTROL_MASK) != 0)
+                       gtk_widget_destroy(sourcewin->window);
+               break;
+       case GDK_Escape:
                gtk_widget_destroy(sourcewin->window);
+               break;
+       }
+
+       return FALSE;
 }