Prevent surplus calls of _size_allocate() if no change

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@58328 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robert Roebling
2009-01-23 13:04:17 +00:00
parent 16eab2e1cf
commit 6063039441

View File

@@ -87,13 +87,15 @@ static void size_allocate(GtkWidget* widget, GtkAllocation* alloc)
}
widget->allocation = *alloc;
// adjust child positions
for (const GList* list = pizza->m_fixed.children; list; list = list->next)
{
const GtkFixedChild* child = static_cast<GtkFixedChild*>(list->data);
if (GTK_WIDGET_VISIBLE(child->widget))
{
GtkAllocation child_old_alloc = child->widget->allocation;
GtkAllocation child_alloc;
// note that child positions do not take border into
// account, they need to be relative to widget->window,
@@ -105,10 +107,13 @@ static void size_allocate(GtkWidget* widget, GtkAllocation* alloc)
child_alloc.width = req.width;
child_alloc.height = req.height;
if (gtk_widget_get_direction(widget) == GTK_TEXT_DIR_RTL)
{
child_alloc.x = w - child_alloc.x - child_alloc.width;
}
gtk_widget_size_allocate(child->widget, &child_alloc);
if ((child_alloc.x != child_old_alloc.x) ||
(child_alloc.y != child_old_alloc.y) ||
(child_alloc.width != child_old_alloc.width) ||
(child_alloc.height != child_old_alloc.height))
gtk_widget_size_allocate(child->widget, &child_alloc);
}
}
}