|
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 |
}
|