2009-10-03 [colin] 3.7.2cvs42
[claws.git] / src / noticeview.c
index 1e127fe29a544d7f50e3da00fd04130e5274d7bc..907bdc67e1996a4ff9234a34a440c2f0c677d02e 100644 (file)
@@ -1,10 +1,10 @@
 /* 
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 2002 Hiroyuki Yamamoto & The Sylpheed Claws Team
+ * Copyright (C) 2002 Hiroyuki Yamamoto & 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,
@@ -13,8 +13,8 @@
  * 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/>.
+ * 
  */
 
 #ifdef HAVE_CONFIG_H
 
 #include <glib.h>
 #include <glib/gi18n.h>
-#include <gtk/gtkwidget.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtkvbox.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkpixmap.h>
+#include <gtk/gtk.h>
 #include <stdio.h>
 #include <string.h>
 #include <time.h>
@@ -52,9 +48,6 @@ static gboolean noticeview_icon_pressed       (GtkWidget *widget, GdkEventButton *evt,
 static gboolean noticeview_visi_notify(GtkWidget *widget,
                                       GdkEventVisibility *event,
                                       NoticeView *noticeview);
-static gboolean noticeview_motion_notify(GtkWidget *widget,
-                                      GdkEventMotion *event,
-                                      NoticeView *noticeview);
 static gboolean noticeview_leave_notify(GtkWidget *widget,
                                      GdkEventCrossing *event,
                                      NoticeView *textview);
@@ -75,7 +68,7 @@ NoticeView *noticeview_create(MainWindow *mainwin)
        GtkWidget  *widget;
        GtkWidget  *widget2;
        GtkWidget  *evtbox;
-       GtkTooltips *tooltips;
+       CLAWS_TIP_DECL();
 
        debug_print("Creating notice view...\n");
        noticeview = g_new0(NoticeView, 1);
@@ -104,8 +97,6 @@ NoticeView *noticeview_create(MainWindow *mainwin)
        g_signal_connect(G_OBJECT(evtbox), "button-press-event", 
                         G_CALLBACK(noticeview_icon_pressed),
                         (gpointer) noticeview);
-       g_signal_connect(G_OBJECT(evtbox), "visibility-notify-event",
-                        G_CALLBACK(noticeview_visi_notify), noticeview);
        g_signal_connect(G_OBJECT(evtbox), "motion-notify-event",
                         G_CALLBACK(noticeview_visi_notify), noticeview);
        g_signal_connect(G_OBJECT(evtbox), "leave-notify-event",
@@ -121,21 +112,17 @@ NoticeView *noticeview_create(MainWindow *mainwin)
        gtk_box_pack_start(GTK_BOX(hbox), text, FALSE, FALSE, 0);
 
        widget = gtk_button_new_with_label("");
-       gtk_widget_set_size_request(widget, 120, -1);
        g_signal_connect(G_OBJECT(widget), "clicked", 
                         G_CALLBACK(noticeview_button_pressed),
                         (gpointer) noticeview);
        gtk_box_pack_start(GTK_BOX(hbox), widget, FALSE, FALSE, 4);
        
        widget2 = gtk_button_new_with_label("");
-       gtk_widget_set_size_request(widget2, 120, -1);
        g_signal_connect(G_OBJECT(widget2), "clicked", 
                         G_CALLBACK(noticeview_2ndbutton_pressed),
                         (gpointer) noticeview);
        gtk_box_pack_start(GTK_BOX(hbox), widget2, FALSE, FALSE, 0);
        
-       tooltips = gtk_tooltips_new();
-       
        noticeview->vbox   = vbox;
        noticeview->hsep   = hsep;
        noticeview->hbox   = hbox;
@@ -145,8 +132,9 @@ NoticeView *noticeview_create(MainWindow *mainwin)
        noticeview->button2= widget2;
        noticeview->evtbox = evtbox;
        noticeview->visible= TRUE;
-       noticeview->tooltips = tooltips;
-
+#if !(GTK_CHECK_VERSION(2,12,0))
+       noticeview->tooltips = tips;
+#endif
        return noticeview;
 }
 
@@ -170,7 +158,7 @@ void noticeview_show(NoticeView *noticeview)
 
 void noticeview_hide(NoticeView *noticeview)
 {
-       if (noticeview->visible) {
+       if (noticeview && noticeview->visible) {
                gtk_widget_hide(GTK_WIDGET_PTR(noticeview));
                noticeview->visible = FALSE;
        }       
@@ -178,17 +166,17 @@ void noticeview_hide(NoticeView *noticeview)
 
 void noticeview_set_text(NoticeView *noticeview, const char *text)
 {
-       g_return_if_fail(noticeview);
+       cm_return_if_fail(noticeview);
        gtk_label_set_text(GTK_LABEL(noticeview->text), text);
 }
 
 void noticeview_set_button_text(NoticeView *noticeview, const char *text)
 {
-       g_return_if_fail(noticeview);
+       cm_return_if_fail(noticeview);
 
        if (text != NULL) {
                gtk_label_set_text
-                       (GTK_LABEL(GTK_BIN(noticeview->button)->child), text);
+                       (GTK_LABEL(gtk_bin_get_child(GTK_BIN((noticeview->button)))), text);
                gtk_widget_show(noticeview->button);
        } else
                gtk_widget_hide(noticeview->button);
@@ -201,7 +189,7 @@ void noticeview_set_button_text(NoticeView *noticeview, const char *text)
 }
 
 void noticeview_set_button_press_callback(NoticeView   *noticeview,
-                                         GtkSignalFunc  callback,
+                                         void          (*callback)(void),
                                          gpointer      *user_data)
 {
        noticeview->press     = (void (*) (NoticeView *, gpointer)) callback;
@@ -233,15 +221,6 @@ static gboolean noticeview_visi_notify(GtkWidget *widget,
        return FALSE;
 }
 
-static gboolean noticeview_motion_notify(GtkWidget *widget,
-                                      GdkEventMotion *event,
-                                      NoticeView *noticeview)
-{
-       if (noticeview->icon_clickable)
-               gdk_window_set_cursor(noticeview->evtbox->window, hand_cursor);
-       return FALSE;
-}
-
 static gboolean noticeview_leave_notify(GtkWidget *widget,
                                      GdkEventCrossing *event,
                                      NoticeView *noticeview)
@@ -261,18 +240,18 @@ static gboolean noticeview_enter_notify(GtkWidget *widget,
 
 void noticeview_set_2ndbutton_text(NoticeView *noticeview, const char *text)
 {
-       g_return_if_fail(noticeview);
+       cm_return_if_fail(noticeview);
 
        if (text != NULL) {
                gtk_label_set_text
-                       (GTK_LABEL(GTK_BIN(noticeview->button2)->child), text);
+                       (GTK_LABEL(gtk_bin_get_child(GTK_BIN((noticeview->button2)))), text);
                gtk_widget_show(noticeview->button2);
        } else
                gtk_widget_hide(noticeview->button2);
 }
 
 void noticeview_set_2ndbutton_press_callback(NoticeView        *noticeview,
-                                         GtkSignalFunc  callback,
+                                         void          (*callback)(void),
                                          gpointer      *user_data)
 {
        noticeview->press2     = (void (*) (NoticeView *, gpointer)) callback;
@@ -288,13 +267,12 @@ static void noticeview_2ndbutton_pressed(GtkButton *button, NoticeView *noticevi
 
 void noticeview_set_icon(NoticeView *noticeview, StockPixmap icon)
 {
-       GdkPixmap *pixmap;
-       GdkBitmap *bitmap;
+       GdkPixbuf *pixbuf;
        
-       if (stock_pixmap_gdk(noticeview->window, icon, &pixmap, &bitmap) < 0)
+       if (stock_pixbuf_gdk(noticeview->window, icon, &pixbuf) < 0)
                return;
        
-       gtk_image_set_from_pixmap(GTK_IMAGE(noticeview->icon), pixmap, bitmap);
+       gtk_image_set_from_pixbuf(GTK_IMAGE(noticeview->icon), pixbuf);
 }
 
 void noticeview_set_icon_clickable(NoticeView *noticeview, gboolean setting)
@@ -304,9 +282,10 @@ void noticeview_set_icon_clickable(NoticeView *noticeview, gboolean setting)
 
 void noticeview_set_tooltip (NoticeView *noticeview, const gchar *text)
 {
-       gtk_tooltips_set_tip(GTK_TOOLTIPS(noticeview->tooltips), 
-                       noticeview->evtbox,
-                       text,
-                       NULL);
+#if !(GTK_CHECK_VERSION(2,12,0))
+       GtkTooltips *tips = noticeview->tooltips;
+#endif
+       CLAWS_SET_TIP(noticeview->evtbox,
+                       text);
 
 }