2007-12-25 Emmanuele Bassi <ebassi@openedhand.com>

reviewed by: <delete if not using a buddy>

	* clutter/clutter-actor.c:
	(parse_rotation_array): Inline, and get the JsonArray as a parameter

	(parse_rotation): Update

	* clutter/clutter-script.c:
	(warn_missing_attribute): Fix for emacs-style warnings
	
	(clutter_script_parse_node): Remove an ifdeffed out section

	(clutter_script_construct_parameters),
	(clutter_script_construct_object): Rename get_parameters, so
	it's obvious what it does
This commit is contained in:
Emmanuele Bassi 2007-12-25 22:31:11 +00:00
parent 0bfe32314a
commit ac9f2fb1c5
3 changed files with 65 additions and 53 deletions

View File

@ -1,3 +1,21 @@
2007-12-25 Emmanuele Bassi <ebassi@openedhand.com>
reviewed by: <delete if not using a buddy>
* clutter/clutter-actor.c:
(parse_rotation_array): Inline, and get the JsonArray as a parameter
(parse_rotation): Update
* clutter/clutter-script.c:
(warn_missing_attribute): Fix for emacs-style warnings
(clutter_script_parse_node): Remove an ifdeffed out section
(clutter_script_construct_parameters),
(clutter_script_construct_object): Rename get_parameters, so
it's obvious what it does
2007-12-25 Emmanuele Bassi <ebassi@openedhand.com>
* tests/test-script.json: Fix the JSON syntax

View File

@ -4302,12 +4302,11 @@ typedef struct {
ClutterUnit center_z;
} RotationInfo;
static gboolean
static inline gboolean
parse_rotation_array (ClutterActor *actor,
JsonNode *node,
JsonArray *array,
RotationInfo *info)
{
JsonArray *array = json_node_get_array (node);
JsonNode *element;
if (json_array_get_length (array) != 2)
@ -4403,7 +4402,9 @@ parse_rotation (ClutterActor *actor,
retval = TRUE;
}
else if (JSON_NODE_TYPE (member) == JSON_NODE_ARRAY)
retval = parse_rotation_array (actor, member, info);
retval = parse_rotation_array (actor,
json_node_get_array (member),
info);
else
retval = FALSE;
}
@ -4419,7 +4420,9 @@ parse_rotation (ClutterActor *actor,
retval = TRUE;
}
else if (JSON_NODE_TYPE (member) == JSON_NODE_ARRAY)
retval = parse_rotation_array (actor, member, info);
retval = parse_rotation_array (actor,
json_node_get_array (member),
info);
else
retval = FALSE;
}
@ -4435,7 +4438,9 @@ parse_rotation (ClutterActor *actor,
retval = TRUE;
}
else if (JSON_NODE_TYPE (member) == JSON_NODE_ARRAY)
retval = parse_rotation_array (actor, member, info);
retval = parse_rotation_array (actor,
json_node_get_array (member),
info);
else
retval = FALSE;
}

View File

@ -212,7 +212,7 @@ warn_missing_attribute (ClutterScript *script,
if (G_LIKELY (id))
{
g_warning ("%s: %d: object `%s' has no `%s' attribute",
g_warning ("%s:%d: object `%s' has no `%s' attribute",
priv->is_filename ? priv->filename : "<input>",
json_parser_get_current_line (priv->parser),
id,
@ -220,7 +220,7 @@ warn_missing_attribute (ClutterScript *script,
}
else
{
g_warning ("%s: %d: object has no `%s' attribute",
g_warning ("%s:%d: object has no `%s' attribute",
priv->is_filename ? priv->filename : "<input>",
json_parser_get_current_line (priv->parser),
attribute);
@ -237,7 +237,7 @@ warn_invalid_value (ClutterScript *script,
if (G_LIKELY (node))
{
g_warning ("%s: %d: invalid value of type `%s' for attribute `%s'",
g_warning ("%s:%d: invalid value of type `%s' for attribute `%s'",
priv->is_filename ? priv->filename : "<input>",
json_parser_get_current_line (priv->parser),
json_node_type_name (node),
@ -245,7 +245,7 @@ warn_invalid_value (ClutterScript *script,
}
else
{
g_warning ("%s: %d: invalid value for attribute `%s'",
g_warning ("%s:%d: invalid value for attribute `%s'",
priv->is_filename ? priv->filename : "<input>",
json_parser_get_current_line (priv->parser),
attribute);
@ -931,17 +931,6 @@ clutter_script_parse_node (ClutterScript *script,
break;
}
#if 0
if (!retval)
{
if (pspec)
{
g_param_value_defaults (pspec, value);
retval = TRUE;
}
}
#endif
return retval;
}
@ -1010,11 +999,11 @@ clutter_script_translate_parameters (ClutterScript *script,
}
static GList *
clutter_script_get_parameters (ClutterScript *script,
GType gtype,
const gchar *name,
GList *properties,
GArray **construct_params)
clutter_script_construct_parameters (ClutterScript *script,
GType gtype,
const gchar *name,
GList *properties,
GArray **construct_params)
{
GObjectClass *klass;
GList *l, *unparsed;
@ -1039,9 +1028,7 @@ clutter_script_get_parameters (ClutterScript *script,
*/
pspec = g_object_class_find_property (klass, pinfo->name);
if (pspec)
{
pinfo->pspec = g_param_spec_ref (pspec);
}
pinfo->pspec = g_param_spec_ref (pspec);
else
{
pinfo->pspec = NULL;
@ -1055,6 +1042,8 @@ clutter_script_get_parameters (ClutterScript *script,
continue;
}
param.name = g_strdup (pinfo->name);
if (!clutter_script_parse_node (script, &param.value,
pinfo->name,
pinfo->node,
@ -1064,8 +1053,6 @@ clutter_script_get_parameters (ClutterScript *script,
continue;
}
param.name = g_strdup (pinfo->name);
g_array_append_val (*construct_params, param);
property_info_free (pinfo);
@ -1197,23 +1184,24 @@ clutter_script_construct_object (ClutterScript *script,
else if (oinfo->gtype == CLUTTER_TYPE_STAGE)
{
/* the stage is a complex beast: we cannot create it using
* g_object_newv() but we need clutter_script_get_parameters()
* g_object_newv() but we need clutter_script_construct_parameters()
* to add the GParamSpec to the PropertyInfo pspec member, so
* that we don't have to implement every complex property (like
* the "color" one) directly inside the ClutterStage class.
*/
oinfo->properties = clutter_script_get_parameters (script,
oinfo->gtype,
oinfo->id,
oinfo->properties,
&construct_params);
oinfo->properties =
clutter_script_construct_parameters (script,
oinfo->gtype,
oinfo->id,
oinfo->properties,
&construct_params);
object = G_OBJECT (clutter_stage_get_default ());
for (i = 0; i < construct_params->len; i++)
{
GParameter *param = &g_array_index (construct_params, GParameter, i);
g_free ((gchar *) param->name);
g_value_unset (&param->value);
}
@ -1223,11 +1211,12 @@ clutter_script_construct_object (ClutterScript *script,
else
{
/* every other object: first, we get the construction parameters */
oinfo->properties = clutter_script_get_parameters (script,
oinfo->gtype,
oinfo->id,
oinfo->properties,
&construct_params);
oinfo->properties =
clutter_script_construct_parameters (script,
oinfo->gtype,
oinfo->id,
oinfo->properties,
&construct_params);
object = g_object_newv (oinfo->gtype,
construct_params->len,
@ -1244,15 +1233,6 @@ clutter_script_construct_object (ClutterScript *script,
g_array_free (construct_params, TRUE);
}
/* then we get the rest of the parameters, asking the object itself
* to translate them for us, if we cannot do that
*/
oinfo->properties = clutter_script_translate_parameters (script,
object,
oinfo->id,
oinfo->properties,
&params);
/* shortcut, to avoid typechecking every time */
if (CLUTTER_IS_SCRIPTABLE (object))
{
@ -1263,6 +1243,15 @@ clutter_script_construct_object (ClutterScript *script,
set_custom_property = TRUE;
}
/* then we get the rest of the parameters, asking the object itself
* to translate them for us, if we cannot do that
*/
oinfo->properties = clutter_script_translate_parameters (script,
object,
oinfo->id,
oinfo->properties,
&params);
/* consume all the properties we could translate in this pass */
for (i = 0; i < params->len; i++)
{