152 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 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
 | |
|  * License along with this library. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #include "config.h"
 | |
| 
 | |
| #include "gtkstyleprovider.h"
 | |
| 
 | |
| #include "gtkintl.h"
 | |
| #include "gtkprivate.h"
 | |
| #include "gtkwidgetpath.h"
 | |
| 
 | |
| /**
 | |
|  * SECTION:gtkstyleprovider
 | |
|  * @Short_description: Interface to provide style information to GtkStyleContext
 | |
|  * @Title: GtkStyleProvider
 | |
|  * @See_also: #GtkStyleContext, #GtkCssProvider
 | |
|  *
 | |
|  * 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().
 | |
|  */
 | |
| 
 | |
| 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)
 | |
| {
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * 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.
 | |
|  *
 | |
|  * Returns: (transfer full): a #GtkStyleProperties containing the
 | |
|  * style settings affecting @path
 | |
|  *
 | |
|  * Since: 3.0
 | |
|  **/
 | |
| GtkStyleProperties *
 | |
| gtk_style_provider_get_style (GtkStyleProvider *provider,
 | |
|                               GtkWidgetPath    *path)
 | |
| {
 | |
|   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;
 | |
| 
 | |
|   return iface->get_style (provider, path);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * gtk_style_provider_get_style_property:
 | |
|  * @provider: a #GtkStyleProvider
 | |
|  * @path: #GtkWidgetPath to query
 | |
|  * @state: state to query the style property for
 | |
|  * @pspec: The #GParamSpec to query
 | |
|  * @value: (out): return location for the property value
 | |
|  *
 | |
|  * Looks up a widget style property as defined by @provider for
 | |
|  * the widget represented by @path.
 | |
|  *
 | |
|  * Returns: %TRUE if the property was found and has a value, %FALSE otherwise
 | |
|  *
 | |
|  * Since: 3.0
 | |
|  **/
 | |
| gboolean
 | |
| gtk_style_provider_get_style_property (GtkStyleProvider *provider,
 | |
|                                        GtkWidgetPath    *path,
 | |
|                                        GtkStateFlags     state,
 | |
|                                        GParamSpec       *pspec,
 | |
|                                        GValue           *value)
 | |
| {
 | |
|   GtkStyleProviderIface *iface;
 | |
| 
 | |
|   g_return_val_if_fail (GTK_IS_STYLE_PROVIDER (provider), FALSE);
 | |
|   g_return_val_if_fail (G_IS_PARAM_SPEC (pspec), FALSE);
 | |
|   g_return_val_if_fail (path != NULL, FALSE);
 | |
|   g_return_val_if_fail (g_type_is_a (gtk_widget_path_get_object_type (path), pspec->owner_type), FALSE);
 | |
|   g_return_val_if_fail (value != NULL, FALSE);
 | |
| 
 | |
|   iface = GTK_STYLE_PROVIDER_GET_IFACE (provider);
 | |
| 
 | |
|   if (!iface->get_style_property)
 | |
|     return FALSE;
 | |
| 
 | |
|   return iface->get_style_property (provider, path, state, pspec, value);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * 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.
 | |
|  *
 | |
|  * Returns: (transfer none): The icon factory to use for @path, or %NULL
 | |
|  *
 | |
|  * Since: 3.0
 | |
|  **/
 | |
| 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);
 | |
| }
 | 
