summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2004-07-13 17:56:29 +0000
committerMatthias Clasen <matthiasc@src.gnome.org>2004-07-13 17:56:29 +0000
commit57101256f29c2b6b6437a56b295152a7f45c9cfe (patch)
tree00b78a2ee6749956da8e46a9f48ae4216ecd4e38
parent20efb51b01d725e91d14ae90d5202b05176dbfc9 (diff)
downloadgdk-pixbuf-57101256f29c2b6b6437a56b295152a7f45c9cfe.tar.gz
Prepare to handle composite implementations of GtkCellEditable, but
2004-07-13 Matthias Clasen <mclasen@redhat.com> * gtk/gtktreeview.c (gtk_tree_view_adjustment_changed): Prepare to handle composite implementations of GtkCellEditable, but recursively poking at allocation->y (hack stolen from GtkCList).
-rw-r--r--ChangeLog5
-rw-r--r--ChangeLog.pre-2-105
-rw-r--r--ChangeLog.pre-2-65
-rw-r--r--ChangeLog.pre-2-85
-rw-r--r--gtk/gtktreeview.c90
5 files changed, 109 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 33581faf2..7e5ca7342 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
2004-07-13 Matthias Clasen <mclasen@redhat.com>
+ * gtk/gtktreeview.c (gtk_tree_view_adjustment_changed):
+ Prepare to handle composite implementations of
+ GtkCellEditable, but recursively poking at
+ allocation->y (hack stolen from GtkCList).
+
* gtk/gtkmain.h: Add gtk_parse_args(), its a public
function. (#147476, Owen Taylor)
diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10
index 33581faf2..7e5ca7342 100644
--- a/ChangeLog.pre-2-10
+++ b/ChangeLog.pre-2-10
@@ -1,5 +1,10 @@
2004-07-13 Matthias Clasen <mclasen@redhat.com>
+ * gtk/gtktreeview.c (gtk_tree_view_adjustment_changed):
+ Prepare to handle composite implementations of
+ GtkCellEditable, but recursively poking at
+ allocation->y (hack stolen from GtkCList).
+
* gtk/gtkmain.h: Add gtk_parse_args(), its a public
function. (#147476, Owen Taylor)
diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6
index 33581faf2..7e5ca7342 100644
--- a/ChangeLog.pre-2-6
+++ b/ChangeLog.pre-2-6
@@ -1,5 +1,10 @@
2004-07-13 Matthias Clasen <mclasen@redhat.com>
+ * gtk/gtktreeview.c (gtk_tree_view_adjustment_changed):
+ Prepare to handle composite implementations of
+ GtkCellEditable, but recursively poking at
+ allocation->y (hack stolen from GtkCList).
+
* gtk/gtkmain.h: Add gtk_parse_args(), its a public
function. (#147476, Owen Taylor)
diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8
index 33581faf2..7e5ca7342 100644
--- a/ChangeLog.pre-2-8
+++ b/ChangeLog.pre-2-8
@@ -1,5 +1,10 @@
2004-07-13 Matthias Clasen <mclasen@redhat.com>
+ * gtk/gtktreeview.c (gtk_tree_view_adjustment_changed):
+ Prepare to handle composite implementations of
+ GtkCellEditable, but recursively poking at
+ allocation->y (hack stolen from GtkCList).
+
* gtk/gtkmain.h: Add gtk_parse_args(), its a public
function. (#147476, Owen Taylor)
diff --git a/gtk/gtktreeview.c b/gtk/gtktreeview.c
index 5ecaad0ae..8630f68c6 100644
--- a/gtk/gtktreeview.c
+++ b/gtk/gtktreeview.c
@@ -8744,6 +8744,77 @@ gtk_tree_view_new_column_width (GtkTreeView *tree_view,
}
+/* FIXME this adjust_allocation is a big cut-and-paste from
+ * GtkCList, needs to be some "official" way to do this
+ * factored out.
+ */
+typedef struct
+{
+ GdkWindow *window;
+ int dx;
+ int dy;
+} ScrollData;
+
+/* The window to which widget->window is relative */
+#define ALLOCATION_WINDOW(widget) \
+ (GTK_WIDGET_NO_WINDOW (widget) ? \
+ (widget)->window : \
+ gdk_window_get_parent ((widget)->window))
+
+static void
+adjust_allocation_recurse (GtkWidget *widget,
+ gpointer data)
+{
+ ScrollData *scroll_data = data;
+
+ /* Need to really size allocate instead of just poking
+ * into widget->allocation if the widget is not realized.
+ * FIXME someone figure out why this was.
+ */
+ if (!GTK_WIDGET_REALIZED (widget))
+ {
+ if (GTK_WIDGET_VISIBLE (widget))
+ {
+ GdkRectangle tmp_rectangle = widget->allocation;
+ tmp_rectangle.x += scroll_data->dx;
+ tmp_rectangle.y += scroll_data->dy;
+
+ gtk_widget_size_allocate (widget, &tmp_rectangle);
+ }
+ }
+ else
+ {
+ if (ALLOCATION_WINDOW (widget) == scroll_data->window)
+ {
+ widget->allocation.x += scroll_data->dx;
+ widget->allocation.y += scroll_data->dy;
+
+ if (GTK_IS_CONTAINER (widget))
+ gtk_container_forall (GTK_CONTAINER (widget),
+ adjust_allocation_recurse,
+ data);
+ }
+ }
+}
+
+static void
+adjust_allocation (GtkWidget *widget,
+ int dx,
+ int dy)
+{
+ ScrollData scroll_data;
+
+ if (GTK_WIDGET_REALIZED (widget))
+ scroll_data.window = ALLOCATION_WINDOW (widget);
+ else
+ scroll_data.window = NULL;
+
+ scroll_data.dx = dx;
+ scroll_data.dy = dy;
+
+ adjust_allocation_recurse (widget, &scroll_data);
+}
+
/* Callbacks */
static void
gtk_tree_view_adjustment_changed (GtkAdjustment *adjustment,
@@ -8763,7 +8834,24 @@ gtk_tree_view_adjustment_changed (GtkAdjustment *adjustment,
if (dy && tree_view->priv->edited_column)
{
if (GTK_IS_WIDGET (tree_view->priv->edited_column->editable_widget))
- GTK_WIDGET (tree_view->priv->edited_column->editable_widget)->allocation.y += dy;
+ {
+ GList *list;
+ GtkWidget *widget;
+ GtkTreeViewChild *child = NULL;
+
+ widget = GTK_WIDGET (tree_view->priv->edited_column->editable_widget);
+ adjust_allocation (widget, 0, dy);
+
+ for (list = tree_view->priv->children; list; list = list->next)
+ {
+ child = (GtkTreeViewChild *)list->data;
+ if (child->widget == widget)
+ {
+ child->y += dy;
+ break;
+ }
+ }
+ }
}
gdk_window_scroll (tree_view->priv->bin_window, 0, dy);