2010-03-04 20:05:03 +00:00
|
|
|
/* GTK - The GIMP Toolkit
|
|
|
|
* Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-02-27 13:01:10 +00:00
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
2010-03-04 20:05:03 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "gtkstyleprovider.h"
|
2012-03-16 19:01:50 +00:00
|
|
|
|
2010-03-04 20:05:03 +00:00
|
|
|
#include "gtkintl.h"
|
2012-03-16 19:01:50 +00:00
|
|
|
#include "gtkprivate.h"
|
|
|
|
#include "gtkwidgetpath.h"
|
2010-03-04 20:05:03 +00:00
|
|
|
|
2010-10-19 08:59:46 +00:00
|
|
|
/**
|
|
|
|
* SECTION:gtkstyleprovider
|
2010-11-20 05:22:29 +00:00
|
|
|
* @Short_description: Interface to provide style information to GtkStyleContext
|
2010-10-19 08:59:46 +00:00
|
|
|
* @Title: GtkStyleProvider
|
|
|
|
* @See_also: #GtkStyleContext, #GtkCssProvider
|
|
|
|
*
|
2011-02-23 10:09:20 +00:00
|
|
|
* GtkStyleProvider is an interface used to provide style information to a #GtkStyleContext.
|
|
|
|
* See gtk_style_context_add_provider() and gtk_style_context_add_provider_for_screen().
|
2010-10-19 08:59:46 +00:00
|
|
|
*/
|
|
|
|
|
2010-03-04 20:05:03 +00:00
|
|
|
static void gtk_style_provider_iface_init (gpointer g_iface);
|
|
|
|
|
|
|
|
GType
|
|
|
|
gtk_style_provider_get_type (void)
|
|
|
|
{
|
|
|
|
static GType style_provider_type = 0;
|
|
|
|
|
|
|
|
if (!style_provider_type)
|
|
|
|
style_provider_type = g_type_register_static_simple (G_TYPE_INTERFACE,
|
|
|
|
I_("GtkStyleProvider"),
|
|
|
|
sizeof (GtkStyleProviderIface),
|
|
|
|
(GClassInitFunc) gtk_style_provider_iface_init,
|
|
|
|
0, NULL, 0);
|
|
|
|
return style_provider_type;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gtk_style_provider_iface_init (gpointer g_iface)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-10-19 08:59:46 +00:00
|
|
|
/**
|
|
|
|
* gtk_style_provider_get_style:
|
|
|
|
* @provider: a #GtkStyleProvider
|
|
|
|
* @path: #GtkWidgetPath to query
|
|
|
|
*
|
|
|
|
* Returns the style settings affecting a widget defined by @path, or %NULL if
|
|
|
|
* @provider doesn't contemplate styling @path.
|
|
|
|
*
|
2011-01-18 09:01:17 +00:00
|
|
|
* Returns: (transfer full): a #GtkStyleProperties containing the
|
|
|
|
* style settings affecting @path
|
2010-10-19 08:59:46 +00:00
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
2010-10-29 04:47:32 +00:00
|
|
|
GtkStyleProperties *
|
2010-04-11 18:30:24 +00:00
|
|
|
gtk_style_provider_get_style (GtkStyleProvider *provider,
|
|
|
|
GtkWidgetPath *path)
|
2010-03-04 20:05:03 +00:00
|
|
|
{
|
|
|
|
GtkStyleProviderIface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GTK_IS_STYLE_PROVIDER (provider), NULL);
|
|
|
|
|
|
|
|
iface = GTK_STYLE_PROVIDER_GET_IFACE (provider);
|
|
|
|
|
|
|
|
if (!iface->get_style)
|
|
|
|
return NULL;
|
|
|
|
|
2010-04-11 18:30:24 +00:00
|
|
|
return iface->get_style (provider, path);
|
2010-03-04 20:05:03 +00:00
|
|
|
}
|
|
|
|
|
2010-10-19 08:59:46 +00:00
|
|
|
/**
|
|
|
|
* gtk_style_provider_get_style_property:
|
|
|
|
* @provider: a #GtkStyleProvider
|
|
|
|
* @path: #GtkWidgetPath to query
|
2010-11-30 01:14:00 +00:00
|
|
|
* @state: state to query the style property for
|
2010-11-17 01:42:27 +00:00
|
|
|
* @pspec: The #GParamSpec to query
|
2010-10-19 08:59:46 +00:00
|
|
|
* @value: (out): return location for the property value
|
|
|
|
*
|
|
|
|
* Looks up a widget style property as defined by @provider for
|
2010-11-17 01:42:27 +00:00
|
|
|
* the widget represented by @path.
|
2010-10-19 08:59:46 +00:00
|
|
|
*
|
|
|
|
* Returns: %TRUE if the property was found and has a value, %FALSE otherwise
|
2012-03-16 01:19:15 +00:00
|
|
|
*
|
|
|
|
* Since: 3.0
|
2010-10-19 08:59:46 +00:00
|
|
|
**/
|
2010-06-18 14:58:16 +00:00
|
|
|
gboolean
|
|
|
|
gtk_style_provider_get_style_property (GtkStyleProvider *provider,
|
2010-10-19 08:59:46 +00:00
|
|
|
GtkWidgetPath *path,
|
2010-11-30 01:14:00 +00:00
|
|
|
GtkStateFlags state,
|
2010-11-17 01:42:27 +00:00
|
|
|
GParamSpec *pspec,
|
2010-06-18 14:58:16 +00:00
|
|
|
GValue *value)
|
|
|
|
{
|
|
|
|
GtkStyleProviderIface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GTK_IS_STYLE_PROVIDER (provider), FALSE);
|
2010-11-17 01:42:27 +00:00
|
|
|
g_return_val_if_fail (G_IS_PARAM_SPEC (pspec), FALSE);
|
2010-10-19 08:59:46 +00:00
|
|
|
g_return_val_if_fail (path != NULL, FALSE);
|
2010-12-13 16:54:02 +00:00
|
|
|
g_return_val_if_fail (g_type_is_a (gtk_widget_path_get_object_type (path), pspec->owner_type), FALSE);
|
2010-06-18 14:58:16 +00:00
|
|
|
g_return_val_if_fail (value != NULL, FALSE);
|
|
|
|
|
|
|
|
iface = GTK_STYLE_PROVIDER_GET_IFACE (provider);
|
|
|
|
|
|
|
|
if (!iface->get_style_property)
|
|
|
|
return FALSE;
|
|
|
|
|
2010-11-30 01:14:00 +00:00
|
|
|
return iface->get_style_property (provider, path, state, pspec, value);
|
2010-06-18 14:58:16 +00:00
|
|
|
}
|
|
|
|
|
2010-10-19 08:59:46 +00:00
|
|
|
/**
|
|
|
|
* gtk_style_provider_get_icon_factory:
|
|
|
|
* @provider: a #GtkStyleProvider
|
|
|
|
* @path: #GtkWidgetPath to query
|
|
|
|
*
|
|
|
|
* Returns the #GtkIconFactory defined to be in use for @path, or %NULL if none
|
|
|
|
* is defined.
|
|
|
|
*
|
2011-01-18 09:01:17 +00:00
|
|
|
* Returns: (transfer none): The icon factory to use for @path, or %NULL
|
2010-10-19 08:59:46 +00:00
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
2010-06-27 17:35:08 +00:00
|
|
|
GtkIconFactory *
|
|
|
|
gtk_style_provider_get_icon_factory (GtkStyleProvider *provider,
|
|
|
|
GtkWidgetPath *path)
|
|
|
|
{
|
|
|
|
GtkStyleProviderIface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GTK_IS_STYLE_PROVIDER (provider), NULL);
|
|
|
|
g_return_val_if_fail (path != NULL, NULL);
|
|
|
|
|
|
|
|
iface = GTK_STYLE_PROVIDER_GET_IFACE (provider);
|
|
|
|
|
|
|
|
if (!iface->get_icon_factory)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
return iface->get_icon_factory (provider, path);
|
|
|
|
}
|