mirror of
https://github.com/brl/mutter.git
synced 2024-11-29 19:40:43 -05:00
interval: Add a pointer variant to compute_value()
ClutterInterval.compute_value() computes the new value given a progress and copies it to a given GValue. Since most of the time we want to pass that very same value to another function that copies it again, we should have a compute_value() variant that stores that computed value inside ClutterInterval and returns a pointer to it. This way we initialize the result GValue just once and we never copy it, as long as the Interval instance is valid.
This commit is contained in:
parent
489c16c6a6
commit
af84d97fca
@ -77,6 +77,15 @@ enum
|
|||||||
PROP_VALUE_TYPE
|
PROP_VALUE_TYPE
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
INITIAL = 0,
|
||||||
|
FINAL,
|
||||||
|
RESULT,
|
||||||
|
|
||||||
|
N_VALUES
|
||||||
|
};
|
||||||
|
|
||||||
#define CLUTTER_INTERVAL_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), CLUTTER_TYPE_INTERVAL, ClutterIntervalPrivate))
|
#define CLUTTER_INTERVAL_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), CLUTTER_TYPE_INTERVAL, ClutterIntervalPrivate))
|
||||||
|
|
||||||
struct _ClutterIntervalPrivate
|
struct _ClutterIntervalPrivate
|
||||||
@ -410,7 +419,7 @@ clutter_interval_init (ClutterInterval *self)
|
|||||||
self->priv = priv = CLUTTER_INTERVAL_GET_PRIVATE (self);
|
self->priv = priv = CLUTTER_INTERVAL_GET_PRIVATE (self);
|
||||||
|
|
||||||
priv->value_type = G_TYPE_INVALID;
|
priv->value_type = G_TYPE_INVALID;
|
||||||
priv->values = g_malloc0 (sizeof (GValue) * 2);
|
priv->values = g_malloc0 (sizeof (GValue) * N_VALUES);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -633,6 +642,8 @@ clutter_interval_set_value_internal (ClutterInterval *interval,
|
|||||||
{
|
{
|
||||||
ClutterIntervalPrivate *priv = interval->priv;
|
ClutterIntervalPrivate *priv = interval->priv;
|
||||||
|
|
||||||
|
g_assert (index_ >= INITIAL && index_ <= RESULT);
|
||||||
|
|
||||||
if (G_IS_VALUE (&priv->values[index_]))
|
if (G_IS_VALUE (&priv->values[index_]))
|
||||||
g_value_unset (&priv->values[index_]);
|
g_value_unset (&priv->values[index_]);
|
||||||
|
|
||||||
@ -647,6 +658,8 @@ clutter_interval_get_value_internal (ClutterInterval *interval,
|
|||||||
{
|
{
|
||||||
ClutterIntervalPrivate *priv = interval->priv;
|
ClutterIntervalPrivate *priv = interval->priv;
|
||||||
|
|
||||||
|
g_assert (index_ >= INITIAL && index_ <= RESULT);
|
||||||
|
|
||||||
g_value_copy (&priv->values[index_], value);
|
g_value_copy (&priv->values[index_], value);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -673,7 +686,7 @@ clutter_interval_set_initial_value (ClutterInterval *interval,
|
|||||||
|
|
||||||
g_return_if_fail (G_VALUE_TYPE (value) == priv->value_type);
|
g_return_if_fail (G_VALUE_TYPE (value) == priv->value_type);
|
||||||
|
|
||||||
clutter_interval_set_value_internal (interval, 0, value);
|
clutter_interval_set_value_internal (interval, INITIAL, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -696,7 +709,7 @@ clutter_interval_get_initial_value (ClutterInterval *interval,
|
|||||||
g_return_if_fail (CLUTTER_IS_INTERVAL (interval));
|
g_return_if_fail (CLUTTER_IS_INTERVAL (interval));
|
||||||
g_return_if_fail (value != NULL);
|
g_return_if_fail (value != NULL);
|
||||||
|
|
||||||
clutter_interval_get_value_internal (interval, 0, value);
|
clutter_interval_get_value_internal (interval, INITIAL, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -716,7 +729,7 @@ clutter_interval_peek_initial_value (ClutterInterval *interval)
|
|||||||
{
|
{
|
||||||
g_return_val_if_fail (CLUTTER_IS_INTERVAL (interval), NULL);
|
g_return_val_if_fail (CLUTTER_IS_INTERVAL (interval), NULL);
|
||||||
|
|
||||||
return interval->priv->values;
|
return interval->priv->values + INITIAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -742,7 +755,7 @@ clutter_interval_set_final_value (ClutterInterval *interval,
|
|||||||
|
|
||||||
g_return_if_fail (G_VALUE_TYPE (value) == priv->value_type);
|
g_return_if_fail (G_VALUE_TYPE (value) == priv->value_type);
|
||||||
|
|
||||||
clutter_interval_set_value_internal (interval, 1, value);
|
clutter_interval_set_value_internal (interval, FINAL, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -765,7 +778,7 @@ clutter_interval_get_final_value (ClutterInterval *interval,
|
|||||||
g_return_if_fail (CLUTTER_IS_INTERVAL (interval));
|
g_return_if_fail (CLUTTER_IS_INTERVAL (interval));
|
||||||
g_return_if_fail (value != NULL);
|
g_return_if_fail (value != NULL);
|
||||||
|
|
||||||
clutter_interval_get_value_internal (interval, 1, value);
|
clutter_interval_get_value_internal (interval, FINAL, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -785,7 +798,7 @@ clutter_interval_peek_final_value (ClutterInterval *interval)
|
|||||||
{
|
{
|
||||||
g_return_val_if_fail (CLUTTER_IS_INTERVAL (interval), NULL);
|
g_return_val_if_fail (CLUTTER_IS_INTERVAL (interval), NULL);
|
||||||
|
|
||||||
return interval->priv->values + 1;
|
return interval->priv->values + FINAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -885,7 +898,7 @@ clutter_interval_validate (ClutterInterval *interval,
|
|||||||
* @value: return location for an initialized #GValue
|
* @value: return location for an initialized #GValue
|
||||||
*
|
*
|
||||||
* Computes the value between the @interval boundaries given the
|
* Computes the value between the @interval boundaries given the
|
||||||
* progress @factor and puts it into @value.
|
* progress @factor and copies it into @value.
|
||||||
*
|
*
|
||||||
* Return value: %TRUE if the operation was successful
|
* Return value: %TRUE if the operation was successful
|
||||||
*
|
*
|
||||||
@ -904,6 +917,50 @@ clutter_interval_compute_value (ClutterInterval *interval,
|
|||||||
value);
|
value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* clutter_interval_compute:
|
||||||
|
* @interval: a #ClutterInterval
|
||||||
|
* @factor: the progress factor, between 0 and 1
|
||||||
|
*
|
||||||
|
* Computes the value between the @interval boundaries given the
|
||||||
|
* progress @factor
|
||||||
|
*
|
||||||
|
* Unlike clutter_interval_compute_value(), this function will
|
||||||
|
* return a const pointer to the computed value
|
||||||
|
*
|
||||||
|
* You should use this function if you immediately pass the computed
|
||||||
|
* value to another function that makes a copy of it, like
|
||||||
|
* g_object_set_property()
|
||||||
|
*
|
||||||
|
* Return value: (transfer none): a pointer to the computed value,
|
||||||
|
* or %NULL if the computation was not successfull
|
||||||
|
*
|
||||||
|
* Since: 1.4
|
||||||
|
*/
|
||||||
|
G_CONST_RETURN GValue *
|
||||||
|
clutter_interval_compute (ClutterInterval *interval,
|
||||||
|
gdouble factor)
|
||||||
|
{
|
||||||
|
GValue *value;
|
||||||
|
gboolean res;
|
||||||
|
|
||||||
|
g_return_val_if_fail (CLUTTER_IS_INTERVAL (interval), NULL);
|
||||||
|
|
||||||
|
value = &(interval->priv->values[RESULT]);
|
||||||
|
|
||||||
|
if (G_VALUE_TYPE (value) == G_TYPE_INVALID)
|
||||||
|
g_value_init (value, interval->priv->value_type);
|
||||||
|
|
||||||
|
res = CLUTTER_INTERVAL_GET_CLASS (interval)->compute_value (interval,
|
||||||
|
factor,
|
||||||
|
value);
|
||||||
|
|
||||||
|
if (res)
|
||||||
|
return interval->priv->values + RESULT;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* clutter_interval_register_progress_func:
|
* clutter_interval_register_progress_func:
|
||||||
* @value_type: a #GType
|
* @value_type: a #GType
|
||||||
|
@ -154,6 +154,9 @@ gboolean clutter_interval_compute_value (ClutterInterval *interval,
|
|||||||
gdouble factor,
|
gdouble factor,
|
||||||
GValue *value);
|
GValue *value);
|
||||||
|
|
||||||
|
G_CONST_RETURN GValue *clutter_interval_compute (ClutterInterval *interval,
|
||||||
|
gdouble factor);
|
||||||
|
|
||||||
void clutter_interval_register_progress_func (GType value_type,
|
void clutter_interval_register_progress_func (GType value_type,
|
||||||
ClutterProgressFunc func);
|
ClutterProgressFunc func);
|
||||||
|
|
||||||
|
@ -1590,8 +1590,9 @@ clutter_interval_set_interval
|
|||||||
clutter_interval_get_interval
|
clutter_interval_get_interval
|
||||||
|
|
||||||
<SUBSECTION>
|
<SUBSECTION>
|
||||||
clutter_interval_compute_value
|
|
||||||
clutter_interval_validate
|
clutter_interval_validate
|
||||||
|
clutter_interval_compute_value
|
||||||
|
clutter_interval_compute
|
||||||
|
|
||||||
<SUBSECTION>
|
<SUBSECTION>
|
||||||
ClutterProgressFunc
|
ClutterProgressFunc
|
||||||
|
Loading…
Reference in New Issue
Block a user