| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
|
| |
... and the functions implementing it. Also deprecate the direction
getter on GtkThemingEngine.
|
|
|
|
|
|
|
| |
... instead of using a custom direction member.
And with that, GtkWidget doesn't need to call
gtk_style_context_set_direction() anymore.
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This function is just a sophisitcated optimization.
If we know the GDK window's background will be opaque, we mark it as
opaque. This is so GDK can do all the optimizations it does for opaque
windows and be fast.
This is mainly used when scrolling.
The previous code didn't get this right, in particular it didn't enforce
a transparent background when it knew the background was not opaque.
|
|
|
|
|
|
|
|
|
| |
This is for a very simple reason: The getter is returning a const value
and the font isn't const anymore. So we need to store the font
description somewhere but we can't reuse it as it's changing all the
time (yay animations, yay inherited values). Sucks.
So keep the hack in here but deprecate the function.
|
|
|
|
|
|
|
|
| |
This is necessary because values in a GtkCssComputedValues can change
now. So if the font-size is inherited or animated, the cached value will
be outdated.
Fixes the fontchooser preview not updating.
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
|
|
| |
Symbolic colors are an implementation detail of the CSS engine and have
been superceded by GtkCssColorValue. We don't want them clobbering the
public API. In particular because the only use I could find in the
public API is people using it to shade colors.
|
|
|
|
|
|
|
| |
Make _gtk_style_provider_private_get_color() return a GtkCssValue (a
GtkCssColorValue to be exact) instead of GtkSymbolicColor.
With this, the symbolic color usage inside GTK is minimized.
|
| |
|
|
|
|
|
| |
The function is used in multiple places, so split it out. In particular
because I'm about to change it.
|
|
|
|
|
| |
This is used in gtk_widget_reset_style() (via GTK_CSS_CHANGE_ANY) now,
and that makes GtkSettings font related changes work again.
|
|
|
|
|
|
| |
If lookup->missing is empty we don't need to continue looking.
We short circuit in several places as this can happen
after iteratively makeign lookup->missing smaller.
|
| |
|
| |
|
|
|
|
|
|
|
|
|
|
| |
Old code tried to use the "background-image" proeprty for setting the
default image background. While this used to work in the early days of
GTK3, today it is grossly misleading as the backgronud image may be
resized, repositioned and semi-translucent which causes very weird
artifacts when rendering.
So we use the background-color only instead.
|
| |
|
|
|
|
|
|
|
| |
... when looking up the needed changes.
This is what that matcher was actually written for, but it seems I never
hooked it in.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Here's the shortest description of the bug I can come up with:
When computing values, we have 3 kinds of dependencies:
(1) other properties ("currentColor" or em values)
(2) inherited properties ("inherit")
(3) generic things from the theme (@keyframes or @define-color)
Previously, we passed the GtkStyleContext as an argument, because it
provided these 3 things using:
(1) _gtk_style_context_peek_property()
(2) _gtk_style_context_peek_property(gtk_style_context_get_parent())
(3) context->priv->cascade
However, this makes it impossible to lookup values other than the ones
accessible via _gtk_style_context_peek_property(). And this is exactly
what we are doing in gtk_style_context_update_cache(). So when the cache
updates encountered case (1), they were looking up the values from the
wrong style data.
So this large patch essentially does nothing but replace the
context argument in all compute functions with new arguments for the 3
cases above:
(1) values
(2) parent_values
(3) provider
We apparently have a lot of computing code.
|
|
|
|
|
| |
We can juts pass a GtkStyleProviderPrivate, that one has the vfunc we
want already. So no need to pass vfuncs anymore.
|
|
|
|
|
| |
Previously, we were using the default classes and regions. That's
obviously wrong.
|
|
|
|
|
|
| |
Even when there is no current values, do create animations. This ensures
that animations do exist for unmapped widgets when they get mapped
later.
|
|
|
|
|
|
|
|
|
| |
While regular animations should always be created, transitions should
not. This patch allows to express this by passing NULL as the values to
transition from.
It also adds a gtk_style_context_should_create_transitions() function
that returns TRUE when transitions should be created.
|
|
|
|
|
| |
We now create animation objects unconditionally, but we only run the
animation loop when gtk_style_context_should_animate() return TRUE.
|
| |
|
|
|
|
|
|
|
|
| |
... that actually was both wrong, a performance failure and has been
there since the original checkin.
Updating the cached style data absolutely does not mean clearing all
cached style data first. There's nothing to update then.
|
| |
|
|
|
|
|
| |
Merge the animated values code into the computed values code. This
should get rid of various bugs related to animated->computed updating.
|
|
|
|
|
|
|
|
|
|
|
| |
This adds the GtkCssAnimation class and the code needed to hook it into
GtkStyleContext. It takes the values out of the CSS "animation"
properties and does animations. See
http://dev.w3.org/csswg/css3-animations/
for details.
Note that the code for starting and stopping animations with widget
visibility doesn't work yet.
|
|
|
|
| |
This will be necessary for creating the computed values for keyframes.
|
|
|
|
|
|
| |
We were failing to unref the style data in some code paths.
https://bugzilla.gnome.org/show_bug.cgi?id=683627
|
| |
|
|
|
|
|
|
|
| |
This fixes the longstanding bug where GTK would not update styles when
parent styles would change.
https://bugzilla.gnome.org/show_bug.cgi?id=672046
|
|
|
|
|
|
| |
This just changes the arguments passed to build_properties() and moves
that function around in the source file. No functional changes are
happening.
|
|
|
|
| |
This is not used yet in this patch.
|
|
|
|
|
|
|
| |
... in the case where no change of the DOM tree actually happened.
We don't do anything yet with that information, this patch just
correctly computes it.
|
| |
|
|
|
|
| |
This way, inherited properties can be updated.
|
|
|
|
|
|
| |
<Company>: cosimoc: yes, that totally makes sense
<Company>: looks like a copy/paste error from when i factored out that
function
|
|
|
|
| |
https://bugzilla.gnome.org/show_bug.cgi?id=643490
|
|
|
|
|
| |
Handle both the case where a widget is set and also the case where a
widget path is set.
|
|
|
|
|
| |
Adding "system" providers like the GtkSettings object shouldn't be
allowed at all, so ensure that it indeed is not.
|
|
|
|
|
|
| |
See inline comments for what it does. Its main use is figuring out if
something has been caused by GTK's caching of CSS properties or if it's
a different problem.
|
|
|
|
| |
This is tested by the stylecontext test, but doesn't appear in practice.
|
|
|
|
|
|
| |
Instead of using 1 global queue for both resizes and style validation,
use 2 queues. This makes the code a lot simpler and fixes a bug where we
could accidentally stop restylying for very delayed restyles.
|
|
|
|
| |
Introduce style_data_lookup_for_state() that does this.
|
|
|
|
|
|
|
| |
We now animate the core style information (see comment in
gtk_style_context_save()). A lot of widgets save + set custom style
classes/states during drawing and so can't be animated. It does work for
labels, menus and buttons though.
|
|
|
|
|
|
|
|
|
|
| |
This has two goals:
1) Move invalidation code out of a nested if branch. Invalidation is
actually the most important thing this function does.
2) Have the changes bitmask available. It will needed for invalidate
calls to children later.
|