GtkStyleContext *context)
{
_gtk_style_context_queue_invalidate (context, GTK_CSS_CHANGE_ANIMATE);
-
- /* A little blech to request one more than we need */
- gdk_frame_clock_request_phase (clock, GDK_FRAME_CLOCK_PHASE_UPDATE);
}
static gboolean
g_signal_handler_disconnect (priv->frame_clock,
priv->frame_clock_update_id);
priv->frame_clock_update_id = 0;
+ gdk_frame_clock_end_updating (priv->frame_clock);
}
}
"update",
G_CALLBACK (gtk_style_context_update),
context);
- gdk_frame_clock_request_phase (priv->frame_clock, GDK_FRAME_CLOCK_PHASE_UPDATE);
+ gdk_frame_clock_begin_updating (priv->frame_clock);
}
}
*
* Returns the #GdkFrameClock to which @context is attached.
*
- * Returns: (transfer none): a #GdkFrameClock.
+ * Returns: (transfer none): a #GdkFrameClock, or %NULL
+ * if @context does not have an attached frame clock.
* Since: 3.8
**/
GdkFrameClock *
_gtk_bitmask_free (animation_changes);
}
- if (!_gtk_bitmask_is_empty (changes) || (change & GTK_CSS_CHANGE_FORCE_INVALIDATE))
- gtk_style_context_do_invalidate (context, changes);
+ if (change & GTK_CSS_CHANGE_FORCE_INVALIDATE)
+ {
+ GtkBitmask *full = _gtk_bitmask_new ();
+ full = _gtk_bitmask_invert_range (full,
+ 0,
+ _gtk_css_style_property_get_n_properties ());
+ gtk_style_context_do_invalidate (context, full);
+ _gtk_bitmask_free (full);
+ }
+ else if (!_gtk_bitmask_is_empty (changes))
+ {
+ gtk_style_context_do_invalidate (context, changes);
+ }
change = _gtk_css_change_for_child (change);
for (list = priv->children; list; list = list->next)