[animation] Move the check for the 'signal::' prefix into a separate function

The old code checked whether the property began with 'signal-' and
then checked for 'signal-swapped' and 'signal-after'. This prevented
you from animating a property called for example 'signal-strength'.

The check for the prefix is now in a separate function which also adds
a 'signal-swapped-after' prefix for completeness.

Fixes bug:

  http://bugzilla.openedhand.com/show_bug.cgi?id=1798
This commit is contained in:
Neil Roberts 2009-09-07 11:36:05 +01:00
parent 7783635af3
commit c69209a253

View File

@ -1616,6 +1616,39 @@ clutter_animation_setupv (ClutterAnimation *animation,
}
}
static const struct
{
const gchar *name;
GConnectFlags flags;
} signal_prefixes[] =
{
{ "::", 0 },
{ "-swapped::", G_CONNECT_SWAPPED },
{ "-after::", G_CONNECT_AFTER },
{ "-swapped-after::", G_CONNECT_SWAPPED | G_CONNECT_AFTER }
};
static gboolean
clutter_animation_has_signal_prefix (const gchar *property_name,
GConnectFlags *flags,
int *offset)
{
int i;
if (!g_str_has_prefix (property_name, "signal"))
return FALSE;
for (i = 0; i < G_N_ELEMENTS (signal_prefixes); i++)
if (g_str_has_prefix (property_name + 6, signal_prefixes[i].name))
{
*offset = strlen (signal_prefixes[i].name) + 6;
*flags = signal_prefixes[i].flags;
return TRUE;
}
return FALSE;
}
static void
clutter_animation_setup_valist (ClutterAnimation *animation,
const gchar *first_property_name,
@ -1634,46 +1667,20 @@ clutter_animation_setup_valist (ClutterAnimation *animation,
GValue final = { 0, };
gchar *error = NULL;
gboolean is_fixed = FALSE;
if (g_str_has_prefix (property_name, "signal::"))
{
const gchar *signal_name = property_name + 8;
GCallback callback = va_arg (var_args, GCallback);
gpointer userdata = va_arg (var_args, gpointer);
g_signal_connect (animation, signal_name, callback, userdata);
}
else if (g_str_has_prefix (property_name, "signal-"))
{
GCallback callback = va_arg (var_args, GCallback);
gpointer userdata = va_arg (var_args, gpointer);
const gchar *signal_name;
GConnectFlags flags;
int offset;
if (g_str_has_prefix (property_name, "signal-after::"))
if (clutter_animation_has_signal_prefix (property_name,
&flags,
&offset))
{
signal_name = property_name + 14;
flags = G_CONNECT_AFTER;
}
else if (g_str_has_prefix (property_name, "signal-swapped::"))
{
signal_name = property_name + 16;
flags = G_CONNECT_SWAPPED;
}
else
{
g_warning ("Unable to connect to '%s': the valid signal "
"modifiers are 'signal-swapped::' and "
"'signal-swapped::'",
property_name);
break;
}
const gchar *signal_name = property_name + offset;
GCallback callback = va_arg (var_args, GCallback);
gpointer userdata = va_arg (var_args, gpointer);
g_signal_connect_data (animation, signal_name,
callback,
userdata,
NULL,
flags);
callback, userdata,
NULL, flags);
}
else
{