void (*test_signal1) (GTest * test, gint an_int);
void (*test_signal2) (GTest * test, gint an_int);
+ gchar * (*test_signal3) (GTest * test, gint an_int);
};
static GType my_test_get_type (void);
{
TEST_SIGNAL1,
TEST_SIGNAL2,
+ TEST_SIGNAL3,
/* add more above */
LAST_SIGNAL
};
static void my_test_dispose (GObject * object);
static void signal2_handler (GTest * test, gint anint);
+static gchar * signal3_handler (GTest * test, gint anint);
static void my_test_set_property (GObject * object, guint prop_id,
const GValue * value, GParamSpec * pspec);
g_signal_new ("test-signal2", G_TYPE_FROM_CLASS (klass),
G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GTestClass, test_signal2), NULL,
NULL, g_cclosure_marshal_VOID__INT, G_TYPE_NONE, 1, G_TYPE_INT);
+ my_test_signals[TEST_SIGNAL3] =
+ g_signal_new ("test-signal3", G_TYPE_FROM_CLASS (klass),
+ G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (GTestClass, test_signal3), NULL,
+ NULL, g_cclosure_marshal_generic, G_TYPE_STRING, 1, G_TYPE_INT);
g_object_class_install_property (G_OBJECT_CLASS (klass), ARG_TEST_PROP,
g_param_spec_int ("test-prop", "Test Prop", "Test property",
0, 1, 0, G_PARAM_READWRITE));
klass->test_signal2 = signal2_handler;
+ klass->test_signal3 = signal3_handler;
}
static void
g_signal_emit (G_OBJECT (test), my_test_signals[TEST_SIGNAL2], 0, 0);
}
+static gchar *
+signal3_handler (GTest * test, gint anint)
+{
+ return g_strdup ("test");
+}
+
+static void
+my_test_do_signal3 (GTest * test)
+{
+ gchar *res;
+
+ g_signal_emit (G_OBJECT (test), my_test_signals[TEST_SIGNAL3], 0, 0, &res);
+ g_assert (res);
+ g_free (res);
+}
+
static void
my_test_do_prop (GTest * test)
{
my_test_do_signal2 (test);
if (TESTNUM == 3)
my_test_do_prop (test);
+ if (TESTNUM == 4)
+ my_test_do_signal3 (test);
if ((i++ % 10000) == 0) {
g_print (".");
g_thread_yield(); /* force context switch */