137 lines
4.8 KiB
Diff
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
|
||
|
|