Reviewed by Tim Janik:
authorMichael Natterer <mitch@imendio.com>
Mon, 21 Jul 2008 10:36:03 +0000 (10:36 +0000)
committerMichael Natterer <mitch@src.gnome.org>
Mon, 21 Jul 2008 10:36:03 +0000 (10:36 +0000)
2008-07-21  Michael Natterer  <mitch@imendio.com>

Reviewed by Tim Janik:

* gsignal.c (g_signal_chain_from_overridden_handler): allocate
the temp GValue array with GSLice.

(g_signal_emit_valist): dito. Remove optimization/obfuscation of
allocating up to 16 GValues on the stack and always use GSLice.

svn path=/trunk/; revision=7229

gobject/ChangeLog
gobject/gsignal.c

index 42c3309981170f25eb624db53612e974440397b8..bc9e16ef4f0c01d41c4c7f7de45d082df0ddb543 100644 (file)
@@ -1,3 +1,11 @@
+2008-07-21  Michael Natterer  <mitch@imendio.com>
+
+       * gsignal.c (g_signal_chain_from_overridden_handler): allocate
+       the temp GValue array with GSLice.
+
+       (g_signal_emit_valist): dito. Remove optimization/obfuscation of
+       allocating up to 16 GValues on the stack and always use GSLice.
+
 2008-07-05  Matthias Clasen  <mclasen@redhat.com>
 
        Bug 539229 – gobject-query calls itself query
index facb8bb97de1d34953e0d6f1a0a4ccb0738bb9cb..f81251fcc91da8517418c361bc05503eee36bc73 100644 (file)
  */
 
 
-/* pre allocation configurations
- */
-#define        MAX_STACK_VALUES        (16)
-
 #define REPORT_BUG      "please report occurrence circumstances to gtk-devel-list@gnome.org"
 #ifdef G_ENABLE_DEBUG
 #define IF_DEBUG(debug_type, cond)     if ((_g_type_debug_flags & G_TYPE_DEBUG_ ## debug_type) || cond)
@@ -1382,7 +1378,7 @@ g_signal_new (const gchar  *signal_name,
  * g_signal_override_class_closure() or
  * g_signal_override_class_handler()and chained to with
  * g_signal_chain_from_overridden() or
- * g_signal_chain_from_overridden().
+ * g_signal_chain_from_overridden_handler().
  *
  * See g_signal_new() for information about signal names.
  *
@@ -1963,7 +1959,7 @@ g_signal_chain_from_overridden_handler (gpointer instance,
 
   if (closure)
     {
-      GValue *instance_and_params, *free_me = NULL;
+      GValue *instance_and_params;
       GType signal_return_type;
       GValue *param_values;
       va_list var_args;
@@ -1972,8 +1968,7 @@ g_signal_chain_from_overridden_handler (gpointer instance,
       va_start (var_args, instance);
 
       signal_return_type = node->return_type;
-      free_me = g_new (GValue, node->n_params + 1);
-      instance_and_params = free_me;
+      instance_and_params = g_slice_alloc (sizeof (GValue) * (n_params + 1));
       param_values = instance_and_params + 1;
 
       for (i = 0; i < node->n_params; i++)
@@ -2000,7 +1995,7 @@ g_signal_chain_from_overridden_handler (gpointer instance,
               while (i--)
                 g_value_unset (param_values + i);
 
-              g_free (free_me);
+              g_slice_free1 (sizeof (GValue) * (n_params + 1), instance_and_params);
               va_end (var_args);
               return;
             }
@@ -2061,8 +2056,7 @@ g_signal_chain_from_overridden_handler (gpointer instance,
       for (i = 0; i < n_params; i++)
         g_value_unset (param_values + i);
       g_value_unset (instance_and_params);
-      if (free_me)
-        g_free (free_me);
+      g_slice_free1 (sizeof (GValue) * (n_params + 1), instance_and_params);
 
       va_end (var_args);
 
@@ -2906,7 +2900,7 @@ g_signal_emit_valist (gpointer instance,
                      GQuark   detail,
                      va_list  var_args)
 {
-  GValue *instance_and_params, stack_values[MAX_STACK_VALUES], *free_me = NULL;
+  GValue *instance_and_params;
   GType signal_return_type;
   GValue *param_values;
   SignalNode *node;
@@ -2943,20 +2937,15 @@ g_signal_emit_valist (gpointer instance,
 
   n_params = node->n_params;
   signal_return_type = node->return_type;
-  if (node->n_params < MAX_STACK_VALUES)
-    instance_and_params = stack_values;
-  else
-    {
-      free_me = g_new (GValue, node->n_params + 1);
-      instance_and_params = free_me;
-    }
+  instance_and_params = g_slice_alloc (sizeof (GValue) * (n_params + 1));
   param_values = instance_and_params + 1;
+
   for (i = 0; i < node->n_params; i++)
     {
       gchar *error;
       GType ptype = node->param_types[i] & ~G_SIGNAL_TYPE_STATIC_SCOPE;
       gboolean static_scope = node->param_types[i] & G_SIGNAL_TYPE_STATIC_SCOPE;
-      
+
       param_values[i].g_type = 0;
       SIGNAL_UNLOCK ();
       g_value_init (param_values + i, ptype);
@@ -2975,7 +2964,7 @@ g_signal_emit_valist (gpointer instance,
          while (i--)
            g_value_unset (param_values + i);
 
-         g_free (free_me);
+         g_slice_free1 (sizeof (GValue) * (n_params + 1), instance_and_params);
          return;
        }
       SIGNAL_LOCK ();
@@ -3016,8 +3005,7 @@ g_signal_emit_valist (gpointer instance,
   for (i = 0; i < n_params; i++)
     g_value_unset (param_values + i);
   g_value_unset (instance_and_params);
-  if (free_me)
-    g_free (free_me);
+  g_slice_free1 (sizeof (GValue) * (n_params + 1), instance_and_params);
 }
 
 /**