[gtk+/wip/baedert/children: 18/22] Move gtk_container_propagate_draw to GtkWidget



commit e2bb0aed295f7eda61dc45fdf3f52a4648b6c154
Author: Timm Bäder <mail baedert org>
Date:   Tue Nov 22 19:58:55 2016 +0100

    Move gtk_container_propagate_draw to GtkWidget

 gtk/gtkboxgadget.c |    2 +-
 gtk/gtkcontainer.c |  101 +---------------------------------------------------
 gtk/gtkcontainer.h |    5 ---
 gtk/gtknotebook.c  |   14 ++++----
 gtk/gtkpaned.c     |    4 +-
 gtk/gtkstack.c     |   24 ++++++------
 gtk/gtktextview.c  |    6 ++--
 gtk/gtktoolbar.c   |    8 ++--
 gtk/gtktreeview.c  |   10 +++---
 gtk/gtkwidget.c    |   48 ++++++++++++++++++++++++
 gtk/gtkwidget.h    |    5 +++
 11 files changed, 88 insertions(+), 139 deletions(-)
---
diff --git a/gtk/gtkboxgadget.c b/gtk/gtkboxgadget.c
index cfc67c3..4536b8f 100644
--- a/gtk/gtkboxgadget.c
+++ b/gtk/gtkboxgadget.c
@@ -508,7 +508,7 @@ gtk_box_gadget_draw (GtkCssGadget *gadget,
       GtkBoxGadgetChild *child = &g_array_index (priv->children, GtkBoxGadgetChild, draw_index);
 
       if (GTK_IS_WIDGET (child->object))
-        gtk_container_propagate_draw (GTK_CONTAINER (owner), GTK_WIDGET (child->object), cr);
+        gtk_widget_propagate_draw (owner, GTK_WIDGET (child->object), cr);
       else
         gtk_css_gadget_draw (GTK_CSS_GADGET (child->object), cr);
     }
diff --git a/gtk/gtkcontainer.c b/gtk/gtkcontainer.c
index cb2f87e..0627464 100644
--- a/gtk/gtkcontainer.c
+++ b/gtk/gtkcontainer.c
@@ -3055,7 +3055,7 @@ gtk_container_draw (GtkWidget *widget,
   for (i = 0; i < child_infos->len; i++)
     {
       child_info = &g_array_index (child_infos, ChildOrderInfo, i);
-      gtk_container_propagate_draw (container, child_info->child, cr);
+      gtk_widget_propagate_draw (widget, child_info->child, cr);
     }
 
   g_array_free (child_infos, TRUE);
@@ -3145,105 +3145,6 @@ gtk_container_get_children_clip (GtkContainer  *container,
   gtk_container_forall (container, union_with_clip, out_clip);
 }
 
-static void
-gtk_container_get_translation_to_child (GtkContainer *container,
-                                        GtkWidget    *child,
-                                        int          *x_out,
-                                        int          *y_out)
-{
-  GtkAllocation allocation;
-  GdkWindow *window, *w;
-  int x, y;
-
-  /* translate coordinates. Ugly business, that. */
-  if (!_gtk_widget_get_has_window (GTK_WIDGET (container)))
-    {
-      _gtk_widget_get_allocation (GTK_WIDGET (container), &allocation);
-      x = -allocation.x;
-      y = -allocation.y;
-    }
-  else
-    {
-      x = 0;
-      y = 0;
-    }
-
-  window = _gtk_widget_get_window (GTK_WIDGET (container));
-
-  for (w = _gtk_widget_get_window (child); w && w != window; w = gdk_window_get_parent (w))
-    {
-      int wx, wy;
-      gdk_window_get_position (w, &wx, &wy);
-      x += wx;
-      y += wy;
-    }
-
-  if (w == NULL)
-    {
-      x = 0;
-      y = 0;
-    }
-
-  if (!_gtk_widget_get_has_window (child))
-    {
-      _gtk_widget_get_allocation (child, &allocation);
-      x += allocation.x;
-      y += allocation.y;
-    }
-
-  *x_out = x;
-  *y_out = y;
-}
-
-/**
- * gtk_container_propagate_draw:
- * @container: a #GtkContainer
- * @child: a child of @container
- * @cr: Cairo context as passed to the container. If you want to use @cr
- *   in container’s draw function, consider using cairo_save() and
- *   cairo_restore() before calling this function.
- *
- * When a container receives a call to the draw function, it must send
- * synthetic #GtkWidget::draw calls to all children that don’t have their
- * own #GdkWindows. This function provides a convenient way of doing this.
- * A container, when it receives a call to its #GtkWidget::draw function,
- * calls gtk_container_propagate_draw() once for each child, passing in
- * the @cr the container received.
- *
- * gtk_container_propagate_draw() takes care of translating the origin of @cr,
- * and deciding whether the draw needs to be sent to the child. It is a
- * convenient and optimized way of getting the same effect as calling
- * gtk_widget_draw() on the child directly.
- *
- * In most cases, a container can simply either inherit the
- * #GtkWidget::draw implementation from #GtkContainer, or do some drawing
- * and then chain to the ::draw implementation from #GtkContainer.
- **/
-void
-gtk_container_propagate_draw (GtkContainer *container,
-                              GtkWidget    *child,
-                              cairo_t      *cr)
-{
-  int x, y;
-
-  g_return_if_fail (GTK_IS_CONTAINER (container));
-  g_return_if_fail (GTK_IS_WIDGET (child));
-  g_return_if_fail (cr != NULL);
-  g_return_if_fail (_gtk_widget_get_parent (child) == GTK_WIDGET (container));
-
-  if (!gtk_container_should_propagate_draw (container, child, cr))
-    return;
-
-  gtk_container_get_translation_to_child (container, child, &x, &y);
-
-  cairo_save (cr);
-  cairo_translate (cr, x, y);
-
-  gtk_widget_draw_internal (child, cr, TRUE);
-
-  cairo_restore (cr);
-}
-
 /**
  * gtk_container_get_path_for_child:
  * @container: a #GtkContainer
diff --git a/gtk/gtkcontainer.h b/gtk/gtkcontainer.h
index 6725a80..42ad410 100644
--- a/gtk/gtkcontainer.h
+++ b/gtk/gtkcontainer.h
@@ -139,11 +139,6 @@ GDK_AVAILABLE_IN_ALL
 GList*   gtk_container_get_children     (GtkContainer       *container);
 
 GDK_AVAILABLE_IN_ALL
-void     gtk_container_propagate_draw   (GtkContainer   *container,
-                                        GtkWidget      *child,
-                                        cairo_t        *cr);
-
-GDK_AVAILABLE_IN_ALL
 void     gtk_container_set_focus_chain  (GtkContainer   *container,
                                          GList          *focusable_widgets);
 GDK_AVAILABLE_IN_ALL
diff --git a/gtk/gtknotebook.c b/gtk/gtknotebook.c
index 5f0144f..1b0f295 100644
--- a/gtk/gtknotebook.c
+++ b/gtk/gtknotebook.c
@@ -2367,9 +2367,9 @@ gtk_notebook_draw_stack (GtkCssGadget *gadget,
   GtkNotebookPrivate *priv = notebook->priv;
 
   if (gtk_notebook_has_current_page (notebook))
-    gtk_container_propagate_draw (GTK_CONTAINER (notebook),
-                                  priv->cur_page->child,
-                                  cr);
+    gtk_widget_propagate_draw (widget,
+                               priv->cur_page->child,
+                               cr);
 
   return FALSE;
 }
@@ -3488,7 +3488,7 @@ on_drag_icon_draw (GtkWidget *widget,
                     requisition.height);
 
   if (child)
-    gtk_container_propagate_draw (GTK_CONTAINER (widget), child, cr);
+    gtk_widget_propagate_draw (widget, child, cr);
 
   gtk_style_context_restore (context);
 
@@ -4590,9 +4590,9 @@ draw_tab (GtkCssGadget *gadget,
 
   widget = gtk_css_gadget_get_owner (gadget);
 
-  gtk_container_propagate_draw (GTK_CONTAINER (widget),
-                                page->tab_label,
-                                cr);
+  gtk_widget_propagate_draw (widget,
+                             page->tab_label,
+                             cr);
 
   return gtk_widget_has_visible_focus (widget) &&
          GTK_NOTEBOOK (widget)->priv->cur_page == page;
diff --git a/gtk/gtkpaned.c b/gtk/gtkpaned.c
index a8c5db8..c040c60 100644
--- a/gtk/gtkpaned.c
+++ b/gtk/gtkpaned.c
@@ -1680,7 +1680,7 @@ gtk_paned_render (GtkCssGadget *gadget,
                        gdk_window_get_width (priv->child1_window),
                        gdk_window_get_height (priv->child1_window));
       cairo_clip (cr);
-      gtk_container_propagate_draw (GTK_CONTAINER (widget), priv->child1, cr);
+      gtk_widget_propagate_draw (widget, priv->child1, cr);
       cairo_restore (cr);
     }
 
@@ -1694,7 +1694,7 @@ gtk_paned_render (GtkCssGadget *gadget,
                        gdk_window_get_width (priv->child2_window),
                        gdk_window_get_height (priv->child2_window));
       cairo_clip (cr);
-      gtk_container_propagate_draw (GTK_CONTAINER (widget), priv->child2, cr);
+      gtk_widget_propagate_draw (widget, priv->child2, cr);
       cairo_restore (cr);
     }
 
diff --git a/gtk/gtkstack.c b/gtk/gtkstack.c
index e79056d..16b8b5e 100644
--- a/gtk/gtkstack.c
+++ b/gtk/gtkstack.c
@@ -1933,9 +1933,9 @@ gtk_stack_draw_crossfade (GtkWidget *widget,
   gdouble progress = gtk_progress_tracker_get_progress (&priv->tracker, FALSE);
 
   cairo_push_group (cr);
-  gtk_container_propagate_draw (GTK_CONTAINER (stack),
-                                priv->visible_child->widget,
-                                cr);
+  gtk_widget_propagate_draw (widget,
+                             priv->visible_child->widget,
+                             cr);
   cairo_save (cr);
 
   /* Multiply alpha by progress */
@@ -2004,9 +2004,9 @@ gtk_stack_draw_under (GtkWidget *widget,
   cairo_rectangle (cr, x, y, width, height);
   cairo_clip (cr);
 
-  gtk_container_propagate_draw (GTK_CONTAINER (stack),
-                                priv->visible_child->widget,
-                                cr);
+  gtk_widget_propagate_draw (widget,
+                             priv->visible_child->widget,
+                             cr);
 
   cairo_restore (cr);
 
@@ -2079,9 +2079,9 @@ gtk_stack_draw_slide (GtkWidget *widget,
      }
 
   if (gtk_cairo_should_draw_window (cr, priv->bin_window))
-    gtk_container_propagate_draw (GTK_CONTAINER (stack),
-                                  priv->visible_child->widget,
-                                  cr);
+    gtk_widget_propagate_draw (widget,
+                               priv->visible_child->widget,
+                               cr);
 }
 
 static gboolean
@@ -2179,9 +2179,9 @@ gtk_stack_render (GtkCssGadget *gadget,
 
         }
       else if (gtk_cairo_should_draw_window (cr, priv->bin_window))
-        gtk_container_propagate_draw (GTK_CONTAINER (stack),
-                                      priv->visible_child->widget,
-                                      cr);
+        gtk_widget_propagate_draw (widget,
+                                   priv->visible_child->widget,
+                                   cr);
     }
 
   return FALSE;
diff --git a/gtk/gtktextview.c b/gtk/gtktextview.c
index f21ed31..9af3eed 100644
--- a/gtk/gtktextview.c
+++ b/gtk/gtktextview.c
@@ -5950,9 +5950,9 @@ gtk_text_view_draw (GtkWidget *widget,
       /* propagate_draw checks that event->window matches
        * child->window
        */
-      gtk_container_propagate_draw (GTK_CONTAINER (widget),
-                                    vc->widget,
-                                    cr);
+      gtk_widget_propagate_draw (widget,
+                                 vc->widget,
+                                 cr);
       
       tmp_list = tmp_list->next;
     }
diff --git a/gtk/gtktoolbar.c b/gtk/gtktoolbar.c
index 03d887e..439e216 100644
--- a/gtk/gtktoolbar.c
+++ b/gtk/gtktoolbar.c
@@ -827,9 +827,9 @@ gtk_toolbar_render (GtkCssGadget *gadget,
       toolbar_content_draw (content, GTK_CONTAINER (widget), cr);
     }
   
-  gtk_container_propagate_draw (GTK_CONTAINER (widget),
-                               priv->arrow_button,
-                               cr);
+  gtk_widget_propagate_draw (widget,
+                             priv->arrow_button,
+                             cr);
 
   return FALSE;
 }
@@ -3137,7 +3137,7 @@ toolbar_content_draw (ToolbarContent *content,
   widget = GTK_WIDGET (content->item);
 
   if (widget)
-    gtk_container_propagate_draw (container, widget, cr);
+    gtk_widget_propagate_draw (GTK_WIDGET (container), widget, cr);
 }
 
 static gboolean
diff --git a/gtk/gtktreeview.c b/gtk/gtktreeview.c
index 0e4ab4e..9107863 100644
--- a/gtk/gtktreeview.c
+++ b/gtk/gtktreeview.c
@@ -5388,7 +5388,7 @@ gtk_tree_view_draw (GtkWidget *widget,
           GtkTreeViewChild *child = tmp_list->data;
           tmp_list = tmp_list->next;
 
-          gtk_container_propagate_draw (GTK_CONTAINER (tree_view), child->widget, cr);
+          gtk_widget_propagate_draw (widget, child->widget, cr);
         }
     }
   else if (tree_view->priv->drag_highlight_window &&
@@ -5442,8 +5442,8 @@ gtk_tree_view_draw (GtkWidget *widget,
          if (gtk_tree_view_column_get_visible (column))
            {
              button = gtk_tree_view_column_get_button (column);
-             gtk_container_propagate_draw (GTK_CONTAINER (tree_view),
-                                           button, cr);
+              gtk_widget_propagate_draw (widget,
+                                         button, cr);
            }
        }
     }
@@ -5452,8 +5452,8 @@ gtk_tree_view_draw (GtkWidget *widget,
       gtk_cairo_should_draw_window (cr, tree_view->priv->drag_window))
     {
       button = gtk_tree_view_column_get_button (tree_view->priv->drag_column);
-      gtk_container_propagate_draw (GTK_CONTAINER (tree_view),
-                                    button, cr);
+      gtk_widget_propagate_draw (widget,
+                                 button, cr);
     }
 
   gtk_style_context_restore (context);
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index ddffdc2..10364ed 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -15952,3 +15952,51 @@ gtk_widget_snapshot_child (GtkWidget      *widget,
   gtk_widget_snapshot (child, snapshot);
   gtk_snapshot_translate_2d (snapshot, -x, -y);
 }
+
+static gboolean
+gtk_widget_should_propagate_draw (GtkWidget *widget,
+                                  GtkWidget *child,
+                                  cairo_t   *cr)
+{
+  GdkWindow *child_in_window;
+
+  if (!_gtk_widget_is_drawable (child))
+    return FALSE;
+
+  /* Never propagate to a child window when exposing a window
+   * that is not the one the child widget is in.
+   */
+  if (_gtk_widget_get_has_window (child))
+    child_in_window = gdk_window_get_parent (_gtk_widget_get_window (child));
+  else
+    child_in_window = _gtk_widget_get_window (child);
+  if (!gtk_cairo_should_draw_window (cr, child_in_window))
+    return FALSE;
+
+  return TRUE;
+}
+
+void
+gtk_widget_propagate_draw (GtkWidget *widget,
+                           GtkWidget *child,
+                           cairo_t   *cr)
+{
+  int x, y;
+
+  g_return_if_fail (GTK_IS_WIDGET (widget));
+  g_return_if_fail (GTK_IS_WIDGET (child));
+  g_return_if_fail (cr != NULL);
+  g_return_if_fail (_gtk_widget_get_parent (child) == widget);
+
+  if (!gtk_widget_should_propagate_draw (widget, child, cr))
+    return;
+
+  gtk_widget_get_translation_to_child (widget, child, &x, &y);
+
+  cairo_save (cr);
+  cairo_translate (cr, x, y);
+
+  gtk_widget_draw_internal (child, cr, TRUE);
+
+  cairo_restore (cr);
+}
diff --git a/gtk/gtkwidget.h b/gtk/gtkwidget.h
index fe39506..80824ce 100644
--- a/gtk/gtkwidget.h
+++ b/gtk/gtkwidget.h
@@ -1321,6 +1321,11 @@ GtkWidget *             gtk_widget_get_next_sibling     (GtkWidget *widget);
 GDK_AVAILABLE_IN_3_90
 GtkWidget *             gtk_widget_get_prev_sibling     (GtkWidget *widget);
 
+GDK_AVAILABLE_IN_3_90
+void                    gtk_widget_propagate_draw       (GtkWidget *widget,
+                                                         GtkWidget *child,
+                                                         cairo_t   *cr);
+
 G_DEFINE_AUTOPTR_CLEANUP_FUNC(GtkWidget, g_object_unref)
 G_DEFINE_AUTOPTR_CLEANUP_FUNC(GtkRequisition, gtk_requisition_free)
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]