[gtk+/toplevel-embedding: 3/12] Slightly less special casing in GtkWindow for gtk_widget_is_toplevel()
- From: Tristan Van Berkom <tvb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/toplevel-embedding: 3/12] Slightly less special casing in GtkWindow for gtk_widget_is_toplevel()
- Date: Wed, 29 Dec 2010 09:16:44 +0000 (UTC)
commit 70796f84752f9d81b2215fecb9495894fd83edcf
Author: Tristan Van Berkom <tristan van berkom gmail com>
Date: Fri Dec 24 02:10:07 2010 +0900
Slightly less special casing in GtkWindow for gtk_widget_is_toplevel()
Also take care of setting the resize-mode at realize time depending
on toplevelness.
gtk/gtkwindow.c | 36 +++++++++---------------------------
1 files changed, 9 insertions(+), 27 deletions(-)
---
diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c
index 1474940..e960bd6 100644
--- a/gtk/gtkwindow.c
+++ b/gtk/gtkwindow.c
@@ -4866,6 +4866,8 @@ gtk_window_realize (GtkWidget *widget)
if (gtk_widget_get_parent_window (widget))
{
+ gtk_container_set_resize_mode (GTK_CONTAINER (widget), GTK_RESIZE_PARENT);
+
gtk_widget_set_realized (widget, TRUE);
attributes.x = allocation.x;
@@ -4893,6 +4895,8 @@ gtk_window_realize (GtkWidget *widget)
return;
}
+ gtk_container_set_resize_mode (GTK_CONTAINER (window), GTK_RESIZE_QUEUE);
+
/* ensure widget tree is properly size allocated */
if (allocation.x == -1 &&
allocation.y == -1 &&
@@ -5357,8 +5361,7 @@ static gboolean
gtk_window_state_event (GtkWidget *widget,
GdkEventWindowState *event)
{
- if (gtk_widget_is_toplevel (GTK_WIDGET (widget)))
- update_grip_visibility (GTK_WINDOW (widget));
+ update_grip_visibility (GTK_WINDOW (widget));
return FALSE;
}
@@ -5369,12 +5372,9 @@ gtk_window_direction_changed (GtkWidget *widget,
{
GtkWindow *window = GTK_WINDOW (widget);
- if (gtk_widget_is_toplevel (GTK_WIDGET (widget)))
- {
- set_grip_cursor (window);
- set_grip_position (window);
- set_grip_shape (window);
- }
+ set_grip_cursor (window);
+ set_grip_position (window);
+ set_grip_shape (window);
}
static void
@@ -5383,8 +5383,7 @@ gtk_window_state_changed (GtkWidget *widget,
{
GtkWindow *window = GTK_WINDOW (widget);
- if (gtk_widget_is_toplevel (GTK_WIDGET (widget)))
- update_grip_visibility (window);
+ update_grip_visibility (window);
}
static void
@@ -7346,23 +7345,6 @@ gtk_window_draw (GtkWidget *widget,
GtkStyleContext *context;
gboolean ret = FALSE;
- /* If the window is not toplevel anymore than it's embedded somewhere,
- * so just chain up and paint the children */
- if (!gtk_widget_is_toplevel (widget))
- {
- if (!gtk_widget_get_app_paintable (widget))
- gtk_paint_flat_box (gtk_widget_get_style (widget),
- cr,
- gtk_widget_get_state (widget),
- GTK_SHADOW_NONE,
- widget, "window",
- 0, 0,
- gtk_widget_get_allocated_width (widget),
- gtk_widget_get_allocated_height (widget));
-
- return GTK_WIDGET_CLASS (gtk_window_parent_class)->draw (widget, cr);
- }
-
context = gtk_widget_get_style_context (widget);
gtk_style_context_save (context);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]