[gtk/wip/baedert/for-master: 20/35] csscalcvalue: Avoid allocating memory in compute()
- From: Timm Bäder <baedert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/baedert/for-master: 20/35] csscalcvalue: Avoid allocating memory in compute()
- Date: Sun, 10 May 2020 06:45:10 +0000 (UTC)
commit df08387e35c1376bc1c5f66f53607b4258c35192
Author: Timm Bäder <mail baedert org>
Date: Wed May 6 08:23:17 2020 +0200
csscalcvalue: Avoid allocating memory in compute()
We already know how many values we're going to have, it's
value->n_terms.
gtk/gtkcsscalcvalue.c | 35 ++++++++++++++++++++---------------
1 file changed, 20 insertions(+), 15 deletions(-)
---
diff --git a/gtk/gtkcsscalcvalue.c b/gtk/gtkcsscalcvalue.c
index 55fb47a43e..330f3c0724 100644
--- a/gtk/gtkcsscalcvalue.c
+++ b/gtk/gtkcsscalcvalue.c
@@ -50,22 +50,21 @@ gtk_css_value_calc_free (GtkCssValue *value)
static GtkCssValue *gtk_css_calc_value_new (gsize n_terms);
static GtkCssValue *
-gtk_css_value_new_from_array (GPtrArray *array)
+gtk_css_value_new_from_array (GtkCssValue **values,
+ guint n_values)
{
GtkCssValue *result;
-
- if (array->len > 1)
+
+ if (n_values > 1)
{
- result = gtk_css_calc_value_new (array->len);
- memcpy (result->terms, array->pdata, array->len * sizeof (GtkCssValue *));
+ result = gtk_css_calc_value_new (n_values);
+ memcpy (result->terms, values, n_values * sizeof (GtkCssValue *));
}
else
{
- result = g_ptr_array_index (array, 0);
+ result = values[0];
}
- g_ptr_array_free (array, TRUE);
-
return result;
}
@@ -105,26 +104,28 @@ gtk_css_value_calc_compute (GtkCssValue *value,
GtkCssStyle *parent_style)
{
GtkCssValue *result;
- GPtrArray *array;
gboolean changed = FALSE;
gsize i;
+ GtkCssValue **new_values;
+
+ new_values = g_alloca (sizeof (GtkCssValue *) * value->n_terms);
- array = g_ptr_array_new ();
for (i = 0; i < value->n_terms; i++)
{
GtkCssValue *computed = _gtk_css_value_compute (value->terms[i], property_id, provider, style,
parent_style);
changed |= computed != value->terms[i];
- gtk_css_calc_array_add (array, computed);
+ new_values[i] = computed;
}
if (changed)
{
- result = gtk_css_value_new_from_array (array);
+ result = gtk_css_value_new_from_array (new_values, value->n_terms);
}
else
{
- g_ptr_array_set_free_func (array, (GDestroyNotify) _gtk_css_value_unref);
- g_ptr_array_free (array, TRUE);
+ for (i = 0; i < value->n_terms; i++)
+ gtk_css_value_unref (new_values[i]);
+
result = _gtk_css_value_ref (value);
}
@@ -279,6 +280,7 @@ gtk_css_calc_value_new_sum (GtkCssValue *value1,
GtkCssValue *value2)
{
GPtrArray *array;
+ GtkCssValue *result;
gsize i;
array = g_ptr_array_new ();
@@ -307,7 +309,10 @@ gtk_css_calc_value_new_sum (GtkCssValue *value1,
gtk_css_calc_array_add (array, _gtk_css_value_ref (value2));
}
- return gtk_css_value_new_from_array (array);
+ result = gtk_css_value_new_from_array ((GtkCssValue **)array->pdata, array->len);
+ g_ptr_array_free (array, TRUE);
+
+ return result;
}
GtkCssValue * gtk_css_calc_value_parse_sum (GtkCssParser *parser,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]