2011-04-08 14:08:28 +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/>.
|
2011-04-08 14:08:28 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
2011-05-21 01:30:36 +00:00
|
|
|
#include "gtkstylepropertyprivate.h"
|
2011-04-08 14:08:28 +00:00
|
|
|
|
|
|
|
#include "gtkcssprovider.h"
|
2011-04-14 02:47:18 +00:00
|
|
|
#include "gtkcssparserprivate.h"
|
2011-12-31 12:43:31 +00:00
|
|
|
#include "gtkcssshorthandpropertyprivate.h"
|
2012-01-01 17:14:51 +00:00
|
|
|
#include "gtkcssstylefuncsprivate.h"
|
2011-12-31 12:43:31 +00:00
|
|
|
#include "gtkcssstylepropertyprivate.h"
|
2011-05-26 01:50:53 +00:00
|
|
|
#include "gtkcsstypesprivate.h"
|
2011-12-31 13:34:42 +00:00
|
|
|
#include "gtkintl.h"
|
2011-11-25 13:36:27 +00:00
|
|
|
#include "gtkprivatetypebuiltins.h"
|
2011-04-08 14:08:28 +00:00
|
|
|
|
2011-12-31 13:34:42 +00:00
|
|
|
enum {
|
|
|
|
PROP_0,
|
2011-12-31 16:36:22 +00:00
|
|
|
PROP_NAME,
|
|
|
|
PROP_VALUE_TYPE
|
2011-12-31 13:34:42 +00:00
|
|
|
};
|
|
|
|
|
2011-12-31 12:43:31 +00:00
|
|
|
G_DEFINE_ABSTRACT_TYPE (GtkStyleProperty, _gtk_style_property, G_TYPE_OBJECT)
|
2011-12-31 02:54:17 +00:00
|
|
|
|
|
|
|
static void
|
|
|
|
gtk_style_property_finalize (GObject *object)
|
|
|
|
{
|
|
|
|
GtkStyleProperty *property = GTK_STYLE_PROPERTY (object);
|
|
|
|
|
2015-09-20 06:32:48 +00:00
|
|
|
g_warning ("finalizing %s '%s', how could this happen?", G_OBJECT_TYPE_NAME (object), property->name);
|
2011-12-31 02:54:17 +00:00
|
|
|
|
|
|
|
G_OBJECT_CLASS (_gtk_style_property_parent_class)->finalize (object);
|
|
|
|
}
|
|
|
|
|
2011-12-31 13:34:42 +00:00
|
|
|
static void
|
|
|
|
gtk_style_property_set_property (GObject *object,
|
|
|
|
guint prop_id,
|
|
|
|
const GValue *value,
|
|
|
|
GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
GtkStyleProperty *property = GTK_STYLE_PROPERTY (object);
|
|
|
|
GtkStylePropertyClass *klass = GTK_STYLE_PROPERTY_GET_CLASS (property);
|
|
|
|
|
|
|
|
switch (prop_id)
|
|
|
|
{
|
|
|
|
case PROP_NAME:
|
|
|
|
property->name = g_value_dup_string (value);
|
|
|
|
g_assert (property->name);
|
|
|
|
g_assert (g_hash_table_lookup (klass->properties, property->name) == NULL);
|
|
|
|
g_hash_table_insert (klass->properties, property->name, property);
|
|
|
|
break;
|
2011-12-31 16:36:22 +00:00
|
|
|
case PROP_VALUE_TYPE:
|
|
|
|
property->value_type = g_value_get_gtype (value);
|
|
|
|
break;
|
2011-12-31 13:34:42 +00:00
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gtk_style_property_get_property (GObject *object,
|
|
|
|
guint prop_id,
|
|
|
|
GValue *value,
|
|
|
|
GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
GtkStyleProperty *property = GTK_STYLE_PROPERTY (object);
|
|
|
|
|
|
|
|
switch (prop_id)
|
|
|
|
{
|
|
|
|
case PROP_NAME:
|
|
|
|
g_value_set_string (value, property->name);
|
|
|
|
break;
|
2011-12-31 16:36:22 +00:00
|
|
|
case PROP_VALUE_TYPE:
|
|
|
|
g_value_set_gtype (value, property->value_type);
|
|
|
|
break;
|
2011-12-31 13:34:42 +00:00
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-31 02:54:17 +00:00
|
|
|
static void
|
|
|
|
_gtk_style_property_class_init (GtkStylePropertyClass *klass)
|
|
|
|
{
|
|
|
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
|
|
|
|
|
|
|
object_class->finalize = gtk_style_property_finalize;
|
2011-12-31 13:34:42 +00:00
|
|
|
object_class->set_property = gtk_style_property_set_property;
|
|
|
|
object_class->get_property = gtk_style_property_get_property;
|
|
|
|
|
|
|
|
g_object_class_install_property (object_class,
|
|
|
|
PROP_NAME,
|
|
|
|
g_param_spec_string ("name",
|
|
|
|
P_("Property name"),
|
|
|
|
P_("The name of the property"),
|
|
|
|
NULL,
|
|
|
|
G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
|
2011-12-31 16:36:22 +00:00
|
|
|
g_object_class_install_property (object_class,
|
|
|
|
PROP_VALUE_TYPE,
|
|
|
|
g_param_spec_gtype ("value-type",
|
|
|
|
P_("Value type"),
|
|
|
|
P_("The value type returned by GtkStyleContext"),
|
|
|
|
G_TYPE_NONE,
|
|
|
|
G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
|
2011-12-31 13:34:42 +00:00
|
|
|
|
|
|
|
klass->properties = g_hash_table_new (g_str_hash, g_str_equal);
|
2011-12-31 02:54:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
_gtk_style_property_init (GtkStyleProperty *property)
|
|
|
|
{
|
2011-12-31 16:36:22 +00:00
|
|
|
property->value_type = G_TYPE_NONE;
|
2011-12-31 02:54:17 +00:00
|
|
|
}
|
|
|
|
|
2012-01-02 09:06:47 +00:00
|
|
|
/**
|
|
|
|
* _gtk_style_property_parse_value:
|
|
|
|
* @property: the property
|
|
|
|
* @parser: the parser to parse from
|
|
|
|
*
|
|
|
|
* Tries to parse the given @property from the given @parser into
|
|
|
|
* @value. The type that @value will be assigned is dependant on
|
|
|
|
* the parser and no assumptions must be made about it. If the
|
|
|
|
* parsing fails, %FALSE will be returned and @value will be
|
|
|
|
* left uninitialized.
|
|
|
|
*
|
|
|
|
* Only if @property is a #GtkCssShorthandProperty, the @value will
|
2012-03-26 15:24:02 +00:00
|
|
|
* always be a #GtkCssValue whose values can be queried with
|
|
|
|
* _gtk_css_array_value_get_nth().
|
2012-01-02 09:06:47 +00:00
|
|
|
*
|
2012-03-26 15:24:02 +00:00
|
|
|
* Returns: %NULL on failure or the parsed #GtkCssValue
|
2012-01-02 09:06:47 +00:00
|
|
|
**/
|
2012-03-26 15:24:02 +00:00
|
|
|
GtkCssValue *
|
2012-01-01 17:14:51 +00:00
|
|
|
_gtk_style_property_parse_value (GtkStyleProperty *property,
|
2012-04-18 20:04:44 +00:00
|
|
|
GtkCssParser *parser)
|
2011-04-08 14:08:28 +00:00
|
|
|
{
|
2012-01-01 23:45:29 +00:00
|
|
|
GtkStylePropertyClass *klass;
|
|
|
|
|
2012-03-26 15:24:02 +00:00
|
|
|
g_return_val_if_fail (GTK_IS_STYLE_PROPERTY (property), NULL);
|
|
|
|
g_return_val_if_fail (parser != NULL, NULL);
|
2011-04-08 14:08:28 +00:00
|
|
|
|
2012-01-01 23:45:29 +00:00
|
|
|
klass = GTK_STYLE_PROPERTY_GET_CLASS (property);
|
|
|
|
|
2012-04-18 20:04:44 +00:00
|
|
|
return klass->parse_value (property, parser);
|
2012-01-01 23:45:29 +00:00
|
|
|
}
|
|
|
|
|
2012-01-01 20:58:45 +00:00
|
|
|
/**
|
|
|
|
* _gtk_style_property_assign:
|
|
|
|
* @property: the property
|
|
|
|
* @props: The properties to assign to
|
|
|
|
* @state: The state to assign
|
|
|
|
* @value: (out): the #GValue with the value to be
|
|
|
|
* assigned
|
|
|
|
*
|
|
|
|
* This function is called by gtk_style_properties_set() and in
|
|
|
|
* turn gtk_style_context_set() and similar functions to set the
|
|
|
|
* value from code using old APIs.
|
|
|
|
**/
|
2011-12-31 18:03:53 +00:00
|
|
|
void
|
|
|
|
_gtk_style_property_assign (GtkStyleProperty *property,
|
|
|
|
GtkStyleProperties *props,
|
|
|
|
GtkStateFlags state,
|
|
|
|
const GValue *value)
|
|
|
|
{
|
2012-01-01 20:58:45 +00:00
|
|
|
GtkStylePropertyClass *klass;
|
|
|
|
|
2011-12-31 18:03:53 +00:00
|
|
|
g_return_if_fail (GTK_IS_STYLE_PROPERTY (property));
|
2014-10-24 19:22:43 +00:00
|
|
|
G_GNUC_BEGIN_IGNORE_DEPRECATIONS;
|
2011-12-31 18:03:53 +00:00
|
|
|
g_return_if_fail (GTK_IS_STYLE_PROPERTIES (props));
|
2014-10-24 19:22:43 +00:00
|
|
|
G_GNUC_END_IGNORE_DEPRECATIONS;
|
2011-12-31 18:03:53 +00:00
|
|
|
g_return_if_fail (value != NULL);
|
|
|
|
|
2012-01-01 20:58:45 +00:00
|
|
|
klass = GTK_STYLE_PROPERTY_GET_CLASS (property);
|
2011-12-31 18:03:53 +00:00
|
|
|
|
2012-01-01 20:58:45 +00:00
|
|
|
klass->assign (property, props, state, value);
|
2011-12-31 18:03:53 +00:00
|
|
|
}
|
|
|
|
|
2012-01-01 20:58:45 +00:00
|
|
|
/**
|
|
|
|
* _gtk_style_property_query:
|
|
|
|
* @property: the property
|
|
|
|
* @value: (out): an uninitialized #GValue to be filled with the
|
|
|
|
* contents of the lookup
|
2012-01-11 01:43:16 +00:00
|
|
|
* @query_func: The function to use to query properties
|
|
|
|
* @query_data: The data to pass to @query_func
|
2012-01-01 20:58:45 +00:00
|
|
|
*
|
|
|
|
* This function is called by gtk_style_properties_get() and in
|
|
|
|
* turn gtk_style_context_get() and similar functions to get the
|
|
|
|
* value to return to code using old APIs.
|
|
|
|
**/
|
2012-03-26 05:08:24 +00:00
|
|
|
void
|
2012-01-11 01:43:16 +00:00
|
|
|
_gtk_style_property_query (GtkStyleProperty *property,
|
2012-03-26 05:08:24 +00:00
|
|
|
GValue *value,
|
2012-01-11 01:43:16 +00:00
|
|
|
GtkStyleQueryFunc query_func,
|
|
|
|
gpointer query_data)
|
2011-12-31 00:14:47 +00:00
|
|
|
{
|
2012-01-01 20:58:45 +00:00
|
|
|
GtkStylePropertyClass *klass;
|
2011-12-31 00:14:47 +00:00
|
|
|
|
2012-03-26 05:08:24 +00:00
|
|
|
g_return_if_fail (value != NULL);
|
|
|
|
g_return_if_fail (GTK_IS_STYLE_PROPERTY (property));
|
|
|
|
g_return_if_fail (query_func != NULL);
|
2011-12-31 00:14:47 +00:00
|
|
|
|
2012-01-01 20:58:45 +00:00
|
|
|
klass = GTK_STYLE_PROPERTY_GET_CLASS (property);
|
2011-12-31 00:14:47 +00:00
|
|
|
|
2015-02-19 13:44:34 +00:00
|
|
|
klass->query (property, value, query_func, query_data);
|
2011-12-31 00:14:47 +00:00
|
|
|
}
|
|
|
|
|
2012-01-09 21:06:17 +00:00
|
|
|
void
|
|
|
|
_gtk_style_property_init_properties (void)
|
2011-05-21 02:17:28 +00:00
|
|
|
{
|
2011-12-31 13:34:42 +00:00
|
|
|
static gboolean initialized = FALSE;
|
2011-12-29 01:28:32 +00:00
|
|
|
|
2011-12-31 13:34:42 +00:00
|
|
|
if (G_LIKELY (initialized))
|
2011-05-21 02:17:28 +00:00
|
|
|
return;
|
|
|
|
|
2011-12-31 13:34:42 +00:00
|
|
|
initialized = TRUE;
|
2011-05-21 02:17:28 +00:00
|
|
|
|
2012-01-02 09:21:57 +00:00
|
|
|
_gtk_css_style_property_init_properties ();
|
2011-12-31 14:05:09 +00:00
|
|
|
/* initialize shorthands last, they depend on the real properties existing */
|
|
|
|
_gtk_css_shorthand_property_init_properties ();
|
2011-05-21 02:17:28 +00:00
|
|
|
}
|
|
|
|
|
2015-11-21 01:20:00 +00:00
|
|
|
void
|
|
|
|
_gtk_style_property_add_alias (const gchar *name,
|
|
|
|
const gchar *alias)
|
|
|
|
{
|
|
|
|
GtkStylePropertyClass *klass;
|
|
|
|
GtkStyleProperty *property;
|
|
|
|
|
|
|
|
g_return_if_fail (name != NULL);
|
|
|
|
g_return_if_fail (alias != NULL);
|
|
|
|
|
|
|
|
klass = g_type_class_peek (GTK_TYPE_STYLE_PROPERTY);
|
|
|
|
|
|
|
|
property = g_hash_table_lookup (klass->properties, name);
|
|
|
|
|
|
|
|
g_assert (property != NULL);
|
|
|
|
g_assert (g_hash_table_lookup (klass->properties, alias) == NULL);
|
|
|
|
|
|
|
|
g_hash_table_insert (klass->properties, (gpointer)alias, property);
|
|
|
|
}
|
|
|
|
|
2011-12-31 13:34:42 +00:00
|
|
|
/**
|
|
|
|
* _gtk_style_property_lookup:
|
|
|
|
* @name: name of the property to lookup
|
|
|
|
*
|
|
|
|
* Looks up the CSS property with the given @name. If no such
|
|
|
|
* property exists, %NULL is returned.
|
|
|
|
*
|
2016-09-22 11:56:47 +00:00
|
|
|
* Returns: (nullable) (transfer none): The property or %NULL if no
|
2011-12-31 13:34:42 +00:00
|
|
|
* property with the given name exists.
|
|
|
|
**/
|
2011-12-31 15:08:23 +00:00
|
|
|
GtkStyleProperty *
|
2011-05-21 02:17:28 +00:00
|
|
|
_gtk_style_property_lookup (const char *name)
|
|
|
|
{
|
2011-12-31 13:34:42 +00:00
|
|
|
GtkStylePropertyClass *klass;
|
|
|
|
|
|
|
|
g_return_val_if_fail (name != NULL, NULL);
|
|
|
|
|
2012-01-09 21:06:17 +00:00
|
|
|
_gtk_style_property_init_properties ();
|
2011-12-31 13:34:42 +00:00
|
|
|
|
|
|
|
klass = g_type_class_peek (GTK_TYPE_STYLE_PROPERTY);
|
|
|
|
|
|
|
|
return g_hash_table_lookup (klass->properties, name);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* _gtk_style_property_get_name:
|
|
|
|
* @property: the property to query
|
|
|
|
*
|
|
|
|
* Gets the name of the given property.
|
|
|
|
*
|
|
|
|
* Returns: the name of the property
|
|
|
|
**/
|
|
|
|
const char *
|
|
|
|
_gtk_style_property_get_name (GtkStyleProperty *property)
|
|
|
|
{
|
|
|
|
g_return_val_if_fail (GTK_IS_STYLE_PROPERTY (property), NULL);
|
2011-05-21 02:17:28 +00:00
|
|
|
|
2011-12-31 13:34:42 +00:00
|
|
|
return property->name;
|
2011-05-21 02:17:28 +00:00
|
|
|
}
|
|
|
|
|
2011-12-31 16:36:22 +00:00
|
|
|
/**
|
|
|
|
* _gtk_style_property_get_value_type:
|
|
|
|
* @property: the property to query
|
|
|
|
*
|
|
|
|
* Gets the value type of the @property, if the property is usable
|
|
|
|
* in public API via _gtk_style_property_assign() and
|
|
|
|
* _gtk_style_property_query(). If the @property is not usable in that
|
|
|
|
* way, %G_TYPE_NONE is returned.
|
|
|
|
*
|
|
|
|
* Returns: the value type in use or %G_TYPE_NONE if none.
|
|
|
|
**/
|
|
|
|
GType
|
|
|
|
_gtk_style_property_get_value_type (GtkStyleProperty *property)
|
|
|
|
{
|
|
|
|
g_return_val_if_fail (GTK_IS_STYLE_PROPERTY (property), G_TYPE_NONE);
|
|
|
|
|
|
|
|
return property->value_type;
|
|
|
|
}
|