nautilus/0026-eel-GSEAL-eel-wrap-table.patch

137 lines
4.8 KiB
Diff

From 47947617e14e9e3b676b0f8614bbe294f86dde86 Mon Sep 17 00:00:00 2001
From: Bastien Nocera <hadess@hadess.net>
Date: Fri, 11 Jun 2010 13:11:51 +0200
Subject: [PATCH 026/249] [eel] GSEAL eel-wrap-table.
---
eel/eel-wrap-table.c | 45 ++++++++++++++++++++++++++++-----------------
1 files changed, 28 insertions(+), 17 deletions(-)
diff --git a/eel/eel-wrap-table.c b/eel/eel-wrap-table.c
index 4570428..fd757c6 100644
--- a/eel/eel-wrap-table.c
+++ b/eel/eel-wrap-table.c
@@ -175,7 +175,7 @@ eel_wrap_table_class_init (EelWrapTableClass *wrap_table_class)
static void
eel_wrap_table_init (EelWrapTable *wrap_table)
{
- GTK_WIDGET_SET_FLAGS (wrap_table, GTK_NO_WINDOW);
+ gtk_widget_set_has_window (GTK_WIDGET (wrap_table), FALSE);
wrap_table->details = g_new0 (EelWrapTableDetails, 1);
wrap_table->details->x_justification = EEL_JUSTIFICATION_BEGINNING;
@@ -293,7 +293,7 @@ eel_wrap_table_size_request (GtkWidget *widget,
/* The -1 tells Satan to use as much space as is available */
requisition->width = -1;
- requisition->height = content_dimensions.height + GTK_CONTAINER (widget)->border_width * 2;
+ requisition->height = content_dimensions.height + gtk_container_get_border_width (GTK_CONTAINER (widget)) * 2;
}
static void
@@ -307,7 +307,7 @@ eel_wrap_table_size_allocate (GtkWidget *widget,
wrap_table = EEL_WRAP_TABLE (widget);
- widget->allocation = *allocation;
+ gtk_widget_set_allocation (widget, allocation);
wrap_table_layout (wrap_table);
}
@@ -345,7 +345,7 @@ eel_wrap_table_map (GtkWidget *widget)
wrap_table = EEL_WRAP_TABLE (widget);
- GTK_WIDGET_SET_FLAGS (widget, GTK_MAPPED);
+ gtk_widget_set_mapped (widget, TRUE);
for (iterator = wrap_table->details->children; iterator; iterator = iterator->next) {
GtkWidget *item;
@@ -368,7 +368,7 @@ eel_wrap_table_unmap (GtkWidget *widget)
wrap_table = EEL_WRAP_TABLE (widget);
- GTK_WIDGET_UNSET_FLAGS (widget, GTK_MAPPED);
+ gtk_widget_set_mapped (widget, FALSE);
for (iterator = wrap_table->details->children; iterator; iterator = iterator->next) {
GtkWidget *item;
@@ -512,6 +512,7 @@ wrap_table_layout (EelWrapTable *wrap_table)
EelDimensions max_child_dimensions;
EelIRect content_bounds;
guint num_cols;
+ GtkAllocation allocation;
g_assert (EEL_IS_WRAP_TABLE (wrap_table));
@@ -520,8 +521,9 @@ wrap_table_layout (EelWrapTable *wrap_table)
pos.x = content_bounds.x0;
pos.y = content_bounds.y0;
- num_cols = wrap_table_get_num_fitting (GTK_WIDGET (wrap_table)->allocation.width -
- GTK_CONTAINER (wrap_table)->border_width * 2,
+ gtk_widget_get_allocation (GTK_WIDGET (wrap_table), &allocation);
+ num_cols = wrap_table_get_num_fitting (allocation.width -
+ gtk_container_get_border_width (GTK_CONTAINER (wrap_table)) * 2,
wrap_table->details->x_spacing,
max_child_dimensions.width);
if (num_cols != wrap_table->details->cols) {
@@ -673,7 +675,7 @@ wrap_table_get_content_dimensions (const EelWrapTable *wrap_table)
max_child_dimensions.height = MAX (max_child_dimensions.height, 1);
num_cols = wrap_table_get_num_fitting (dimensions.width -
- GTK_CONTAINER (wrap_table)->border_width * 2,
+ gtk_container_get_border_width (GTK_CONTAINER (wrap_table)) * 2,
wrap_table->details->x_spacing,
max_child_dimensions.width);
num_rows = num_children / num_cols;
@@ -697,15 +699,17 @@ static EelIRect
wrap_table_get_content_bounds (const EelWrapTable *wrap_table)
{
EelIRect content_bounds;
+ guint border;
g_assert (EEL_IS_WRAP_TABLE (wrap_table));
content_bounds = eel_gtk_widget_get_bounds (GTK_WIDGET (wrap_table));
- content_bounds.x0 += GTK_CONTAINER (wrap_table)->border_width;
- content_bounds.y0 += GTK_CONTAINER (wrap_table)->border_width;
- content_bounds.x1 -= GTK_CONTAINER (wrap_table)->border_width;
- content_bounds.y1 -= GTK_CONTAINER (wrap_table)->border_width;
+ border = gtk_container_get_border_width (GTK_CONTAINER (wrap_table));
+ content_bounds.x0 += border;
+ content_bounds.y0 += border;
+ content_bounds.x1 -= border;
+ content_bounds.y1 -= border;
return content_bounds;
}
@@ -715,11 +719,18 @@ wrap_table_child_focus_in (GtkWidget *widget,
GdkEventFocus *event,
gpointer data)
{
- g_assert (widget->parent && widget->parent->parent);
- g_assert (GTK_IS_VIEWPORT (widget->parent->parent));
-
- eel_gtk_viewport_scroll_to_rect (GTK_VIEWPORT (widget->parent->parent),
- &widget->allocation);
+ GtkWidget *parent, *pparent;
+ GtkAllocation allocation;
+
+ parent = gtk_widget_get_parent (widget);
+ if (parent)
+ pparent = gtk_widget_get_parent (parent);
+ g_assert (parent && pparent);
+ g_assert (GTK_IS_VIEWPORT (pparent));
+
+ gtk_widget_get_allocation (widget, &allocation);
+ eel_gtk_viewport_scroll_to_rect (GTK_VIEWPORT (pparent),
+ &allocation);
return FALSE;
}
--
1.7.2