sl@0: /* Portion Copyright © 2008-09 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.*/ sl@0: sl@0: sl@0: sl@0: sl@0: #include sl@0: #include sl@0: #include sl@0: sl@0: #ifdef SYMBIAN sl@0: #include "glib_global.h" sl@0: #include "mrt2_glib2_test.h" sl@0: #define MULTITHREAD sl@0: //#define TEST_STOP_EMISSION sl@0: //#define VERBOSE sl@0: #define LOOP 3 sl@0: int TESTNUM; sl@0: int notifynum; sl@0: int handlernum; sl@0: gulong hookid; sl@0: GValue gv ; sl@0: GSignalQuery gq; sl@0: guint gi; sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: sl@0: #define G_TYPE_TEST (g_test_get_type ()) sl@0: #define G_TEST(test) (G_TYPE_CHECK_INSTANCE_CAST ((test), G_TYPE_TEST, GTest)) sl@0: #define G_IS_TEST(test) (G_TYPE_CHECK_INSTANCE_TYPE ((test), G_TYPE_TEST)) sl@0: #define G_TEST_CLASS(tclass) (G_TYPE_CHECK_CLASS_CAST ((tclass), G_TYPE_TEST, GTestClass)) sl@0: #define G_IS_TEST_CLASS(tclass) (G_TYPE_CHECK_CLASS_TYPE ((tclass), G_TYPE_TEST)) sl@0: #define G_TEST_GET_CLASS(test) (G_TYPE_INSTANCE_GET_CLASS ((test), G_TYPE_TEST, GTestClass)) sl@0: sl@0: static GRand *grand; sl@0: sl@0: typedef struct _GTest GTest; sl@0: typedef struct _GTestClass GTestClass; sl@0: sl@0: struct _GTest sl@0: { sl@0: GObject object; sl@0: sl@0: gint value; sl@0: }; sl@0: sl@0: struct _GTestClass sl@0: { sl@0: GObjectClass parent_class; sl@0: sl@0: void (*test_signal1) (GTest * test, gint an_int); sl@0: void (*test_signal2) (GTest * test, gint an_int); sl@0: }; sl@0: sl@0: static GType g_test_get_type (void); sl@0: static volatile gboolean stopping; sl@0: sl@0: /* Element signals and args */ sl@0: enum sl@0: { sl@0: TEST_SIGNAL1, sl@0: TEST_SIGNAL2, sl@0: /* add more above */ sl@0: LAST_SIGNAL sl@0: }; sl@0: sl@0: enum sl@0: { sl@0: ARG_0, sl@0: ARG_TEST_PROP sl@0: }; sl@0: sl@0: static void g_test_class_init (GTestClass * klass); sl@0: static void g_test_init (GTest * test); sl@0: static void g_test_dispose (GObject * object); sl@0: sl@0: static void signal2_handler (GTest * test, gint anint); sl@0: sl@0: static void g_test_set_property (GObject * object, guint prop_id, sl@0: const GValue * value, GParamSpec * pspec); sl@0: static void g_test_get_property (GObject * object, guint prop_id, sl@0: GValue * value, GParamSpec * pspec); sl@0: sl@0: static GObjectClass *parent_class = NULL; sl@0: sl@0: static guint g_test_signals[LAST_SIGNAL] = { 0 }; sl@0: sl@0: static GType sl@0: g_test_get_type (void) sl@0: { sl@0: static GType test_type = 0; sl@0: sl@0: if (!test_type) { sl@0: static const GTypeInfo test_info = { sl@0: sizeof (GTestClass), sl@0: NULL, sl@0: NULL, sl@0: (GClassInitFunc) g_test_class_init, sl@0: NULL, sl@0: NULL, sl@0: sizeof (GTest), sl@0: 0, sl@0: (GInstanceInitFunc) g_test_init, sl@0: NULL sl@0: }; sl@0: sl@0: grand = g_rand_new(); sl@0: sl@0: test_type = g_type_register_static (G_TYPE_OBJECT, "GTest", sl@0: &test_info, 0); sl@0: } sl@0: return test_type; sl@0: } sl@0: sl@0: static void sl@0: g_test_class_init (GTestClass * klass) sl@0: { sl@0: GObjectClass *gobject_class; sl@0: sl@0: gobject_class = (GObjectClass *) klass; sl@0: sl@0: parent_class = g_type_class_ref (G_TYPE_OBJECT); sl@0: #ifndef SYMBIAN sl@0: if (!g_thread_supported ()) sl@0: g_thread_init (NULL); sl@0: #else sl@0: sl@0: #ifdef MULTITHREAD sl@0: if (!g_thread_supported ()) sl@0: g_thread_init (NULL); sl@0: #endif /*MULTITHREAD*/ sl@0: sl@0: #endif /*SYMBAIN*/ sl@0: sl@0: gobject_class->dispose = g_test_dispose; sl@0: gobject_class->set_property = g_test_set_property; sl@0: gobject_class->get_property = g_test_get_property; sl@0: sl@0: g_test_signals[TEST_SIGNAL1] = sl@0: g_signal_new ("test-signal1", G_TYPE_FROM_CLASS (klass), sl@0: G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GTestClass, test_signal1), NULL, sl@0: NULL, g_cclosure_marshal_VOID__INT, G_TYPE_NONE, 1, G_TYPE_INT); sl@0: g_test_signals[TEST_SIGNAL2] = sl@0: g_signal_new ("test-signal2", G_TYPE_FROM_CLASS (klass), sl@0: G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GTestClass, test_signal2), NULL, sl@0: NULL, g_cclosure_marshal_VOID__INT, G_TYPE_NONE, 1, G_TYPE_INT); sl@0: sl@0: g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_TEST_PROP, sl@0: g_param_spec_int ("test-prop", "Test Prop", "Test property", sl@0: 0, 1, 0, G_PARAM_READWRITE)); sl@0: sl@0: klass->test_signal2 = signal2_handler; sl@0: } sl@0: sl@0: static void sl@0: g_test_init (GTest * test) sl@0: { sl@0: #ifndef SYMBIAN sl@0: g_print ("init %p\n", test); sl@0: #else sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("init %p\n", test); sl@0: #endif sl@0: sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: test->value = 0; sl@0: } sl@0: sl@0: static void sl@0: g_test_dispose (GObject * object) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: g_print ("dispose %p!\n", object); sl@0: sl@0: G_OBJECT_CLASS (parent_class)->dispose (object); sl@0: } sl@0: sl@0: static void sl@0: g_test_set_property (GObject * object, guint prop_id, sl@0: const GValue * value, GParamSpec * pspec) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: switch (prop_id) { sl@0: case ARG_TEST_PROP: sl@0: test->value = g_value_get_int (value); sl@0: break; sl@0: default: sl@0: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); sl@0: break; sl@0: } sl@0: } sl@0: sl@0: static void sl@0: g_test_get_property (GObject * object, guint prop_id, sl@0: GValue * value, GParamSpec * pspec) sl@0: { sl@0: GTest *test; sl@0: sl@0: test = G_TEST (object); sl@0: sl@0: switch (prop_id) { sl@0: case ARG_TEST_PROP: sl@0: g_value_set_int (value, test->value); sl@0: break; sl@0: default: sl@0: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); sl@0: break; sl@0: } sl@0: } sl@0: sl@0: static void sl@0: g_test_do_signal1 (GTest * test) sl@0: { sl@0: g_signal_emit (G_OBJECT (test), g_test_signals[TEST_SIGNAL1], 0, 0); sl@0: } sl@0: sl@0: static void sl@0: signal2_handler (GTest * test, gint anint) sl@0: { sl@0: #ifdef VERBOSE sl@0: g_print ("Function: signal2_handler called\n"); sl@0: #endif sl@0: sl@0: handlernum++; sl@0: } sl@0: sl@0: static void sl@0: g_test_do_signal2 (GTest * test) sl@0: { sl@0: g_signal_emit (G_OBJECT (test), g_test_signals[TEST_SIGNAL2], 0, 0); sl@0: } sl@0: sl@0: static void sl@0: g_test_do_prop (GTest * test) sl@0: { sl@0: test->value = g_rand_int (grand); sl@0: g_object_notify (G_OBJECT (test), "test-prop"); sl@0: } sl@0: sl@0: static gpointer sl@0: run_thread (GTest * test) sl@0: { sl@0: gint i = 1; sl@0: sl@0: #ifndef SYMBIAN sl@0: while (!stopping) sl@0: { sl@0: if (TESTNUM == 1) sl@0: g_test_do_signal1 (test); sl@0: if (TESTNUM == 2) sl@0: g_test_do_signal2 (test); sl@0: if (TESTNUM == 3) sl@0: g_test_do_prop (test); sl@0: if ((i++ % 10000) == 0) { sl@0: g_print ("."); sl@0: g_thread_yield(); /*force context switch */ sl@0: } sl@0: } sl@0: #else sl@0: sl@0: #ifdef MULTITHREAD sl@0: while (!stopping) sl@0: { sl@0: if (TESTNUM == 1) sl@0: g_test_do_signal1 (test); sl@0: if (TESTNUM == 2) sl@0: g_test_do_signal2 (test); sl@0: if (TESTNUM == 3) sl@0: g_test_do_prop (test); sl@0: if ((i++ % 10/*000*/) == 0) sl@0: { sl@0: #ifdef VERBOSE sl@0: g_print ("."); sl@0: #endif /*VERBOSE*/ sl@0: g_thread_yield(); /* force context switch */ sl@0: } sl@0: } sl@0: #else sl@0: for(i=0;i <= LOOP;i++) sl@0: { sl@0: if (TESTNUM == 1) sl@0: g_test_do_signal1 (test); sl@0: if (TESTNUM == 2) sl@0: g_test_do_signal2 (test); sl@0: if (TESTNUM == 3) sl@0: g_test_do_prop (test); sl@0: sl@0: #ifdef VERBOSE sl@0: g_print("."); sl@0: #endif sl@0: } sl@0: #endif /*MULTITHREAD*/ sl@0: sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: return NULL; sl@0: } sl@0: sl@0: sl@0: sl@0: sl@0: static void sl@0: notify (GObject *object, GParamSpec *spec, gpointer user_data) sl@0: { sl@0: gint value; sl@0: sl@0: notifynum++; sl@0: #ifdef VERBOSE sl@0: g_print ("Function: notify called\n"); sl@0: #endif sl@0: sl@0: g_object_get (object, "test-prop", &value, NULL); sl@0: //g_print ("+ %d", value); sl@0: } sl@0: sl@0: #ifdef SYMBIAN sl@0: void hook_function() sl@0: { sl@0: #ifdef VERBOSE sl@0: g_print ("Function: hook_function called\n"); sl@0: #endif sl@0: handlernum++; sl@0: } sl@0: #endif sl@0: sl@0: int sl@0: main (int argc, char **argv) sl@0: { sl@0: gint i; sl@0: GTest *test1, *test2; sl@0: GArray *test_threads; sl@0: const gint n_threads = 1; sl@0: sl@0: #ifdef SYMBIAN sl@0: g_log_set_handler (NULL, G_LOG_FLAG_FATAL| G_LOG_FLAG_RECURSION | G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_WARNING | G_LOG_LEVEL_MESSAGE | G_LOG_LEVEL_INFO | G_LOG_LEVEL_DEBUG, &mrtLogHandler, NULL); sl@0: g_set_print_handler(mrtPrintHandler); sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: g_thread_init (NULL); sl@0: sl@0: #ifndef SYMBIAN sl@0: g_print ("START: %s\n", argv[0]); sl@0: #else sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("START: %s\n", argv[0]); sl@0: #endif sl@0: sl@0: #endif /*SYMBIAN*/ sl@0: g_log_set_always_fatal (G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL | g_log_set_always_fatal (G_LOG_FATAL_MASK)); sl@0: g_type_init (); sl@0: sl@0: test1 = g_object_new (G_TYPE_TEST, NULL); sl@0: test2 = g_object_new (G_TYPE_TEST, NULL); sl@0: sl@0: g_signal_connect (test1, "notify::test-prop", G_CALLBACK (notify), NULL); sl@0: g_signal_connect (test1, "test-signal1", G_CALLBACK (notify), NULL); sl@0: g_signal_connect (test1, "test-signal2", G_CALLBACK (notify), NULL); sl@0: sl@0: sl@0: sl@0: sl@0: #ifndef SYMBIAN sl@0: test_threads = g_array_new (FALSE, FALSE, sizeof (GThread *)); sl@0: sl@0: stopping = FALSE; sl@0: sl@0: for (i = 0; i < n_threads; i++) { sl@0: GThread *thread; sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test1, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test2, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: } sl@0: g_usleep (500000); sl@0: sl@0: stopping = TRUE; sl@0: sl@0: g_print ("\nstopping\n"); sl@0: sl@0: /* join all threads */ sl@0: for (i = 0; i < 2 * n_threads; i++) { sl@0: GThread *thread; sl@0: sl@0: thread = g_array_index (test_threads, GThread *, i); sl@0: g_thread_join (thread); sl@0: } sl@0: sl@0: g_print ("stopped:%d\n",TESTNUM); sl@0: #else sl@0: sl@0: #ifdef MULTITHREAD sl@0: sl@0: test_threads = g_array_new (FALSE, FALSE, sizeof (GThread *)); sl@0: stopping = FALSE; sl@0: TESTNUM=1; sl@0: notifynum=0; sl@0: handlernum=0; sl@0: for (i = 0; i < n_threads; i++) sl@0: { sl@0: GThread *thread; sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test1, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test2, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: } sl@0: g_usleep (500000); sl@0: sl@0: stopping = TRUE; sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("\nstopping\n"); sl@0: #endif sl@0: /* join all threads */ sl@0: for (i = 0; i < 2 * n_threads; i++) sl@0: { sl@0: GThread *thread; sl@0: sl@0: thread = g_array_index (test_threads, GThread *, i); sl@0: g_thread_join (thread); sl@0: } sl@0: sl@0: g_assert(notifynum != 0); sl@0: g_assert(handlernum == 0); sl@0: sl@0: g_array_free (test_threads, TRUE); sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("Signals.c: completed for TESTNUM = %d\n",TESTNUM); sl@0: #endif sl@0: sl@0: sl@0: sl@0: test_threads = g_array_new (FALSE, FALSE, sizeof (GThread *)); sl@0: stopping = FALSE; sl@0: TESTNUM=2; sl@0: notifynum=0; sl@0: handlernum=0; sl@0: sl@0: for (i = 0; i < n_threads; i++) sl@0: { sl@0: GThread *thread; sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test1, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test2, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: } sl@0: g_usleep (500000); sl@0: sl@0: stopping = TRUE; sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("\nstopping\n"); sl@0: #endif sl@0: /* join all threads */ sl@0: for (i = 0; i < 2 * n_threads; i++) sl@0: { sl@0: GThread *thread; sl@0: sl@0: thread = g_array_index (test_threads, GThread *, i); sl@0: g_thread_join (thread); sl@0: } sl@0: sl@0: g_assert(notifynum != 0); sl@0: g_assert(handlernum != 0); sl@0: sl@0: g_array_free (test_threads, TRUE); sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("Signals.c: completed for TESTNUM = %d\n",TESTNUM); sl@0: #endif sl@0: sl@0: sl@0: test_threads = g_array_new (FALSE, FALSE, sizeof (GThread *)); sl@0: stopping = FALSE; sl@0: TESTNUM=3; sl@0: notifynum=0; sl@0: handlernum=0; sl@0: sl@0: for (i = 0; i < n_threads; i++) sl@0: { sl@0: GThread *thread; sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test1, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: sl@0: thread = g_thread_create ((GThreadFunc) run_thread, test2, TRUE, NULL); sl@0: g_array_append_val (test_threads, thread); sl@0: } sl@0: g_usleep (5000000); sl@0: sl@0: stopping = TRUE; sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("\nstopping\n"); sl@0: #endif sl@0: /* join all threads */ sl@0: for (i = 0; i < 2 * n_threads; i++) sl@0: { sl@0: GThread *thread; sl@0: sl@0: thread = g_array_index (test_threads, GThread *, i); sl@0: g_thread_join (thread); sl@0: } sl@0: sl@0: g_assert(notifynum != 0); sl@0: g_assert(handlernum == 0); sl@0: sl@0: g_array_free (test_threads, TRUE); sl@0: sl@0: #ifdef VERBOSE sl@0: g_print ("Signals.c: completed for TESTNUM = %d\n",TESTNUM); sl@0: #endif sl@0: sl@0: #else /* ! MULTITHREAD*/ sl@0: sl@0: sl@0: TESTNUM=1; sl@0: #ifdef VERBOSE sl@0: g_print ("\nStarting with TESTNUM=%d\n",TESTNUM); sl@0: #endif sl@0: sl@0: notifynum=0; sl@0: handlernum=0; sl@0: run_thread(test1); sl@0: g_assert(notifynum == LOOP +1); sl@0: g_assert(handlernum ==0); sl@0: sl@0: notifynum=0; sl@0: handlernum=0; sl@0: run_thread(test2); sl@0: g_assert(notifynum == 0); sl@0: g_assert(handlernum == 0); sl@0: sl@0: TESTNUM=2; sl@0: #ifdef VERBOSE sl@0: g_print ("\nStarting with TESTNUM=%d\n",TESTNUM); sl@0: #endif sl@0: sl@0: notifynum=0; sl@0: handlernum=0; sl@0: run_thread(test1); sl@0: g_assert(notifynum == LOOP+1); sl@0: g_assert(handlernum == LOOP+1); sl@0: sl@0: notifynum=0; sl@0: handlernum=0; sl@0: run_thread(test2); sl@0: g_assert(notifynum == 0); sl@0: g_assert(handlernum == LOOP+1); sl@0: sl@0: TESTNUM=3; sl@0: #ifdef VERBOSE sl@0: g_print ("\nStarting with TESTNUM=%d\n",TESTNUM); sl@0: #endif sl@0: sl@0: notifynum=0; sl@0: handlernum=0; sl@0: run_thread(test1); sl@0: g_assert(notifynum == LOOP +1); sl@0: g_assert(handlernum ==0); sl@0: sl@0: notifynum=0; sl@0: handlernum=0; sl@0: run_thread(test2); sl@0: g_assert(notifynum == 0); sl@0: g_assert(handlernum == 0); sl@0: sl@0: g_assert(g_signal_has_handler_pending(G_OBJECT(test1),g_signal_lookup("test-signal2",G_TYPE_TEST),NULL,TRUE)==TRUE); sl@0: g_assert(g_signal_has_handler_pending(G_OBJECT(test2),g_signal_lookup("test-signal2",G_TYPE_TEST),NULL,TRUE)==FALSE); sl@0: sl@0: g_assert(g_signal_handler_is_connected(G_OBJECT(test1),g_signal_lookup("test-signal1",G_TYPE_TEST))==TRUE); sl@0: g_assert(g_signal_handler_is_connected(G_OBJECT(test2),g_signal_lookup("test-signal2",G_TYPE_TEST))==FALSE); sl@0: sl@0: handlernum=g_signal_lookup("test-signal1",G_TYPE_TEST); sl@0: #ifdef VERBOSE sl@0: g_print("Signal id: %d\n",handlernum); sl@0: #endif sl@0: sl@0: g_signal_connect (test2, "test-signal1", G_CALLBACK (notify), NULL); sl@0: sl@0: hookid=g_signal_add_emission_hook(handlernum,NULL,(GSignalEmissionHook) hook_function,NULL,NULL); sl@0: sl@0: #ifdef VERBOSE sl@0: g_print("Hookid: %d\n",hookid); sl@0: #endif sl@0: /********************/ sl@0: sl@0: #ifdef TEST_STOP_EMISSION sl@0: /* sl@0: notifynum=0; sl@0: handlernum=0; sl@0: g_print("The following call stops signal emission\n"); sl@0: g_signal_stop_emission(G_OBJECT(test1),g_signal_lookup("test-signal1",G_TYPE_TEST),0); sl@0: sl@0: g_print("The following call should abort and it is normal\n"); sl@0: run_thread(test1); sl@0: printf("Notifynum: %d and Handlernum: %d\n",notifynum,handlernum); sl@0: sl@0: */ sl@0: notifynum=0; sl@0: handlernum=0; sl@0: g_signal_stop_emission_by_name(G_OBJECT(test1),"test-signal1"); sl@0: //run_thread(test1); sl@0: g_print("Notifynum: %d and Handlernum: %d\n",notifynum,handlernum); sl@0: sl@0: sl@0: #endif /*TEST_STOP_EMISSION*/ sl@0: sl@0: /*******************/ sl@0: sl@0: sl@0: handlernum=0; sl@0: g_signal_emit(G_OBJECT (test1), g_test_signals[TEST_SIGNAL1], 0, 0); sl@0: g_signal_emit(G_OBJECT (test2), g_test_signals[TEST_SIGNAL1], 0, 0); sl@0: g_assert(handlernum==2); sl@0: sl@0: sl@0: g_signal_remove_emission_hook(g_signal_lookup("test-signal1",G_TYPE_TEST),hookid); sl@0: sl@0: #ifdef VERBOSE sl@0: g_print("Emitting signal again after removing emission hook\n"); sl@0: #endif sl@0: sl@0: handlernum=0; sl@0: g_signal_emit (G_OBJECT (test1), g_test_signals[TEST_SIGNAL1], 0, 0); sl@0: g_signal_emit (G_OBJECT (test2), g_test_signals[TEST_SIGNAL1], 0, 0); sl@0: g_assert(handlernum==0); sl@0: sl@0: g_assert (strcmp ("test-signal1", g_signal_name (g_signal_lookup("test-signal1",G_TYPE_TEST))) == 0); sl@0: g_assert (strcmp ("test-signal2", g_signal_name (g_signal_lookup("test-signal2",G_TYPE_TEST))) == 0); sl@0: sl@0: sl@0: memset(&gv,0,sizeof(gv)); sl@0: g_value_init(&gv,G_TYPE_OBJECT); sl@0: g_value_set_object(&gv,test1); sl@0: sl@0: gi=0; sl@0: g_signal_list_ids(G_OBJECT_TYPE(test1),&gi); sl@0: g_assert(g_signal_lookup("test-signal1",G_TYPE_TEST)==gi); sl@0: sl@0: notifynum=0; sl@0: g_signal_emitv (&gv, g_test_signals[TEST_SIGNAL1], 0, &gv); sl@0: g_assert(notifynum==1); sl@0: sl@0: g_signal_query(g_signal_lookup("test-signal1",G_TYPE_TEST),&gq); sl@0: g_assert(strcmp("test-signal1",gq.signal_name)==0); sl@0: g_assert(g_signal_lookup("test-signal1",G_TYPE_TEST)==gq.signal_id); sl@0: sl@0: sl@0: g_assert(g_signal_handler_find(G_OBJECT(test1), G_SIGNAL_RUN_LAST,g_signal_lookup("test-signal2",G_TYPE_TEST),NULL,NULL,NULL,NULL)==2); sl@0: sl@0: sl@0: notifynum=g_signal_handlers_block_matched(G_OBJECT(test1),G_SIGNAL_MATCH_FUNC,g_signal_lookup("test-signal2",G_TYPE_TEST),NULL,NULL,(gpointer)G_CALLBACK(notify),NULL); sl@0: handlernum=g_signal_handlers_unblock_matched(G_OBJECT(test1),G_SIGNAL_MATCH_FUNC,g_signal_lookup("test-signal2",G_TYPE_TEST),NULL,NULL,(gpointer)G_CALLBACK(notify),NULL); sl@0: g_assert(notifynum==handlernum); sl@0: sl@0: #endif /*MULTITHREAD*/ sl@0: sl@0: #ifdef VERBOSE sl@0: g_printf ("\nsignals.c: Completed all tests\n"); sl@0: #endif sl@0: sl@0: #endif /*SYMBIAN*/ sl@0: sl@0: sl@0: sl@0: #if SYMBIAN sl@0: testResultXml("signals-multithread"); sl@0: #endif /* EMULATOR */ sl@0: sl@0: return 0; sl@0: }