aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog12
-rw-r--r--lib/widgets/Makefile.am2
-rw-r--r--lib/widgets/ephy-event-box.c221
-rw-r--r--lib/widgets/ephy-event-box.h64
-rw-r--r--src/ephy-favicon-action.c5
-rw-r--r--src/ephy-notebook.c16
-rwxr-xr-xsrc/statusbar.c2
7 files changed, 30 insertions, 292 deletions
diff --git a/ChangeLog b/ChangeLog
index 4160da1fb..5186b0df7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,15 @@
+2003-09-09 Christian Persch <chpe@cvs.gnome.org>
+
+ * lib/widgets/Makefile.am:
+ * lib/widgets/ephy-event-box.c:
+ * lib/widgets/ephy-event-box.h:
+ * src/ephy-favicon-action.c: (create_tool_item):
+ * src/ephy-notebook.c: (build_tab_label):
+ * src/statusbar.c: (create_statusbar_security_icon):
+
+ gtk+ now supports invisible event boxes. Remove our custom implementation
+ and use gtk+ api instead.
+
2003-09-08 Marco Pesenti Gritti <marco@gnome.org>
* po/POTFILES.in:
diff --git a/lib/widgets/Makefile.am b/lib/widgets/Makefile.am
index b7e1bdc23..e89a98023 100644
--- a/lib/widgets/Makefile.am
+++ b/lib/widgets/Makefile.am
@@ -19,8 +19,6 @@ libephywidgets_la_SOURCES = \
ephy-autocompletion-window.h \
ephy-ellipsizing-label.c \
ephy-ellipsizing-label.h \
- ephy-event-box.c \
- ephy-event-box.h \
ephy-location-entry.c \
ephy-location-entry.h \
ephy-node-view.c \
diff --git a/lib/widgets/ephy-event-box.c b/lib/widgets/ephy-event-box.c
deleted file mode 100644
index c616ce236..000000000
--- a/lib/widgets/ephy-event-box.c
+++ /dev/null
@@ -1,221 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library 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) any later version.
- *
- * This library 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 this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#include "ephy-event-box.h"
-
-
-static void ephy_event_box_class_init (EphyEventBoxClass *klass);
-static void ephy_event_box_init (EphyEventBox *event_box);
-static void ephy_event_box_realize (GtkWidget *widget);
-static void ephy_event_box_unrealize (GtkWidget *widget);
-static void ephy_event_box_size_request (GtkWidget *widget,
- GtkRequisition *requisition);
-static void ephy_event_box_size_allocate (GtkWidget *widget,
- GtkAllocation *allocation);
-static void ephy_event_box_map (GtkWidget *widget);
-static void ephy_event_box_unmap (GtkWidget *widget);
-
-static GtkBinClass *parent_class = NULL;
-
-GType
-ephy_event_box_get_type (void)
-{
- static GType event_box_type = 0;
-
- if (!event_box_type)
- {
- static const GTypeInfo event_box_info =
- {
- sizeof (EphyEventBoxClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) ephy_event_box_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (EphyEventBox),
- 0, /* n_preallocs */
- (GInstanceInitFunc) ephy_event_box_init,
- };
-
- event_box_type = g_type_register_static (GTK_TYPE_BIN, "EphyEventBox",
- &event_box_info, 0);
- }
-
- return event_box_type;
-}
-
-
-static void
-ephy_event_box_class_init (EphyEventBoxClass *class)
-{
- GtkWidgetClass *widget_class;
-
- parent_class = g_type_class_peek_parent (class);
-
- widget_class = (GtkWidgetClass*) class;
-
- widget_class->realize = ephy_event_box_realize;
- widget_class->unrealize = ephy_event_box_unrealize;
- widget_class->map = ephy_event_box_map;
- widget_class->unmap = ephy_event_box_unmap;
- widget_class->size_request = ephy_event_box_size_request;
- widget_class->size_allocate = ephy_event_box_size_allocate;
-}
-
-static void
-ephy_event_box_init (EphyEventBox *event_box)
-{
- GTK_WIDGET_SET_FLAGS (event_box, GTK_NO_WINDOW);
-}
-
-GtkWidget*
-ephy_event_box_new (void)
-{
- return g_object_new (EPHY_TYPE_EVENT_BOX, NULL);
-}
-
-static void
-ephy_event_box_map (GtkWidget *widget)
-{
- EphyEventBox *event_box;
-
- event_box = EPHY_EVENT_BOX (widget);
-
- (* GTK_WIDGET_CLASS (parent_class)->map) (widget);
-
- gdk_window_show (event_box->input_window);
-}
-
-static void
-ephy_event_box_unmap (GtkWidget *widget)
-{
- EphyEventBox *event_box;
-
- event_box = EPHY_EVENT_BOX (widget);
-
- gdk_window_hide (event_box->input_window);
-
- (* GTK_WIDGET_CLASS (parent_class)->unmap) (widget);
-}
-
-static void
-ephy_event_box_realize (GtkWidget *widget)
-{
- GdkWindowAttr attributes;
- EphyEventBox *event_box;
- gint attributes_mask;
- gint border_width;
-
- (* GTK_WIDGET_CLASS (parent_class)->realize) (widget);
-
- event_box = EPHY_EVENT_BOX (widget);
-
- border_width = GTK_CONTAINER (widget)->border_width;
-
- attributes.x = widget->allocation.x + border_width;
- attributes.y = widget->allocation.y + border_width;
- attributes.width = widget->allocation.width - 2*border_width;
- attributes.height = widget->allocation.height - 2*border_width;
- attributes.window_type = GDK_WINDOW_CHILD;
- //attributes.override_redirect = TRUE;
- attributes.wclass = GDK_INPUT_ONLY;
- attributes.event_mask = gtk_widget_get_events (widget)
- | GDK_BUTTON_MOTION_MASK
- | GDK_BUTTON_PRESS_MASK
- | GDK_BUTTON_RELEASE_MASK
- | GDK_ENTER_NOTIFY_MASK
- | GDK_LEAVE_NOTIFY_MASK;
-
- attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_NOREDIR;
-
- event_box->input_window = gdk_window_new (widget->window,
- &attributes, attributes_mask);
- gdk_window_set_user_data (event_box->input_window, widget);
-}
-
-static void
-ephy_event_box_unrealize (GtkWidget *widget)
-{
- EphyEventBox *event_box;
-
- (* GTK_WIDGET_CLASS (parent_class)->unrealize) (widget);
-
- event_box = EPHY_EVENT_BOX (widget);
-
- gdk_window_set_user_data (event_box->input_window, NULL);
- gdk_window_destroy (event_box->input_window);
- event_box->input_window = NULL;
-}
-
-static void
-ephy_event_box_size_request (GtkWidget *widget,
- GtkRequisition *requisition)
-{
- GtkBin *bin = GTK_BIN (widget);
-
- requisition->width = GTK_CONTAINER (widget)->border_width * 2;
- requisition->height = GTK_CONTAINER (widget)->border_width * 2;
-
- if (bin->child && GTK_WIDGET_VISIBLE (bin->child))
- {
- GtkRequisition child_requisition;
-
- gtk_widget_size_request (bin->child, &child_requisition);
-
- requisition->width += child_requisition.width;
- requisition->height += child_requisition.height;
- }
-}
-
-static void
-ephy_event_box_size_allocate (GtkWidget *widget,
- GtkAllocation *allocation)
-{
- GtkBin *bin;
- GtkAllocation child_allocation;
- EphyEventBox *event_box;
-
- widget->allocation = *allocation;
- bin = GTK_BIN (widget);
-
- child_allocation.x = allocation->x + GTK_CONTAINER (widget)->border_width;
- child_allocation.y = allocation->y + GTK_CONTAINER (widget)->border_width;
- child_allocation.width = MAX (allocation->width - GTK_CONTAINER (widget)->border_width * 2, 0);
- child_allocation.height = MAX (allocation->height - GTK_CONTAINER (widget)->border_width * 2, 0);
-
- if (GTK_WIDGET_REALIZED (widget))
- {
- event_box = EPHY_EVENT_BOX (widget);
- gdk_window_move_resize (event_box->input_window,
- child_allocation.x,
- child_allocation.y,
- child_allocation.width,
- child_allocation.height);
- }
-
- if (bin->child)
- gtk_widget_size_allocate (bin->child, &child_allocation);
-}
diff --git a/lib/widgets/ephy-event-box.h b/lib/widgets/ephy-event-box.h
deleted file mode 100644
index d1f0f267a..000000000
--- a/lib/widgets/ephy-event-box.h
+++ /dev/null
@@ -1,64 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library 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) any later version.
- *
- * This library 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 this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-
-#ifndef EPHY_EVENT_BOX_H
-#define EPHY_EVENT_BOX_H
-
-#include <glib.h>
-#include <gdk/gdk.h>
-#include <gtk/gtkbin.h>
-
-G_BEGIN_DECLS
-
-#define EPHY_TYPE_EVENT_BOX (ephy_event_box_get_type ())
-#define EPHY_EVENT_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_EVENT_BOX, EphyEventBox))
-#define EPHY_EVENT_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_EVENT_BOX, EphyEventBoxClass))
-#define EPHY_IS_EVENT_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_EVENT_BOX))
-#define EPHY_IS_EVENT_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), EPHY_TYPE_EVENT_BOX))
-#define EPHY_EVENT_BOX_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), EPHY_TYPE_EVENT_BOX, EphyEventBoxClass))
-
-
-typedef struct _EphyEventBox EphyEventBox;
-typedef struct _EphyEventBoxClass EphyEventBoxClass;
-
-struct _EphyEventBox
-{
- GtkBin bin;
- GdkWindow *input_window;
-};
-
-struct _EphyEventBoxClass
-{
- GtkBinClass parent_class;
-};
-
-GType ephy_event_box_get_type (void) G_GNUC_CONST;
-
-GtkWidget *ephy_event_box_new (void);
-
-G_END_DECLS
-
-#endif /* EPHY_EVENT_BOX_H */
diff --git a/src/ephy-favicon-action.c b/src/ephy-favicon-action.c
index 4b8b290fb..1e575fd77 100644
--- a/src/ephy-favicon-action.c
+++ b/src/ephy-favicon-action.c
@@ -24,12 +24,12 @@
#include "ephy-dnd.h"
#include "ephy-favicon-cache.h"
#include "ephy-shell.h"
-#include "ephy-event-box.h"
#include "ephy-debug.h"
#include <gtk/gtktoolitem.h>
#include <gtk/gtkimage.h>
#include <gtk/gtkstock.h>
+#include <gtk/gtkeventbox.h>
static GtkTargetEntry url_drag_types [] =
{
@@ -136,7 +136,8 @@ create_tool_item (GtkAction *action)
item = GTK_WIDGET (gtk_tool_item_new ());
- ebox = ephy_event_box_new ();
+ ebox = gtk_event_box_new ();
+ gtk_event_box_set_visible_window (GTK_EVENT_BOX (ebox), FALSE);
image = gtk_image_new ();
gtk_container_add (GTK_CONTAINER (ebox), image);
gtk_container_set_border_width (GTK_CONTAINER (ebox), 2);
diff --git a/src/ephy-notebook.c b/src/ephy-notebook.c
index 620b81d68..1ca616eed 100644
--- a/src/ephy-notebook.c
+++ b/src/ephy-notebook.c
@@ -34,10 +34,19 @@
#include "ephy-shell.h"
#include "ephy-debug.h"
#include "ephy-favicon-cache.h"
-#include "ephy-event-box.h"
-#include <gtk/gtk.h>
#include <glib-object.h>
+#include <gtk/gtkeventbox.h>
+#include <gtk/gtknotebook.h>
+#include <gtk/gtkhbox.h>
+#include <gtk/gtklabel.h>
+#include <gtk/gtkwidget.h>
+#include <gtk/gtktooltips.h>
+#include <gtk/gtkmain.h>
+#include <gtk/gtkstock.h>
+#include <gtk/gtkimage.h>
+#include <gtk/gtkbutton.h>
+#include <gtk/gtkiconfactory.h>
#include <bonobo/bonobo-i18n.h>
#include <libgnomevfs/gnome-vfs-uri.h>
@@ -907,7 +916,8 @@ build_tab_label (EphyNotebook *nb, GtkWidget *child)
gtk_box_pack_start (GTK_BOX (hbox), icon, FALSE, FALSE, 0);
/* setup label */
- label_ebox = ephy_event_box_new ();
+ label_ebox = gtk_event_box_new ();
+ gtk_event_box_set_visible_window (GTK_EVENT_BOX (label_ebox), FALSE);
label = gtk_label_new ("");
gtk_misc_set_alignment (GTK_MISC (label), 0.00, 0.5);
gtk_misc_set_padding (GTK_MISC (label), 4, 0);
diff --git a/src/statusbar.c b/src/statusbar.c
index ece07ece7..b2f299a16 100755
--- a/src/statusbar.c
+++ b/src/statusbar.c
@@ -98,6 +98,8 @@ create_statusbar_security_icon (Statusbar *s)
s->priv->security_icon = gtk_image_new ();
s->priv->security_evbox = gtk_event_box_new ();
+ gtk_event_box_set_visible_window (GTK_EVENT_BOX (s->priv->security_evbox),
+ FALSE);
gtk_container_add (GTK_CONTAINER (security_frame),
GTK_WIDGET (s->priv->security_evbox));
gtk_container_add (GTK_CONTAINER (s->priv->security_evbox),