Blame gobject/tests/signal-handler.c

Packit ae235b
#include <glib-object.h>
Packit ae235b
Packit ae235b
typedef struct {
Packit ae235b
  GObject instance;
Packit ae235b
} MyObj;
Packit ae235b
Packit ae235b
typedef struct {
Packit ae235b
  GObjectClass parent_class;
Packit ae235b
} MyObjClass;
Packit ae235b
Packit ae235b
enum {
Packit ae235b
  SIGNAL1,
Packit ae235b
  SIGNAL2,
Packit ae235b
  LAST_SIGNAL
Packit ae235b
};
Packit ae235b
Packit ae235b
guint signals[LAST_SIGNAL];
Packit ae235b
Packit ae235b
GType my_obj_get_type (void);
Packit ae235b
Packit ae235b
G_DEFINE_TYPE (MyObj, my_obj, G_TYPE_OBJECT)
Packit ae235b
Packit ae235b
static void
Packit ae235b
my_obj_init (MyObj *o)
Packit ae235b
{
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
my_obj_class_init (MyObjClass *class)
Packit ae235b
{
Packit ae235b
  signals[SIGNAL1] =
Packit ae235b
    g_signal_new ("signal1",
Packit ae235b
                  G_TYPE_FROM_CLASS (class),
Packit ae235b
                  G_SIGNAL_RUN_LAST,
Packit ae235b
                  0, NULL, NULL, NULL, G_TYPE_NONE, 0);
Packit ae235b
  signals[SIGNAL2] =
Packit ae235b
    g_signal_new ("signal2",
Packit ae235b
                  G_TYPE_FROM_CLASS (class),
Packit ae235b
                  G_SIGNAL_RUN_LAST,
Packit ae235b
                  0, NULL, NULL, NULL, G_TYPE_NONE, 0);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
nop (void)
Packit ae235b
{
Packit ae235b
}
Packit ae235b
Packit ae235b
#define HANDLERS 500000
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_connect_many (void)
Packit ae235b
{
Packit ae235b
  MyObj *o;
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i;
Packit ae235b
Packit ae235b
  o = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    g_signal_connect (o, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "connected %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_disconnect_many_ordered (void)
Packit ae235b
{
Packit ae235b
  MyObj *o;
Packit ae235b
  gulong handlers[HANDLERS];
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i;
Packit ae235b
Packit ae235b
  o = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    handlers[i] = g_signal_connect (o, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    g_signal_handler_disconnect (o, handlers[i]); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "disconnected %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_disconnect_many_inverse (void)
Packit ae235b
{
Packit ae235b
  MyObj *o;
Packit ae235b
  gulong handlers[HANDLERS];
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i;
Packit ae235b
Packit ae235b
  o = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    handlers[i] = g_signal_connect (o, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = HANDLERS - 1; i >= 0; i--)
Packit ae235b
    g_signal_handler_disconnect (o, handlers[i]); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "disconnected %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_disconnect_many_random (void)
Packit ae235b
{
Packit ae235b
  MyObj *o;
Packit ae235b
  gulong handlers[HANDLERS];
Packit ae235b
  gulong id;
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i, j;
Packit ae235b
Packit ae235b
  o = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    handlers[i] = g_signal_connect (o, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    {
Packit ae235b
      j = g_test_rand_int_range (0, HANDLERS);
Packit ae235b
      id = handlers[i];
Packit ae235b
      handlers[i] = handlers[j];
Packit ae235b
      handlers[j] = id;
Packit ae235b
    }
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    g_signal_handler_disconnect (o, handlers[i]); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "disconnected %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_disconnect_2_signals (void)
Packit ae235b
{
Packit ae235b
  MyObj *o;
Packit ae235b
  gulong handlers[HANDLERS];
Packit ae235b
  gulong id;
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i, j;
Packit ae235b
Packit ae235b
  o = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    {
Packit ae235b
      if (i % 2 == 0)
Packit ae235b
        handlers[i] = g_signal_connect (o, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
      else
Packit ae235b
        handlers[i] = g_signal_connect (o, "signal2", G_CALLBACK (nop), NULL); 
Packit ae235b
    }
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    {
Packit ae235b
      j = g_test_rand_int_range (0, HANDLERS);
Packit ae235b
      id = handlers[i];
Packit ae235b
      handlers[i] = handlers[j];
Packit ae235b
      handlers[j] = id;
Packit ae235b
    }
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    g_signal_handler_disconnect (o, handlers[i]); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "disconnected %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_disconnect_2_objects (void)
Packit ae235b
{
Packit ae235b
  MyObj *o1, *o2, *o;
Packit ae235b
  gulong handlers[HANDLERS];
Packit ae235b
  MyObj *objects[HANDLERS];
Packit ae235b
  gulong id;
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i, j;
Packit ae235b
Packit ae235b
  o1 = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
  o2 = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    {
Packit ae235b
      if (i % 2 == 0)
Packit ae235b
        {
Packit ae235b
          handlers[i] = g_signal_connect (o1, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
          objects[i] = o1;
Packit ae235b
        }
Packit ae235b
      else
Packit ae235b
        {
Packit ae235b
          handlers[i] = g_signal_connect (o2, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
          objects[i] = o2;
Packit ae235b
        }
Packit ae235b
    }
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    {
Packit ae235b
      j = g_test_rand_int_range (0, HANDLERS);
Packit ae235b
      id = handlers[i];
Packit ae235b
      handlers[i] = handlers[j];
Packit ae235b
      handlers[j] = id;
Packit ae235b
      o = objects[i];
Packit ae235b
      objects[i] = objects[j];
Packit ae235b
      objects[j] = o;
Packit ae235b
    }
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    g_signal_handler_disconnect (objects[i], handlers[i]); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o1);
Packit ae235b
  g_object_unref (o2);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "disconnected %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_block_many (void)
Packit ae235b
{
Packit ae235b
  MyObj *o;
Packit ae235b
  gulong handlers[HANDLERS];
Packit ae235b
  gulong id;
Packit ae235b
  gdouble time_elapsed;
Packit ae235b
  gint i, j;
Packit ae235b
Packit ae235b
  o = g_object_new (my_obj_get_type (), NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    handlers[i] = g_signal_connect (o, "signal1", G_CALLBACK (nop), NULL); 
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    {
Packit ae235b
      j = g_test_rand_int_range (0, HANDLERS);
Packit ae235b
      id = handlers[i];
Packit ae235b
      handlers[i] = handlers[j];
Packit ae235b
      handlers[j] = id;
Packit ae235b
    }
Packit ae235b
Packit ae235b
  g_test_timer_start ();
Packit ae235b
Packit ae235b
  for (i = 0; i < HANDLERS; i++)
Packit ae235b
    g_signal_handler_block (o, handlers[i]); 
Packit ae235b
Packit ae235b
  for (i = HANDLERS - 1; i >= 0; i--)
Packit ae235b
    g_signal_handler_unblock (o, handlers[i]); 
Packit ae235b
Packit ae235b
  time_elapsed = g_test_timer_elapsed ();
Packit ae235b
Packit ae235b
  g_object_unref (o);
Packit ae235b
Packit ae235b
  g_test_minimized_result (time_elapsed, "blocked and unblocked %u handlers in %6.3f seconds", HANDLERS, time_elapsed);
Packit ae235b
}
Packit ae235b
Packit ae235b
int
Packit ae235b
main (int argc, char *argv[])
Packit ae235b
{
Packit ae235b
  g_test_init (&argc, &argv, NULL);
Packit ae235b
Packit ae235b
  if (g_test_perf ())
Packit ae235b
    {
Packit ae235b
      g_test_add_func ("/signal/handler/connect-many", test_connect_many);
Packit ae235b
      g_test_add_func ("/signal/handler/disconnect-many-ordered", test_disconnect_many_ordered);
Packit ae235b
      g_test_add_func ("/signal/handler/disconnect-many-inverse", test_disconnect_many_inverse);
Packit ae235b
      g_test_add_func ("/signal/handler/disconnect-many-random", test_disconnect_many_random);
Packit ae235b
      g_test_add_func ("/signal/handler/disconnect-2-signals", test_disconnect_2_signals);
Packit ae235b
      g_test_add_func ("/signal/handler/disconnect-2-objects", test_disconnect_2_objects);
Packit ae235b
      g_test_add_func ("/signal/handler/block-many", test_block_many);
Packit ae235b
    }
Packit ae235b
Packit ae235b
  return g_test_run ();
Packit ae235b
}