1 /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
4 #include <glib-object.h>
5 #include <gobject/gvaluecollector.h>
9 static gboolean abort_on_error = TRUE;
11 #define ASSERT_VALUE(condition) \
13 g_assert (condition); \
15 g_warn_if_fail (condition); \
18 regress_set_abort_on_error (gboolean in)
25 regress_test_boolean (gboolean in)
31 regress_test_boolean_true (gboolean in)
33 ASSERT_VALUE (in == TRUE);
38 regress_test_boolean_false (gboolean in)
40 ASSERT_VALUE (in == FALSE);
45 regress_test_int8 (gint8 in)
51 regress_test_uint8 (guint8 in)
57 regress_test_int16 (gint16 in)
63 regress_test_uint16 (guint16 in)
69 regress_test_int32 (gint32 in)
75 regress_test_uint32 (guint32 in)
81 regress_test_int64 (gint64 in)
87 regress_test_uint64 (guint64 in)
93 regress_test_short (gshort in)
99 regress_test_ushort (gushort in)
105 regress_test_int (gint in)
111 regress_test_uint (guint in)
117 regress_test_long (glong in)
123 regress_test_ulong (gulong in)
129 regress_test_ssize (gssize in)
135 regress_test_size (gsize in)
141 regress_test_float (gfloat in)
147 regress_test_double (gdouble in)
153 regress_test_unichar (gunichar in)
159 regress_test_timet (time_t in)
165 regress_test_gtype (GType in)
171 regress_test_closure (GClosure *closure)
173 GValue return_value = {0, };
176 g_value_init (&return_value, G_TYPE_INT);
178 g_closure_invoke (closure,
183 ret = g_value_get_int (&return_value);
185 g_value_unset(&return_value);
191 regress_test_closure_one_arg (GClosure *closure, int arg)
193 GValue return_value = {0, };
197 g_value_init (&return_value, G_TYPE_INT);
199 memset (&arguments[0], 0, sizeof (arguments));
200 g_value_init (&arguments[0], G_TYPE_INT);
201 g_value_set_int (&arguments[0], arg);
203 g_closure_invoke (closure,
208 ret = g_value_get_int (&return_value);
210 g_value_unset(&return_value);
211 g_value_unset(&arguments[0]);
217 * regress_test_closure_variant:
218 * @closure: GClosure which takes one GVariant and returns a GVariant
219 * @arg: (transfer none): a GVariant passed as argument to @closure
221 * Return value: (transfer full): the return value of @closure
224 regress_test_closure_variant (GClosure *closure, const GVariant* arg)
226 GValue return_value = {0, };
227 GValue arguments[1] = {{0,} };
229 GVariant *local_arg = (GVariant*)g_memdup(arg, sizeof (GVariant*));
231 g_value_init (&return_value, G_TYPE_VARIANT);
233 g_value_init (&arguments[0], G_TYPE_VARIANT);
234 g_value_set_variant (&arguments[0], local_arg);
236 g_closure_invoke (closure,
241 ret = g_value_get_variant (&return_value);
244 g_value_unset (&return_value);
245 g_value_unset (&arguments[0]);
251 * regress_test_value_arg:
252 * @v: (transfer none): a GValue expected to contain an int
254 * Return value: the int contained in the GValue.
257 regress_test_int_value_arg(const GValue *v)
261 i = g_value_get_int (v);
268 * regress_test_value_return:
271 * Return value: (transfer none): the int wrapped in a GValue.
274 regress_test_value_return(int i)
276 memset(&value, '\0', sizeof(GValue));
278 g_value_init (&value, G_TYPE_INT);
279 g_value_set_int (&value, i);
284 /************************************************************************/
285 /* foreign structs */
288 * regress_test_cairo_context_full_return:
290 * Returns: (transfer full):
293 regress_test_cairo_context_full_return (void)
295 cairo_surface_t *surface;
296 surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, 10, 10);
297 return cairo_create (surface);
301 * regress_test_cairo_context_none_in:
302 * @context: (transfer none):
305 regress_test_cairo_context_none_in (cairo_t *context)
307 cairo_surface_t *surface = cairo_get_target (context);
309 g_assert (cairo_image_surface_get_format (surface) == CAIRO_FORMAT_ARGB32);
310 g_assert (cairo_image_surface_get_width (surface) == 10);
311 g_assert (cairo_image_surface_get_height (surface) == 10);
316 * regress_test_cairo_surface_none_return:
318 * Returns: (transfer none):
321 regress_test_cairo_surface_none_return (void)
323 static cairo_surface_t *surface;
325 if (surface == NULL) {
326 surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, 10, 10);
333 * regress_test_cairo_surface_full_return:
335 * Returns: (transfer full):
338 regress_test_cairo_surface_full_return (void)
340 return cairo_image_surface_create (CAIRO_FORMAT_ARGB32, 10, 10);
344 * regress_test_cairo_surface_none_in:
345 * @surface: (transfer none):
348 regress_test_cairo_surface_none_in (cairo_surface_t *surface)
350 g_assert (cairo_image_surface_get_format (surface) == CAIRO_FORMAT_ARGB32);
351 g_assert (cairo_image_surface_get_width (surface) == 10);
352 g_assert (cairo_image_surface_get_height (surface) == 10);
356 * regress_test_cairo_surface_full_out:
357 * @surface: (out) (transfer full):
360 regress_test_cairo_surface_full_out (cairo_surface_t **surface)
362 *surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, 10, 10);
366 * regress_test_gvariant_i:
368 * Returns: (transfer none): New variant
371 regress_test_gvariant_i (void)
373 return g_variant_new_int32 (1);
377 * regress_test_gvariant_s:
379 * Returns: (transfer none): New variant
382 regress_test_gvariant_s (void)
384 return g_variant_new_string ("one");
388 * regress_test_gvariant_asv:
390 * Returns: (transfer none): New variant
393 regress_test_gvariant_asv (void)
397 g_variant_builder_init (&b, G_VARIANT_TYPE ("a{sv}"));
399 g_variant_builder_add (&b, "{sv}", "name", g_variant_new_string ("foo"));
400 g_variant_builder_add (&b, "{sv}", "timeout", g_variant_new_int32 (10));
402 return g_variant_builder_end (&b);
406 * regress_test_gvariant_v:
408 * Returns: (transfer none): New variant
411 regress_test_gvariant_v (void)
413 return g_variant_new_variant (g_variant_new_string ("contents"));
417 * regress_test_gvariant_as:
419 * Returns: (transfer none): New variant
422 regress_test_gvariant_as (void)
424 const char *as[] = { "one", "two", "three", NULL };
426 return g_variant_new_strv (as, -1);
429 /************************************************************************/
431 /* insert BLACK HEART SUIT to ensure UTF-8 doesn't get mangled */
432 static const char utf8_const[] = "const \xe2\x99\xa5 utf8";
433 static const char utf8_nonconst[] = "nonconst \xe2\x99\xa5 utf8";
436 * regress_test_utf8_const_return:
438 * Return value: UTF-8 string
441 regress_test_utf8_const_return (void)
443 /* transfer mode none */
448 * regress_test_utf8_nonconst_return:
450 * Return value: (transfer full): UTF-8 string
453 regress_test_utf8_nonconst_return (void)
455 return g_strdup (utf8_nonconst);
459 * regress_test_utf8_const_in:
463 regress_test_utf8_const_in (const char *in)
465 /* transfer mode none */
466 g_assert (strcmp (in, utf8_const) == 0);
470 * regress_test_utf8_out:
471 * @out: (out) (transfer full):
474 regress_test_utf8_out (char **out)
476 /* out parameter, transfer mode full */
477 *out = g_strdup (utf8_nonconst);
481 * regress_test_utf8_inout:
482 * @inout: (inout) (transfer full):
485 regress_test_utf8_inout (char **inout)
487 /* inout parameter, transfer mode full */
488 g_assert (strcmp (*inout, utf8_const) == 0);
489 *inout = g_strdup (utf8_nonconst);
493 * regress_test_filename_return:
495 * Return value: (element-type filename) (transfer full): list of strings
498 regress_test_filename_return (void)
500 GSList *filenames = NULL;
501 filenames = g_slist_prepend (filenames, g_filename_from_utf8("/etc/fstab", -1, NULL, NULL, NULL));
502 filenames = g_slist_prepend (filenames, g_filename_from_utf8("åäö", -1, NULL, NULL, NULL));
506 /* in arguments after out arguments */
509 * regress_test_int_out_utf8:
514 regress_test_int_out_utf8 (int *length, const char *in)
516 *length = g_utf8_strlen(in, -1);
520 /* multiple output arguments */
523 * regress_test_multi_double_args:
529 regress_test_multi_double_args (gdouble in, gdouble *one, gdouble *two)
536 * regress_test_utf8_out_out:
537 * @out0: (out) (transfer full): a copy of "first"
538 * @out1: (out) (transfer full): a copy of "second"
541 regress_test_utf8_out_out (char **out0, char **out1)
543 *out0 = g_strdup ("first");
544 *out1 = g_strdup ("second");
548 * regress_test_utf8_out_nonconst_return:
549 * @out: (out) (transfer full): a copy of "second"
551 * Returns: (transfer full): a copy of "first"
554 regress_test_utf8_out_nonconst_return (char **out)
556 *out = g_strdup ("second");
557 return g_strdup ("first");
561 * regress_test_utf8_null_in:
565 regress_test_utf8_null_in (char *in)
567 g_assert (in == NULL);
571 * regress_test_utf8_null_out:
572 * @char_out: (allow-none) (out):
574 void regress_test_utf8_null_out (char **char_out)
580 /* non-basic-types */
582 static const char *test_sequence[] = {"1", "2", "3"};
587 * regress_test_array_int_in:
589 * @ints: (array length=n_ints): List of ints
592 regress_test_array_int_in (int n_ints, int *ints)
595 for (i = 0; i < n_ints; i++)
601 * regress_test_array_int_out:
602 * @n_ints: (out): the length of @ints
603 * @ints: (out) (array length=n_ints) (transfer full): a list of 5 integers, from 0 to 4 in consecutive order
606 regress_test_array_int_out (int *n_ints, int **ints)
610 *ints = g_malloc0(sizeof(**ints) * *n_ints);
611 for (i = 1; i < *n_ints; i++)
612 (*ints)[i] = (*ints)[i-1] + 1;
616 * regress_test_array_int_inout:
617 * @n_ints: (inout): the length of @ints
618 * @ints: (inout) (array length=n_ints) (transfer full): a list of integers whose items will be increased by 1, except the first that will be dropped
621 regress_test_array_int_inout (int *n_ints, int **ints)
629 new_ints = g_malloc(sizeof(**ints) * *n_ints);
630 for (i = 0; i < *n_ints; i++)
631 new_ints[i] = (*ints)[i + 1] + 1;
637 * regress_test_array_gint8_in:
639 * @ints: (array length=n_ints): List of ints
642 regress_test_array_gint8_in (int n_ints, gint8 *ints)
645 for (i = 0; i < n_ints; i++)
651 * regress_test_array_gint16_in:
653 * @ints: (array length=n_ints): List of ints
656 regress_test_array_gint16_in (int n_ints, gint16 *ints)
659 for (i = 0; i < n_ints; i++)
665 * regress_test_array_gint32_in:
667 * @ints: (array length=n_ints): List of ints
670 regress_test_array_gint32_in (int n_ints, gint32 *ints)
674 for (i = 0; i < n_ints; i++)
680 * regress_test_array_gint64_in:
682 * @ints: (array length=n_ints): List of ints
685 regress_test_array_gint64_in (int n_ints, gint64 *ints)
689 for (i = 0; i < n_ints; i++)
695 * regress_test_strv_in:
696 * @arr: (array zero-terminated=1) (transfer none):
699 regress_test_strv_in (char **arr)
701 if (g_strv_length (arr) != 3)
703 if (strcmp (arr[0], "1") != 0)
705 if (strcmp (arr[1], "2") != 0)
707 if (strcmp (arr[2], "3") != 0)
713 * regress_test_array_gtype_in:
715 * @types: (array length=n_types): List of types
717 * Return value: (transfer full): string representation of provided types
720 regress_test_array_gtype_in (int n_types, GType *types)
725 string = g_string_new ("[");
726 for (i = 0; i < n_types; i++)
728 g_string_append (string, g_type_name (types[i]));
729 g_string_append_c (string, ',');
731 g_string_append_c (string, ']');
732 return g_string_free (string, FALSE);
736 * regress_test_strv_out:
738 * Returns: (transfer full):
741 regress_test_strv_out (void)
745 char **ret = g_new (char *, n);
746 ret[i++] = g_strdup ("thanks");
747 ret[i++] = g_strdup ("for");
748 ret[i++] = g_strdup ("all");
749 ret[i++] = g_strdup ("the");
750 ret[i++] = g_strdup ("fish");
757 * regress_test_strv_out_container:
759 * Return value: (array zero-terminated=1) (transfer container):
762 regress_test_strv_out_container (void)
764 char **ret = g_new (char *, 4);
773 * regress_test_strv_outarg:
774 * @retp: (array zero-terminated=1) (out) (transfer container):
777 regress_test_strv_outarg (char ***retp)
779 char **ret = g_new (char *, 4);
788 * regress_test_array_fixed_size_int_in:
789 * @ints: (array fixed-size=5): a list of 5 integers
791 * Returns: the sum of the items in @ints
794 regress_test_array_fixed_size_int_in (int *ints)
797 for (i = 0; i < 5; i++)
803 * regress_test_array_fixed_size_int_out:
804 * @ints: (out) (array fixed-size=5) (transfer full): a list of 5 integers ranging from 0 to 4
807 regress_test_array_fixed_size_int_out (int **ints)
810 *ints = g_malloc0(sizeof(**ints) * 5);
811 for (i = 1; i < 5; i++)
812 (*ints)[i] = (*ints)[i-1] + 1;
816 * regress_test_array_fixed_size_int_return:
818 * Returns: (array fixed-size=5) (transfer full): a list of 5 integers ranging from 0 to 4
821 regress_test_array_fixed_size_int_return (void)
824 ints = g_malloc0(sizeof(*ints) * 5);
825 for (i = 1; i < 5; i++)
826 ints[i] = ints[i-1] + 1;
831 * regress_test_strv_out_c:
833 * Returns: (transfer none):
836 regress_test_strv_out_c (void)
838 static char **ret = NULL;
841 ret = regress_test_strv_out ();
843 return (const char * const *) ret;
847 * regress_test_array_int_full_out:
848 * @len: length of the returned array.
850 * Returns: (array length=len) (transfer full): a new array of integers.
853 regress_test_array_int_full_out(int *len)
857 result = g_malloc0(sizeof(*result) * (*len));
858 for (i=1; i < (*len); i++)
859 result[i] = result[i-1] + 1;
864 * regress_test_array_int_none_out:
865 * @len: length of the returned array.
867 * Returns: (array length=len) (transfer none): a static array of integers.
870 regress_test_array_int_none_out(int *len)
872 static int result[5] = { 1, 2, 3, 4, 5 };
878 * regress_test_array_int_null_in:
879 * @arr: (array length=len) (allow-none):
883 regress_test_array_int_null_in (int *arr, int len)
885 g_assert (arr == NULL);
889 * regress_test_array_int_null_out:
890 * @arr: (out) (array length=len) (allow-none):
891 * @len: (out) : length
894 regress_test_array_int_null_out (int **arr, int *len)
902 /************************************************************************/
905 static /*const*/ GList *
906 regress_test_sequence_list()
908 static GList *list = NULL;
911 for (i = 0; i < G_N_ELEMENTS(test_sequence); ++i) {
912 list = g_list_prepend (list, (gpointer)test_sequence[i]);
914 list = g_list_reverse (list);
920 * regress_test_glist_nothing_return:
922 * Return value: (element-type utf8) (transfer none):
925 regress_test_glist_nothing_return (void)
927 return regress_test_sequence_list ();
931 * regress_test_glist_nothing_return2:
933 * Return value: (element-type utf8) (transfer none):
936 regress_test_glist_nothing_return2 (void)
938 return regress_test_sequence_list ();
942 * regress_test_glist_container_return:
944 * Return value: (element-type utf8) (transfer container):
947 regress_test_glist_container_return (void)
949 return g_list_copy (regress_test_sequence_list ());
953 * regress_test_glist_everything_return:
955 * Return value: (element-type utf8) (transfer full):
958 regress_test_glist_everything_return (void)
963 list = g_list_copy (regress_test_sequence_list ());
964 for (l = list; l != NULL; l = l->next)
965 l->data = g_strdup (l->data);
970 regress_assert_test_sequence_list (const GList *in)
975 for (i = 0, l = in; l != NULL; ++i, l = l->next) {
976 g_assert (i < G_N_ELEMENTS(test_sequence));
977 g_assert (strcmp (l->data, test_sequence[i]) == 0);
979 g_assert (i == G_N_ELEMENTS(test_sequence));
983 * regress_test_glist_nothing_in:
984 * @in: (element-type utf8):
987 regress_test_glist_nothing_in (const GList *in)
989 regress_assert_test_sequence_list (in);
993 * regress_test_glist_nothing_in2:
994 * @in: (element-type utf8):
997 regress_test_glist_nothing_in2 (GList *in)
999 regress_assert_test_sequence_list (in);
1003 * regress_test_glist_null_in:
1004 * @in: (element-type utf8) (allow-none):
1007 regress_test_glist_null_in (GSList *in)
1009 g_assert (in == NULL);
1013 * regress_test_glist_null_out:
1014 * @out_list: (out) (element-type utf8) (allow-none):
1017 regress_test_glist_null_out (GSList **out_list)
1023 /************************************************************************/
1026 static /*const*/ GSList *
1027 regress_test_sequence_slist()
1029 static GSList *list = NULL;
1032 for (i = 0; i < G_N_ELEMENTS(test_sequence); ++i) {
1033 list = g_slist_prepend (list, (gpointer)test_sequence[i]);
1035 list = g_slist_reverse (list);
1041 * regress_test_gslist_nothing_return:
1043 * Return value: (element-type utf8) (transfer none):
1046 regress_test_gslist_nothing_return (void)
1048 return regress_test_sequence_slist ();
1052 * regress_test_gslist_nothing_return2:
1054 * Return value: (element-type utf8) (transfer none):
1057 regress_test_gslist_nothing_return2 (void)
1059 return regress_test_sequence_slist ();
1063 * regress_test_gslist_container_return:
1065 * Return value: (element-type utf8) (transfer container):
1068 regress_test_gslist_container_return (void)
1070 return g_slist_copy (regress_test_sequence_slist ());
1074 * regress_test_gslist_everything_return:
1076 * Return value: (element-type utf8) (transfer full):
1079 regress_test_gslist_everything_return (void)
1084 list = g_slist_copy (regress_test_sequence_slist ());
1085 for (l = list; l != NULL; l = l->next)
1086 l->data = g_strdup (l->data);
1091 regress_assert_test_sequence_slist (const GSList *in)
1096 for (i = 0, l = in; l != NULL; ++i, l = l->next) {
1097 g_assert (i < G_N_ELEMENTS(test_sequence));
1098 g_assert (strcmp (l->data, test_sequence[i]) == 0);
1100 g_assert (i == G_N_ELEMENTS(test_sequence));
1104 * regress_test_gslist_nothing_in:
1105 * @in: (element-type utf8):
1108 regress_test_gslist_nothing_in (const GSList *in)
1110 regress_assert_test_sequence_slist (in);
1114 * regress_test_gslist_nothing_in2:
1115 * @in: (element-type utf8):
1118 regress_test_gslist_nothing_in2 (GSList *in)
1120 regress_assert_test_sequence_slist (in);
1124 * regress_test_gslist_null_in:
1125 * @in: (element-type utf8) (allow-none):
1128 regress_test_gslist_null_in (GSList *in)
1130 g_assert (in == NULL);
1134 * regress_test_gslist_null_out:
1135 * @out_list: (out) (element-type utf8) (allow-none):
1138 regress_test_gslist_null_out (GSList **out_list)
1143 /************************************************************************/
1146 static char *table_data[3][2] = {
1147 { "foo", "bar" }, { "baz", "bat" }, { "qux", "quux" }
1151 regress_test_table_ghash_new_container()
1155 hash = g_hash_table_new(g_str_hash, g_str_equal);
1157 g_hash_table_insert(hash, table_data[i][0], table_data[i][1]);
1162 regress_test_table_ghash_new_full()
1166 hash = g_hash_table_new_full(g_str_hash, g_str_equal, g_free, g_free);
1168 g_hash_table_insert(hash,
1169 g_strdup(table_data[i][0]),
1170 g_strdup(table_data[i][1]));
1174 static /*const*/ GHashTable *
1175 regress_test_table_ghash_const()
1177 static GHashTable *hash = NULL;
1179 hash = regress_test_table_ghash_new_container();
1185 * regress_test_ghash_null_return:
1187 * Return value: (element-type utf8 utf8) (transfer none) (allow-none):
1190 regress_test_ghash_null_return (void)
1196 * regress_test_ghash_nothing_return:
1198 * Return value: (element-type utf8 utf8) (transfer none):
1201 regress_test_ghash_nothing_return (void)
1203 return regress_test_table_ghash_const ();
1207 * regress_test_ghash_nothing_return2:
1209 * Return value: (element-type utf8 utf8) (transfer none):
1212 regress_test_ghash_nothing_return2 (void)
1214 return regress_test_table_ghash_const ();
1218 g_value_new (GType type)
1220 GValue *value = g_slice_new0(GValue);
1221 g_value_init(value, type);
1226 g_value_free (GValue *value)
1228 g_value_unset(value);
1229 g_slice_free(GValue, value);
1232 static const gchar *string_array[] = {
1240 * regress_test_ghash_gvalue_return:
1242 * Return value: (element-type utf8 GValue) (transfer none):
1245 regress_test_ghash_gvalue_return (void)
1249 hash = g_hash_table_new_full(g_str_hash, g_str_equal,
1250 g_free, (GDestroyNotify)g_value_free);
1252 value = g_value_new(G_TYPE_INT);
1253 g_value_set_int(value, 12);
1254 g_hash_table_insert(hash, g_strdup("integer"), value);
1256 value = g_value_new(G_TYPE_BOOLEAN);
1257 g_value_set_boolean(value, TRUE);
1258 g_hash_table_insert(hash, g_strdup("boolean"), value);
1260 value = g_value_new(G_TYPE_STRING);
1261 g_value_set_string(value, "some text");
1262 g_hash_table_insert(hash, g_strdup("string"), value);
1264 value = g_value_new(G_TYPE_STRV);
1265 g_value_set_boxed(value, string_array);
1266 g_hash_table_insert(hash, g_strdup("strings"), value);
1272 * regress_test_ghash_gvalue_in:
1273 * @hash: (element-type utf8 GValue): the hash table returned by
1274 * regress_test_ghash_gvalue_return().
1277 regress_test_ghash_gvalue_in (GHashTable *hash)
1280 const gchar **strings;
1283 g_assert(hash != NULL);
1285 value = g_hash_table_lookup(hash, "integer");
1286 g_assert(value != NULL);
1287 g_assert(G_VALUE_HOLDS_INT(value));
1288 g_assert(g_value_get_int(value) == 12);
1290 value = g_hash_table_lookup(hash, "boolean");
1291 g_assert(value != NULL);
1292 g_assert(G_VALUE_HOLDS_BOOLEAN(value));
1293 g_assert(g_value_get_boolean(value) == TRUE);
1295 value = g_hash_table_lookup(hash, "string");
1296 g_assert(value != NULL);
1297 g_assert(G_VALUE_HOLDS_STRING(value));
1298 g_assert(strcmp(g_value_get_string(value), "some text") == 0);
1300 value = g_hash_table_lookup(hash, "strings");
1301 g_assert(value != NULL);
1302 g_assert(G_VALUE_HOLDS(value, G_TYPE_STRV));
1303 strings = g_value_get_boxed(value);
1304 g_assert(strings != NULL);
1305 for (i = 0; string_array[i] != NULL; i++)
1306 g_assert(strcmp(strings[i], string_array[i]) == 0);
1310 * regress_test_ghash_container_return:
1312 * Return value: (element-type utf8 utf8) (transfer container):
1315 regress_test_ghash_container_return (void)
1317 return regress_test_table_ghash_new_container ();
1321 * regress_test_ghash_everything_return:
1323 * Return value: (element-type utf8 utf8) (transfer full):
1326 regress_test_ghash_everything_return (void)
1328 return regress_test_table_ghash_new_full ();
1332 assert_test_table_ghash (const GHashTable *in)
1334 GHashTable *h = regress_test_table_ghash_const();
1335 GHashTableIter iter;
1336 gpointer key, value;
1338 g_assert(g_hash_table_size(h) ==
1339 g_hash_table_size((GHashTable*)in));
1341 g_hash_table_iter_init(&iter, (GHashTable*)in);
1342 while (g_hash_table_iter_next (&iter, &key, &value))
1343 g_assert( strcmp(g_hash_table_lookup(h, (char*)key), (char*)value) == 0);
1347 * regress_test_ghash_null_in:
1348 * @in: (element-type utf8 utf8) (allow-none):
1351 regress_test_ghash_null_in (const GHashTable *in)
1353 g_assert (in == NULL);
1357 * regress_test_ghash_null_out:
1358 * @out: (element-type utf8 utf8) (allow-none) (out):
1361 regress_test_ghash_null_out (const GHashTable **out)
1367 * regress_test_ghash_nothing_in:
1368 * @in: (element-type utf8 utf8):
1371 regress_test_ghash_nothing_in (const GHashTable *in)
1373 assert_test_table_ghash (in);
1377 * regress_test_ghash_nothing_in2:
1378 * @in: (element-type utf8 utf8):
1381 regress_test_ghash_nothing_in2 (GHashTable *in)
1383 assert_test_table_ghash (in);
1386 /* Nested collection types */
1389 * regress_test_ghash_nested_everything_return:
1391 * Specify nested parameterized types directly with the (type ) annotation.
1393 * Return value: (type GLib.HashTable<utf8,GLib.HashTable<utf8,utf8>>) (transfer full):
1396 regress_test_ghash_nested_everything_return (void)
1399 hash = g_hash_table_new_full(g_str_hash, g_str_equal, g_free,
1400 (void (*) (gpointer)) g_hash_table_destroy);
1401 g_hash_table_insert(hash, g_strdup("wibble"), regress_test_table_ghash_new_full());
1406 * regress_test_ghash_nested_everything_return2:
1408 * Another way of specifying nested parameterized types: using the
1409 * element-type annotation.
1411 * Return value: (element-type utf8 GLib.HashTable<utf8,utf8>) (transfer full):
1414 regress_test_ghash_nested_everything_return2 (void)
1416 return regress_test_ghash_nested_everything_return();
1419 /************************************************************************/
1422 * regress_test_garray_container_return:
1424 * Returns: (transfer container) (type GLib.PtrArray) (element-type utf8):
1427 regress_test_garray_container_return (void)
1431 array = g_ptr_array_new_with_free_func (g_free);
1432 g_ptr_array_add (array, g_strdup ("regress"));
1438 * regress_test_garray_full_return:
1440 * Returns: (transfer full) (type GLib.PtrArray) (element-type utf8):
1443 regress_test_garray_full_return (void)
1447 array = g_ptr_array_new ();
1448 g_ptr_array_add (array, g_strdup ("regress"));
1453 /************************************************************************/
1460 * NUM_REGRESS_FOO: (skip)
1462 * num of elements in RegressFoo
1466 regress_test_enum_get_type (void)
1468 static GType etype = 0;
1469 if (G_UNLIKELY(etype == 0)) {
1470 static const GEnumValue values[] = {
1471 { REGRESS_TEST_VALUE1, "REGRESS_TEST_VALUE1", "value1" },
1472 { REGRESS_TEST_VALUE2, "REGRESS_TEST_VALUE2", "value2" },
1473 { REGRESS_TEST_VALUE3, "REGRESS_TEST_VALUE3", "value3" },
1474 { REGRESS_TEST_VALUE4, "REGRESS_TEST_VALUE4", "value4" },
1477 etype = g_enum_register_static (g_intern_static_string ("RegressTestEnum"), values);
1484 regress_test_enum_unsigned_get_type (void)
1486 static GType etype = 0;
1487 if (G_UNLIKELY(etype == 0)) {
1488 static const GEnumValue values[] = {
1489 { REGRESS_TEST_UNSIGNED_VALUE1, "REGRESS_TEST_UNSIGNED_VALUE1", "value1" },
1490 { REGRESS_TEST_UNSIGNED_VALUE2, "REGRESS_TEST_UNSIGNED_VALUE2", "value2" },
1493 etype = g_enum_register_static (g_intern_static_string ("RegressTestEnumUnsigned"), values);
1500 regress_test_flags_get_type (void)
1502 static GType etype = 0;
1503 if (G_UNLIKELY(etype == 0)) {
1504 static const GFlagsValue values[] = {
1505 { REGRESS_TEST_FLAG1, "TEST_FLAG1", "flag1" },
1506 { REGRESS_TEST_FLAG2, "TEST_FLAG2", "flag2" },
1507 { REGRESS_TEST_FLAG3, "TEST_FLAG3", "flag3" },
1510 etype = g_flags_register_static (g_intern_static_string ("RegressTestFlags"), values);
1517 regress_test_enum_param(RegressTestEnum e)
1522 ec = g_type_class_ref (regress_test_enum_get_type ());
1523 ev = g_enum_get_value (ec, e);
1524 g_type_class_unref (ec);
1526 return ev->value_nick;
1530 regress_test_unsigned_enum_param(RegressTestEnumUnsigned e)
1535 ec = g_type_class_ref (regress_test_enum_unsigned_get_type ());
1536 ev = g_enum_get_value (ec, e);
1537 g_type_class_unref (ec);
1539 return ev->value_nick;
1543 * regress_global_get_flags_out:
1544 * @v: (out): A flags value
1548 regress_global_get_flags_out (RegressTestFlags *v)
1550 *v = REGRESS_TEST_FLAG1 | REGRESS_TEST_FLAG3;
1556 * regress_test_struct_a_clone:
1558 * @a_out: (out caller-allocates): the cloned structure
1560 * Make a copy of a RegressTestStructA
1563 regress_test_struct_a_clone (RegressTestStructA *a,
1564 RegressTestStructA *a_out)
1570 * regress_test_struct_b_clone:
1572 * @b_out: (out): the cloned structure
1574 * Make a copy of a RegressTestStructB
1577 regress_test_struct_b_clone (RegressTestStructB *b,
1578 RegressTestStructB *b_out)
1583 /* plain-old-data boxed types */
1585 RegressTestSimpleBoxedA *
1586 regress_test_simple_boxed_a_copy (RegressTestSimpleBoxedA *a)
1588 RegressTestSimpleBoxedA *new_a = g_slice_new (RegressTestSimpleBoxedA);
1596 regress_test_simple_boxed_a_free (RegressTestSimpleBoxedA *a)
1598 g_slice_free (RegressTestSimpleBoxedA, a);
1602 regress_test_simple_boxed_a_get_gtype (void)
1604 static GType our_type = 0;
1607 our_type = g_boxed_type_register_static (g_intern_static_string ("RegressTestSimpleBoxedA"),
1608 (GBoxedCopyFunc)regress_test_simple_boxed_a_copy,
1609 (GBoxedFreeFunc)regress_test_simple_boxed_a_free);
1613 RegressTestSimpleBoxedB *
1614 regress_test_simple_boxed_b_copy (RegressTestSimpleBoxedB *b)
1616 RegressTestSimpleBoxedB *new_b = g_slice_new (RegressTestSimpleBoxedB);
1624 regress_test_simple_boxed_a_equals (RegressTestSimpleBoxedA *a,
1625 RegressTestSimpleBoxedA *other_a)
1627 return (a->some_int == other_a->some_int &&
1628 a->some_int8 == other_a->some_int8 &&
1629 a->some_double == other_a->some_double);
1632 const RegressTestSimpleBoxedA*
1633 regress_test_simple_boxed_a_const_return (void)
1635 static RegressTestSimpleBoxedA simple_a = {
1643 regress_test_simple_boxed_b_free (RegressTestSimpleBoxedB *a)
1645 g_slice_free (RegressTestSimpleBoxedB, a);
1649 regress_test_simple_boxed_b_get_type (void)
1651 static GType our_type = 0;
1654 our_type = g_boxed_type_register_static (g_intern_static_string ("RegressTestSimpleBoxedB"),
1655 (GBoxedCopyFunc)regress_test_simple_boxed_b_copy,
1656 (GBoxedFreeFunc)regress_test_simple_boxed_b_free);
1662 struct _RegressTestBoxedPrivate
1668 * regress_test_boxed_new:
1670 * Returns: (transfer full):
1673 regress_test_boxed_new (void)
1675 RegressTestBoxed *boxed = g_slice_new0(RegressTestBoxed);
1676 boxed->priv = g_slice_new0(RegressTestBoxedPrivate);
1677 boxed->priv->magic = 0xdeadbeef;
1683 * regress_test_boxed_new_alternative_constructor1:
1685 * Returns: (transfer full):
1688 regress_test_boxed_new_alternative_constructor1 (int i)
1690 RegressTestBoxed *boxed = g_slice_new0(RegressTestBoxed);
1691 boxed->priv = g_slice_new0(RegressTestBoxedPrivate);
1692 boxed->priv->magic = 0xdeadbeef;
1693 boxed->some_int8 = i;
1699 * regress_test_boxed_new_alternative_constructor2:
1701 * Returns: (transfer full):
1704 regress_test_boxed_new_alternative_constructor2 (int i, int j)
1706 RegressTestBoxed *boxed = g_slice_new0(RegressTestBoxed);
1707 boxed->priv = g_slice_new0(RegressTestBoxedPrivate);
1708 boxed->priv->magic = 0xdeadbeef;
1709 boxed->some_int8 = i + j;
1715 * regress_test_boxed_new_alternative_constructor3:
1717 * Returns: (transfer full):
1720 regress_test_boxed_new_alternative_constructor3 (char *s)
1722 RegressTestBoxed *boxed = g_slice_new0(RegressTestBoxed);
1723 boxed->priv = g_slice_new0(RegressTestBoxedPrivate);
1724 boxed->priv->magic = 0xdeadbeef;
1725 boxed->some_int8 = atoi(s);
1731 * regress_test_boxed_copy:
1733 * Returns: (transfer full):
1736 regress_test_boxed_copy (RegressTestBoxed *boxed)
1738 RegressTestBoxed *new_boxed = regress_test_boxed_new();
1739 RegressTestBoxedPrivate *save;
1741 save = new_boxed->priv;
1742 *new_boxed = *boxed;
1743 new_boxed->priv = save;
1749 regress_test_boxed_equals (RegressTestBoxed *boxed,
1750 RegressTestBoxed *other)
1752 return (other->some_int8 == boxed->some_int8 &&
1753 regress_test_simple_boxed_a_equals(&other->nested_a, &boxed->nested_a));
1757 regress_test_boxed_free (RegressTestBoxed *boxed)
1759 g_assert (boxed->priv->magic == 0xdeadbeef);
1761 g_slice_free (RegressTestBoxedPrivate, boxed->priv);
1762 g_slice_free (RegressTestBoxed, boxed);
1766 regress_test_boxed_get_type (void)
1768 static GType our_type = 0;
1771 our_type = g_boxed_type_register_static (g_intern_static_string ("RegressTestBoxed"),
1772 (GBoxedCopyFunc)regress_test_boxed_copy,
1773 (GBoxedFreeFunc)regress_test_boxed_free);
1778 regress_test_boxed_b_new (gint8 some_int8, glong some_long)
1780 RegressTestBoxedB *boxed;
1782 boxed = g_slice_new (RegressTestBoxedB);
1783 boxed->some_int8 = some_int8;
1784 boxed->some_long = some_long;
1790 regress_test_boxed_b_copy (RegressTestBoxedB *boxed)
1792 return regress_test_boxed_b_new (boxed->some_int8, boxed->some_long);
1796 regress_test_boxed_b_free (RegressTestBoxedB *boxed)
1798 g_slice_free (RegressTestBoxedB, boxed);
1801 G_DEFINE_BOXED_TYPE(RegressTestBoxedB,
1802 regress_test_boxed_b,
1803 regress_test_boxed_b_copy,
1804 regress_test_boxed_b_free);
1806 G_DEFINE_TYPE(RegressTestObj, regress_test_obj, G_TYPE_OBJECT);
1810 PROP_TEST_OBJ_BARE = 1,
1811 PROP_TEST_OBJ_BOXED,
1812 PROP_TEST_OBJ_HASH_TABLE,
1814 PROP_TEST_OBJ_HASH_TABLE_OLD,
1815 PROP_TEST_OBJ_LIST_OLD,
1817 PROP_TEST_OBJ_FLOAT,
1818 PROP_TEST_OBJ_DOUBLE,
1819 PROP_TEST_OBJ_STRING,
1824 regress_test_obj_set_property (GObject *object,
1826 const GValue *value,
1829 RegressTestObj *self = REGRESS_TEST_OBJECT (object);
1832 switch (property_id)
1834 case PROP_TEST_OBJ_BARE:
1835 regress_test_obj_set_bare (self, g_value_get_object (value));
1838 case PROP_TEST_OBJ_BOXED:
1840 regress_test_boxed_free (self->boxed);
1841 self->boxed = g_value_dup_boxed (value);
1844 case PROP_TEST_OBJ_HASH_TABLE:
1845 case PROP_TEST_OBJ_HASH_TABLE_OLD:
1846 if (self->hash_table)
1847 g_hash_table_unref (self->hash_table);
1848 self->hash_table = g_hash_table_ref (g_value_get_boxed (value));
1851 case PROP_TEST_OBJ_LIST:
1852 case PROP_TEST_OBJ_LIST_OLD:
1853 if (self->list != NULL)
1855 for (list = self->list; list != NULL; list = g_list_next (list))
1856 g_free (list->data);
1857 g_list_free (self->list);
1860 for (list = g_value_get_pointer (value); list != NULL; list = g_list_next (list))
1861 self->list = g_list_append (self->list, g_strdup (list->data));
1864 case PROP_TEST_OBJ_INT:
1865 self->some_int8 = g_value_get_int (value);
1868 case PROP_TEST_OBJ_FLOAT:
1869 self->some_float = g_value_get_float (value);
1872 case PROP_TEST_OBJ_DOUBLE:
1873 self->some_double = g_value_get_double (value);
1876 case PROP_TEST_OBJ_STRING:
1877 self->string = g_value_dup_string (value);
1880 case PROP_TEST_OBJ_GTYPE:
1881 self->gtype = g_value_get_gtype (value);
1885 /* We don't have any other property... */
1886 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
1892 regress_test_obj_get_property (GObject *object,
1897 RegressTestObj *self = REGRESS_TEST_OBJECT (object);
1899 switch (property_id)
1901 case PROP_TEST_OBJ_BARE:
1902 g_value_set_object (value, self->bare);
1905 case PROP_TEST_OBJ_BOXED:
1906 g_value_set_boxed (value, self->boxed);
1909 case PROP_TEST_OBJ_HASH_TABLE:
1910 case PROP_TEST_OBJ_HASH_TABLE_OLD:
1911 if (self->hash_table != NULL)
1912 g_hash_table_ref (self->hash_table);
1913 g_value_set_boxed (value, self->hash_table);
1916 case PROP_TEST_OBJ_LIST:
1917 case PROP_TEST_OBJ_LIST_OLD:
1918 g_value_set_pointer (value, self->list);
1921 case PROP_TEST_OBJ_INT:
1922 g_value_set_int (value, self->some_int8);
1925 case PROP_TEST_OBJ_FLOAT:
1926 g_value_set_float (value, self->some_float);
1929 case PROP_TEST_OBJ_DOUBLE:
1930 g_value_set_double (value, self->some_double);
1933 case PROP_TEST_OBJ_STRING:
1934 g_value_set_string (value, self->string);
1937 case PROP_TEST_OBJ_GTYPE:
1938 g_value_set_gtype (value, self->gtype);
1942 /* We don't have any other property... */
1943 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
1949 regress_test_obj_dispose (GObject *gobject)
1951 RegressTestObj *self = REGRESS_TEST_OBJECT (gobject);
1955 g_object_unref (self->bare);
1962 regress_test_boxed_free (self->boxed);
1966 /* Chain up to the parent class */
1967 G_OBJECT_CLASS (regress_test_obj_parent_class)->dispose (gobject);
1971 regress_test_obj_default_matrix (RegressTestObj *obj, const char *somestr)
1977 REGRESS_TEST_OBJ_SIGNAL_SIG_NEW_WITH_ARRAY_PROP,
1978 REGRESS_TEST_OBJ_SIGNAL_SIG_WITH_HASH_PROP,
1979 REGRESS_TEST_OBJ_SIGNAL_SIG_WITH_STRV,
1980 REGRESS_TEST_OBJ_SIGNAL_SIG_WITH_OBJ,
1981 REGRESS_TEST_OBJ_SIGNAL_FIRST,
1982 REGRESS_TEST_OBJ_SIGNAL_CLEANUP,
1983 REGRESS_TEST_OBJ_SIGNAL_ALL,
1984 N_REGRESS_TEST_OBJ_SIGNALS
1987 static guint regress_test_obj_signals[N_REGRESS_TEST_OBJ_SIGNALS] = { 0 };
1990 regress_test_obj_class_init (RegressTestObjClass *klass)
1992 GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
1994 GType param_types[1];
1996 klass->test_signal =
1997 g_signal_newv ("test",
1998 G_TYPE_FROM_CLASS (gobject_class),
1999 G_SIGNAL_RUN_LAST | G_SIGNAL_NO_RECURSE | G_SIGNAL_NO_HOOKS,
2001 NULL /* accumulator */,
2002 NULL /* accumulator data */,
2003 g_cclosure_marshal_VOID__VOID,
2004 G_TYPE_NONE /* return_type */,
2006 NULL /* param_types */);
2008 param_types[0] = regress_test_simple_boxed_a_get_gtype() | G_SIGNAL_TYPE_STATIC_SCOPE;
2009 klass->test_signal_with_static_scope_arg =
2010 g_signal_newv ("test-with-static-scope-arg",
2011 G_TYPE_FROM_CLASS (gobject_class),
2012 G_SIGNAL_RUN_LAST | G_SIGNAL_NO_RECURSE | G_SIGNAL_NO_HOOKS,
2014 NULL /* accumulator */,
2015 NULL /* accumulator data */,
2016 g_cclosure_marshal_VOID__BOXED,
2017 G_TYPE_NONE /* return_type */,
2022 * RegressTestObj::sig-with-array-prop:
2024 * @arr: (type GArray) (element-type uint): numbers
2026 * This test signal is like TelepathyGlib's
2027 * TpChannel:: group-members-changed-detailed:
2029 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_SIG_NEW_WITH_ARRAY_PROP] =
2030 g_signal_new ("sig-with-array-prop",
2031 G_TYPE_FROM_CLASS (gobject_class),
2036 g_cclosure_marshal_VOID__BOXED,
2042 * RegressTestObj::sig-with-hash-prop:
2044 * @hash: (element-type utf8 GObject.Value):
2046 * This test signal is like TelepathyGlib's
2047 * TpAccount::status-changed
2049 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_SIG_WITH_HASH_PROP] =
2050 g_signal_new ("sig-with-hash-prop",
2051 G_TYPE_FROM_CLASS (gobject_class),
2056 g_cclosure_marshal_VOID__BOXED,
2062 * RegressTestObj::sig-with-strv:
2066 * Test GStrv as a param.
2068 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_SIG_WITH_STRV] =
2069 g_signal_new ("sig-with-strv",
2070 G_TYPE_FROM_CLASS (gobject_class),
2075 g_cclosure_marshal_VOID__BOXED,
2081 * RegressTestObj::sig-with-obj:
2083 * @obj: (transfer none): A newly created RegressTestObj
2085 * Test transfer none GObject as a param (tests refcounting).
2086 * Use with regress_test_obj_emit_sig_with_obj
2088 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_SIG_WITH_OBJ] =
2089 g_signal_new ("sig-with-obj",
2090 G_TYPE_FROM_CLASS (gobject_class),
2095 g_cclosure_marshal_VOID__OBJECT,
2100 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_FIRST] =
2101 g_signal_new ("first",
2102 G_TYPE_FROM_CLASS (gobject_class),
2107 g_cclosure_marshal_VOID__VOID,
2111 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_CLEANUP] =
2112 g_signal_new ("cleanup",
2113 G_TYPE_FROM_CLASS (gobject_class),
2114 G_SIGNAL_RUN_CLEANUP,
2118 g_cclosure_marshal_VOID__VOID,
2122 regress_test_obj_signals[REGRESS_TEST_OBJ_SIGNAL_ALL] =
2123 g_signal_new ("all",
2124 G_TYPE_FROM_CLASS (gobject_class),
2125 G_SIGNAL_RUN_FIRST | G_SIGNAL_NO_RECURSE | G_SIGNAL_DETAILED | G_SIGNAL_ACTION | G_SIGNAL_NO_HOOKS,
2129 g_cclosure_marshal_VOID__VOID,
2133 gobject_class->set_property = regress_test_obj_set_property;
2134 gobject_class->get_property = regress_test_obj_get_property;
2135 gobject_class->dispose = regress_test_obj_dispose;
2137 pspec = g_param_spec_object ("bare",
2139 "A contained object",
2142 g_object_class_install_property (gobject_class,
2146 pspec = g_param_spec_boxed ("boxed",
2148 "A contained boxed struct",
2149 REGRESS_TEST_TYPE_BOXED,
2151 g_object_class_install_property (gobject_class,
2152 PROP_TEST_OBJ_BOXED,
2156 * RegressTestObj:hash-table:
2158 * Type: GLib.HashTable(utf8,gint8)
2159 * Transfer: container
2161 pspec = g_param_spec_boxed ("hash-table",
2162 "GHashTable property",
2163 "A contained GHashTable",
2166 g_object_class_install_property (gobject_class,
2167 PROP_TEST_OBJ_HASH_TABLE,
2171 * RegressTestObj:list:
2173 * Type: GLib.List(utf8)
2176 pspec = g_param_spec_pointer ("list",
2178 "A contained GList",
2180 g_object_class_install_property (gobject_class,
2185 * RegressTestObj:hash-table-old:
2187 * Type: GLib.HashTable<utf8,gint8>
2188 * Transfer: container
2190 pspec = g_param_spec_boxed ("hash-table-old",
2191 "GHashTable property with <>",
2192 "A contained GHashTable with <>",
2195 g_object_class_install_property (gobject_class,
2196 PROP_TEST_OBJ_HASH_TABLE_OLD,
2200 * RegressTestObj:list-old:
2202 * Type: GLib.List<utf8>
2205 pspec = g_param_spec_pointer ("list-old",
2206 "GList property with ()",
2207 "A contained GList with <>",
2209 g_object_class_install_property (gobject_class,
2210 PROP_TEST_OBJ_LIST_OLD,
2218 pspec = g_param_spec_int ("int",
2225 g_object_class_install_property (gobject_class,
2232 pspec = g_param_spec_float ("float",
2234 "A contained float",
2239 g_object_class_install_property (gobject_class,
2240 PROP_TEST_OBJ_FLOAT,
2246 pspec = g_param_spec_double ("double",
2248 "A contained double",
2253 g_object_class_install_property (gobject_class,
2254 PROP_TEST_OBJ_DOUBLE,
2260 pspec = g_param_spec_string ("string",
2262 "A contained string",
2265 g_object_class_install_property (gobject_class,
2266 PROP_TEST_OBJ_STRING,
2273 pspec = g_param_spec_gtype ("gtype",
2278 g_object_class_install_property (gobject_class,
2279 PROP_TEST_OBJ_GTYPE,
2282 klass->matrix = regress_test_obj_default_matrix;
2286 regress_test_obj_init (RegressTestObj *obj)
2290 obj->hash_table = NULL;
2291 obj->gtype = G_TYPE_INVALID;
2295 * regress_test_obj_new: (constructor)
2296 * @obj: A #RegressTestObj
2299 regress_test_obj_new (RegressTestObj *obj)
2301 return g_object_new (REGRESS_TEST_TYPE_OBJ, NULL);
2305 * regress_constructor: (constructor)
2309 regress_constructor (void)
2311 return g_object_new (REGRESS_TEST_TYPE_OBJ, NULL);
2315 * regress_test_obj_new_from_file:
2318 regress_test_obj_new_from_file (const char *x, GError **error)
2320 return g_object_new (REGRESS_TEST_TYPE_OBJ, NULL);
2324 * regress_test_obj_set_bare:
2325 * @bare: (allow-none):
2328 regress_test_obj_set_bare (RegressTestObj *obj, GObject *bare)
2331 g_object_unref (obj->bare);
2334 g_object_ref (obj->bare);
2338 regress_test_obj_emit_sig_with_obj (RegressTestObj *obj)
2340 RegressTestObj *obj_param = regress_constructor ();
2341 g_object_set (obj_param, "int", 3, NULL);
2342 g_signal_emit_by_name (obj, "sig-with-obj", obj_param);
2343 g_object_unref (obj_param);
2347 regress_test_obj_instance_method (RegressTestObj *obj)
2353 regress_test_obj_static_method (int x)
2359 * regress_forced_method: (method)
2360 * @obj: A #RegressTestObj
2364 regress_forced_method (RegressTestObj *obj)
2369 * regress_test_obj_torture_signature_0:
2370 * @obj: A #RegressTestObj
2380 regress_test_obj_torture_signature_0 (RegressTestObj *obj,
2390 *q = g_utf8_strlen (foo, -1) + m;
2394 * regress_test_obj_torture_signature_1:
2395 * @obj: A #RegressTestObj
2404 * This function throws an error if m is odd.
2407 regress_test_obj_torture_signature_1 (RegressTestObj *obj,
2418 *q = g_utf8_strlen (foo, -1) + m;
2421 g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, "m is odd");
2426 * regress_test_obj_skip_return_val:
2427 * @obj: a #RegressTestObj
2429 * @out_b: (out): A return value.
2430 * @c: Other parameter.
2431 * @inout_d: (inout): Will be incremented.
2432 * @out_sum: (out): Return value.
2435 * @error: Return location for error.
2437 * Check that the return value is skipped
2439 * Returns: (skip): %TRUE if the call succeeds, %FALSE if @error is set.
2442 regress_test_obj_skip_return_val (RegressTestObj *obj,
2454 if (inout_d != NULL)
2455 *inout_d = *inout_d + 1;
2456 if (out_sum != NULL)
2457 *out_sum = num1 + 10*num2;
2462 * regress_test_obj_skip_return_val_no_out:
2463 * @obj: a #RegressTestObj
2465 * @error: Return location for error.
2467 * Check that the return value is skipped. Succeed if a is nonzero, otherwise
2470 * Returns: (skip): %TRUE if the call succeeds, %FALSE if @error is set.
2473 regress_test_obj_skip_return_val_no_out (RegressTestObj *obj,
2478 g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, "a is zero");
2486 * regress_test_obj_skip_param:
2487 * @obj: A #RegressTestObj.
2489 * @out_b: (out): Return value.
2490 * @c: (skip): Other parameter.
2491 * @inout_d: (inout): Will be incremented.
2492 * @out_sum: (out): Return value.
2495 * @error: Return location for error.
2497 * Check that a parameter is skipped
2499 * Returns: %TRUE if the call succeeds, %FALSE if @error is set.
2502 regress_test_obj_skip_param (RegressTestObj *obj,
2514 if (inout_d != NULL)
2515 *inout_d = *inout_d + 1;
2516 if (out_sum != NULL)
2517 *out_sum = num1 + 10*num2;
2522 * regress_test_obj_skip_out_param:
2523 * @obj: A #RegressTestObj.
2525 * @out_b: (out) (skip): Return value.
2526 * @c: Other parameter.
2527 * @inout_d: (inout): Will be incremented.
2528 * @out_sum: (out): Return value.
2531 * @error: Return location for error.
2533 * Check that the out value is skipped
2535 * Returns: %TRUE if the call succeeds, %FALSE if @error is set.
2538 regress_test_obj_skip_out_param (RegressTestObj *obj,
2550 if (inout_d != NULL)
2551 *inout_d = *inout_d + 1;
2552 if (out_sum != NULL)
2553 *out_sum = num1 + 10*num2;
2558 * regress_test_obj_skip_inout_param:
2559 * @obj: A #RegressTestObj.
2561 * @out_b: (out): Return value.
2562 * @c: Other parameter.
2563 * @inout_d: (inout) (skip): Will be incremented.
2564 * @out_sum: (out): Return value.
2567 * @error: Return location for error.
2569 * Check that the out value is skipped
2571 * Returns: %TRUE if the call succeeds, %FALSE if @error is set.
2574 regress_test_obj_skip_inout_param (RegressTestObj *obj,
2586 if (inout_d != NULL)
2587 *inout_d = *inout_d + 1;
2588 if (out_sum != NULL)
2589 *out_sum = num1 + 10*num2;
2594 * regress_test_obj_do_matrix:
2595 * @obj: A #RegressTestObj
2596 * @somestr: Meaningless string
2598 * This method is virtual. Notably its name differs from the virtual
2599 * slot name, which makes it useful for testing bindings handle this
2605 regress_test_obj_do_matrix (RegressTestObj *obj, const char *somestr)
2607 return REGRESS_TEST_OBJ_GET_CLASS (obj)->matrix (obj, somestr);
2611 * regress_func_obj_null_in:
2612 * @obj: (allow-none): A #RegressTestObj
2615 regress_func_obj_null_in (RegressTestObj *obj)
2620 * regress_test_obj_null_out:
2621 * @obj: (allow-none) (out): A #RegressTestObj
2624 regress_test_obj_null_out (RegressTestObj **obj)
2631 * regress_test_array_fixed_out_objects:
2632 * @objs: (out) (array fixed-size=2) (transfer full): An array of #RegressTestObj
2635 regress_test_array_fixed_out_objects (RegressTestObj ***objs)
2637 RegressTestObj **values = (RegressTestObj**)g_new(gpointer, 2);
2639 values[0] = regress_constructor();
2640 values[1] = regress_constructor();
2645 typedef struct _CallbackInfo CallbackInfo;
2647 struct _CallbackInfo
2649 RegressTestCallbackUserData callback;
2650 GDestroyNotify notify;
2655 G_DEFINE_TYPE(RegressTestSubObj, regress_test_sub_obj, REGRESS_TEST_TYPE_OBJ);
2658 regress_test_sub_obj_class_init (RegressTestSubObjClass *klass)
2663 regress_test_sub_obj_init (RegressTestSubObj *obj)
2668 regress_test_sub_obj_new ()
2670 return g_object_new (REGRESS_TEST_TYPE_SUB_OBJ, NULL);
2674 regress_test_sub_obj_instance_method (RegressTestSubObj *obj)
2680 regress_test_sub_obj_unset_bare (RegressTestSubObj *obj)
2682 regress_test_obj_set_bare(REGRESS_TEST_OBJECT(obj), NULL);
2685 /* RegressTestFundamental */
2688 * regress_test_fundamental_object_ref:
2690 * Returns: (transfer full): A new #RegressTestFundamentalObject
2692 RegressTestFundamentalObject *
2693 regress_test_fundamental_object_ref (RegressTestFundamentalObject * fundamental_object)
2695 g_return_val_if_fail (fundamental_object != NULL, NULL);
2696 g_atomic_int_inc (&fundamental_object->refcount);
2698 return fundamental_object;
2702 regress_test_fundamental_object_free (RegressTestFundamentalObject * fundamental_object)
2704 RegressTestFundamentalObjectClass *mo_class;
2705 regress_test_fundamental_object_ref (fundamental_object);
2707 mo_class = REGRESS_TEST_FUNDAMENTAL_OBJECT_GET_CLASS (fundamental_object);
2708 mo_class->finalize (fundamental_object);
2710 if (G_LIKELY (g_atomic_int_dec_and_test (&fundamental_object->refcount))) {
2711 g_type_free_instance ((GTypeInstance *) fundamental_object);
2716 regress_test_fundamental_object_unref (RegressTestFundamentalObject * fundamental_object)
2718 g_return_if_fail (fundamental_object != NULL);
2719 g_return_if_fail (fundamental_object->refcount > 0);
2721 if (G_UNLIKELY (g_atomic_int_dec_and_test (&fundamental_object->refcount))) {
2722 regress_test_fundamental_object_free (fundamental_object);
2727 regress_test_fundamental_object_replace (RegressTestFundamentalObject ** olddata, RegressTestFundamentalObject * newdata)
2729 RegressTestFundamentalObject *olddata_val;
2731 g_return_if_fail (olddata != NULL);
2733 olddata_val = g_atomic_pointer_get ((gpointer *) olddata);
2735 if (olddata_val == newdata)
2739 regress_test_fundamental_object_ref (newdata);
2741 while (!g_atomic_pointer_compare_and_exchange ((gpointer *) olddata,
2742 olddata_val, newdata)) {
2743 olddata_val = g_atomic_pointer_get ((gpointer *) olddata);
2747 regress_test_fundamental_object_unref (olddata_val);
2751 regress_test_value_fundamental_object_init (GValue * value)
2753 value->data[0].v_pointer = NULL;
2757 regress_test_value_fundamental_object_free (GValue * value)
2759 if (value->data[0].v_pointer) {
2760 regress_test_fundamental_object_unref (REGRESS_TEST_FUNDAMENTAL_OBJECT_CAST (value->data[0].v_pointer));
2765 regress_test_value_fundamental_object_copy (const GValue * src_value, GValue * dest_value)
2767 if (src_value->data[0].v_pointer) {
2768 dest_value->data[0].v_pointer =
2769 regress_test_fundamental_object_ref (REGRESS_TEST_FUNDAMENTAL_OBJECT_CAST (src_value->data[0].
2772 dest_value->data[0].v_pointer = NULL;
2777 regress_test_value_fundamental_object_peek_pointer (const GValue * value)
2779 return value->data[0].v_pointer;
2783 regress_test_value_fundamental_object_collect (GValue * value,
2784 guint n_collect_values,
2785 GTypeCValue * collect_values,
2786 guint collect_flags)
2788 if (collect_values[0].v_pointer) {
2789 value->data[0].v_pointer =
2790 regress_test_fundamental_object_ref (collect_values[0].v_pointer);
2792 value->data[0].v_pointer = NULL;
2799 regress_test_value_fundamental_object_lcopy (const GValue * value,
2800 guint n_collect_values,
2801 GTypeCValue * collect_values,
2802 guint collect_flags)
2804 gpointer *fundamental_object_p = collect_values[0].v_pointer;
2806 if (!fundamental_object_p) {
2807 return g_strdup_printf ("value location for '%s' passed as NULL",
2808 G_VALUE_TYPE_NAME (value));
2811 if (!value->data[0].v_pointer)
2812 *fundamental_object_p = NULL;
2813 else if (collect_flags & G_VALUE_NOCOPY_CONTENTS)
2814 *fundamental_object_p = value->data[0].v_pointer;
2816 *fundamental_object_p = regress_test_fundamental_object_ref (value->data[0].v_pointer);
2822 regress_test_fundamental_object_finalize (RegressTestFundamentalObject * obj)
2827 static RegressTestFundamentalObject *
2828 regress_test_fundamental_object_copy_default (const RegressTestFundamentalObject * obj)
2830 g_warning ("RegressTestFundamentalObject classes must implement RegressTestFundamentalObject::copy");
2835 regress_test_fundamental_object_class_init (gpointer g_class, gpointer class_data)
2837 RegressTestFundamentalObjectClass *mo_class = REGRESS_TEST_FUNDAMENTAL_OBJECT_CLASS (g_class);
2839 mo_class->copy = regress_test_fundamental_object_copy_default;
2840 mo_class->finalize = regress_test_fundamental_object_finalize;
2844 regress_test_fundamental_object_init (GTypeInstance * instance, gpointer klass)
2846 RegressTestFundamentalObject *fundamental_object = REGRESS_TEST_FUNDAMENTAL_OBJECT_CAST (instance);
2848 fundamental_object->refcount = 1;
2852 * RegressTestFundamentalObject:
2854 * Ref Func: regress_test_fundamental_object_ref
2855 * Unref Func: regress_test_fundamental_object_unref
2856 * Set Value Func: regress_test_value_set_fundamental_object
2857 * Get Value Func: regress_test_value_get_fundamental_object
2861 regress_test_fundamental_object_get_type (void)
2863 static GType _test_fundamental_object_type = 0;
2865 if (G_UNLIKELY (_test_fundamental_object_type == 0)) {
2866 static const GTypeValueTable value_table = {
2867 regress_test_value_fundamental_object_init,
2868 regress_test_value_fundamental_object_free,
2869 regress_test_value_fundamental_object_copy,
2870 regress_test_value_fundamental_object_peek_pointer,
2872 regress_test_value_fundamental_object_collect,
2874 regress_test_value_fundamental_object_lcopy
2876 static const GTypeInfo fundamental_object_info = {
2877 sizeof (RegressTestFundamentalObjectClass),
2879 regress_test_fundamental_object_class_init,
2882 sizeof (RegressTestFundamentalObject),
2884 (GInstanceInitFunc) regress_test_fundamental_object_init,
2887 static const GTypeFundamentalInfo fundamental_object_fundamental_info = {
2888 (G_TYPE_FLAG_CLASSED | G_TYPE_FLAG_INSTANTIATABLE |
2889 G_TYPE_FLAG_DERIVABLE | G_TYPE_FLAG_DEEP_DERIVABLE)
2892 _test_fundamental_object_type = g_type_fundamental_next ();
2893 g_type_register_fundamental (_test_fundamental_object_type, "RegressTestFundamentalObject",
2894 &fundamental_object_info, &fundamental_object_fundamental_info, G_TYPE_FLAG_ABSTRACT);
2898 return _test_fundamental_object_type;
2902 * regress_test_value_set_fundamental_object: (skip)
2904 * @fundamental_object:
2907 regress_test_value_set_fundamental_object (GValue * value, RegressTestFundamentalObject * fundamental_object)
2909 gpointer *pointer_p;
2911 g_return_if_fail (REGRESS_TEST_VALUE_HOLDS_FUNDAMENTAL_OBJECT (value));
2912 g_return_if_fail (fundamental_object == NULL || REGRESS_TEST_IS_FUNDAMENTAL_OBJECT (fundamental_object));
2914 pointer_p = &value->data[0].v_pointer;
2916 regress_test_fundamental_object_replace ((RegressTestFundamentalObject **) pointer_p, fundamental_object);
2920 * regress_test_value_get_fundamental_object: (skip)
2923 RegressTestFundamentalObject *
2924 regress_test_value_get_fundamental_object (const GValue * value)
2926 g_return_val_if_fail (REGRESS_TEST_VALUE_HOLDS_FUNDAMENTAL_OBJECT (value), NULL);
2928 return value->data[0].v_pointer;
2931 static RegressTestFundamentalObjectClass *parent_class = NULL;
2933 G_DEFINE_TYPE (RegressTestFundamentalSubObject, regress_test_fundamental_sub_object, REGRESS_TEST_TYPE_FUNDAMENTAL_OBJECT);
2935 static RegressTestFundamentalSubObject *
2936 _regress_test_fundamental_sub_object_copy (RegressTestFundamentalSubObject * fundamental_sub_object)
2938 RegressTestFundamentalSubObject *copy;
2940 copy = regress_test_fundamental_sub_object_new(NULL);
2941 copy->data = g_strdup(fundamental_sub_object->data);
2946 regress_test_fundamental_sub_object_finalize (RegressTestFundamentalSubObject * fundamental_sub_object)
2948 g_return_if_fail (fundamental_sub_object != NULL);
2950 g_free(fundamental_sub_object->data);
2951 regress_test_fundamental_object_finalize (REGRESS_TEST_FUNDAMENTAL_OBJECT (fundamental_sub_object));
2955 regress_test_fundamental_sub_object_class_init (RegressTestFundamentalSubObjectClass * klass)
2957 parent_class = g_type_class_peek_parent (klass);
2959 klass->fundamental_object_class.copy = (RegressTestFundamentalObjectCopyFunction) _regress_test_fundamental_sub_object_copy;
2960 klass->fundamental_object_class.finalize =
2961 (RegressTestFundamentalObjectFinalizeFunction) regress_test_fundamental_sub_object_finalize;
2965 regress_test_fundamental_sub_object_init(RegressTestFundamentalSubObject *object)
2971 * regress_test_fundamental_sub_object_new:
2973 RegressTestFundamentalSubObject *
2974 regress_test_fundamental_sub_object_new (const char * data)
2976 RegressTestFundamentalSubObject *object;
2978 object = (RegressTestFundamentalSubObject *) g_type_create_instance (regress_test_fundamental_sub_object_get_type());
2979 object->data = g_strdup(data);
2985 * regress_test_callback:
2986 * @callback: (scope call) (allow-none):
2990 regress_test_callback (RegressTestCallback callback)
2992 if (callback != NULL)
2998 * regress_test_multi_callback:
2999 * @callback: (scope call) (allow-none):
3003 regress_test_multi_callback (RegressTestCallback callback)
3006 if (callback != NULL) {
3015 * regress_test_array_callback:
3016 * @callback: (scope call):
3019 int regress_test_array_callback (RegressTestCallbackArray callback)
3021 static const char *strings[] = { "one", "two", "three" };
3022 static int ints[] = { -1, 0, 1, 2 };
3025 sum += callback(ints, 4, strings, 3);
3026 sum += callback(ints, 4, strings, 3);
3032 * regress_test_simple_callback:
3033 * @callback: (scope call) (allow-none):
3037 regress_test_simple_callback (RegressTestSimpleCallback callback)
3039 if (callback != NULL)
3046 * regress_test_callback_user_data:
3047 * @callback: (scope call):
3049 * Call - callback parameter persists for the duration of the method
3050 * call and can be released on return.
3053 regress_test_callback_user_data (RegressTestCallbackUserData callback,
3056 return callback(user_data);
3059 static GSList *notified_callbacks = NULL;
3062 * regress_test_callback_destroy_notify:
3063 * @callback: (scope notified):
3065 * Notified - callback persists until a DestroyNotify delegate
3069 regress_test_callback_destroy_notify (RegressTestCallbackUserData callback,
3071 GDestroyNotify notify)
3076 retval = callback(user_data);
3078 info = g_slice_new(CallbackInfo);
3079 info->callback = callback;
3080 info->notify = notify;
3081 info->user_data = user_data;
3083 notified_callbacks = g_slist_prepend(notified_callbacks, info);
3089 * regress_test_callback_thaw_notifications:
3091 * Invokes all callbacks installed by #test_callback_destroy_notify(),
3092 * adding up their return values, and removes them, invoking the
3093 * corresponding destroy notfications.
3095 * Return value: Sum of the return values of the invoked callbacks.
3098 regress_test_callback_thaw_notifications (void)
3103 for (node = notified_callbacks; node != NULL; node = node->next)
3105 CallbackInfo *info = node->data;
3106 retval += info->callback (info->user_data);
3108 info->notify (info->user_data);
3109 g_slice_free (CallbackInfo, info);
3112 g_slist_free (notified_callbacks);
3113 notified_callbacks = NULL;
3118 static GSList *async_callbacks = NULL;
3121 * regress_test_callback_async:
3122 * @callback: (scope async):
3126 regress_test_callback_async (RegressTestCallbackUserData callback,
3131 info = g_slice_new(CallbackInfo);
3132 info->callback = callback;
3133 info->user_data = user_data;
3135 async_callbacks = g_slist_prepend(async_callbacks, info);
3139 * regress_test_callback_thaw_async:
3142 regress_test_callback_thaw_async (void)
3147 for (node = async_callbacks; node != NULL; node = node->next)
3149 CallbackInfo *info = node->data;
3150 retval = info->callback (info->user_data);
3151 g_slice_free (CallbackInfo, info);
3154 g_slist_free (async_callbacks);
3155 async_callbacks = NULL;
3160 regress_test_async_ready_callback (GAsyncReadyCallback callback)
3162 GSimpleAsyncResult *result = g_simple_async_result_new (NULL, callback, NULL,
3163 regress_test_async_ready_callback);
3164 g_simple_async_result_complete_in_idle (result);
3168 * regress_test_obj_instance_method_callback:
3169 * @callback: (scope call) (allow-none):
3173 regress_test_obj_instance_method_callback (RegressTestObj *obj, RegressTestCallback callback)
3175 if (callback != NULL)
3180 * regress_test_obj_static_method_callback:
3181 * @callback: (scope call) (allow-none):
3185 regress_test_obj_static_method_callback (RegressTestCallback callback)
3187 if (callback != NULL)
3192 * regress_test_obj_new_callback:
3193 * @callback: (scope notified):
3196 regress_test_obj_new_callback (RegressTestCallbackUserData callback, gpointer user_data,
3197 GDestroyNotify notify)
3201 callback(user_data);
3203 info = g_slice_new(CallbackInfo);
3204 info->callback = callback;
3205 info->notify = notify;
3206 info->user_data = user_data;
3208 notified_callbacks = g_slist_prepend(notified_callbacks, info);
3210 return g_object_new (REGRESS_TEST_TYPE_OBJ, NULL);
3214 * regress_test_hash_table_callback:
3215 * @data: (element-type utf8 gint): GHashTable that gets passed to callback
3216 * @callback: (scope call):
3219 regress_test_hash_table_callback (GHashTable *data, RegressTestCallbackHashtable callback)
3225 * regress_test_gerror_callback:
3226 * @callback: (scope call):
3229 regress_test_gerror_callback (RegressTestCallbackGError callback)
3233 error = g_error_new_literal (G_IO_ERROR,
3234 G_IO_ERROR_NOT_SUPPORTED,
3235 "regression test error");
3237 g_error_free (error);
3241 * regress_test_null_gerror_callback:
3242 * @callback: (scope call):
3245 regress_test_null_gerror_callback (RegressTestCallbackGError callback)
3251 * regress_test_owned_gerror_callback:
3252 * @callback: (scope call):
3255 regress_test_owned_gerror_callback (RegressTestCallbackOwnedGError callback)
3259 error = g_error_new_literal (G_IO_ERROR,
3260 G_IO_ERROR_PERMISSION_DENIED,
3261 "regression test owned error");
3268 regress_test_interface_class_init(void *g_iface)
3273 regress_test_interface_get_type(void)
3275 static GType type = 0;
3277 type = g_type_register_static_simple (G_TYPE_INTERFACE,
3278 "RegressTestInterface",
3279 sizeof (RegressTestInterfaceIface),
3280 (GClassInitFunc) regress_test_interface_class_init,
3287 /* gobject with non-standard prefix */
3288 G_DEFINE_TYPE(RegressTestWi8021x, regress_test_wi_802_1x, G_TYPE_OBJECT);
3292 PROP_TEST_WI_802_1X_TESTBOOL = 1
3296 regress_test_wi_802_1x_set_property (GObject *object,
3298 const GValue *value,
3301 RegressTestWi8021x *self = REGRESS_TEST_WI_802_1X (object);
3303 switch (property_id)
3305 case PROP_TEST_WI_802_1X_TESTBOOL:
3306 regress_test_wi_802_1x_set_testbool (self, g_value_get_boolean (value));
3310 /* We don't have any other property... */
3311 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
3317 regress_test_wi_802_1x_get_property (GObject *object,
3322 RegressTestWi8021x *self = REGRESS_TEST_WI_802_1X (object);
3324 switch (property_id)
3326 case PROP_TEST_WI_802_1X_TESTBOOL:
3327 g_value_set_boolean (value, regress_test_wi_802_1x_get_testbool (self));
3331 /* We don't have any other property... */
3332 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
3338 regress_test_wi_802_1x_dispose (GObject *gobject)
3340 /* Chain up to the parent class */
3341 G_OBJECT_CLASS (regress_test_wi_802_1x_parent_class)->dispose (gobject);
3345 regress_test_wi_802_1x_class_init (RegressTestWi8021xClass *klass)
3347 GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
3350 gobject_class->set_property = regress_test_wi_802_1x_set_property;
3351 gobject_class->get_property = regress_test_wi_802_1x_get_property;
3352 gobject_class->dispose = regress_test_wi_802_1x_dispose;
3354 pspec = g_param_spec_boolean ("testbool",
3355 "Nick for testbool",
3356 "Blurb for testbool",
3359 g_object_class_install_property (gobject_class,
3360 PROP_TEST_WI_802_1X_TESTBOOL,
3365 regress_test_wi_802_1x_init (RegressTestWi8021x *obj)
3367 obj->testbool = TRUE;
3370 RegressTestWi8021x *
3371 regress_test_wi_802_1x_new (void)
3373 return g_object_new (REGRESS_TEST_TYPE_WI_802_1X, NULL);
3377 regress_test_wi_802_1x_set_testbool (RegressTestWi8021x *obj, gboolean val)
3379 obj->testbool = val;
3383 regress_test_wi_802_1x_get_testbool (RegressTestWi8021x *obj)
3385 return obj->testbool;
3389 regress_test_wi_802_1x_static_method (int x)
3394 /* floating gobject */
3395 G_DEFINE_TYPE(RegressTestFloating, regress_test_floating, G_TYPE_INITIALLY_UNOWNED);
3398 regress_test_floating_finalize(GObject *object)
3400 g_assert(!g_object_is_floating (object));
3402 G_OBJECT_CLASS(regress_test_floating_parent_class)->finalize(object);
3406 regress_test_floating_class_init (RegressTestFloatingClass *klass)
3408 GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
3409 gobject_class->finalize = regress_test_floating_finalize;
3413 regress_test_floating_init (RegressTestFloating *obj)
3418 * regress_test_floating_new:
3420 * Returns:: A new floating #RegressTestFloating
3422 RegressTestFloating *
3423 regress_test_floating_new (void)
3425 return g_object_new (REGRESS_TEST_TYPE_FLOATING, NULL);
3430 * regress_test_torture_signature_0:
3440 regress_test_torture_signature_0 (int x,
3449 *q = g_utf8_strlen (foo, -1) + m;
3453 * regress_test_torture_signature_1:
3462 * This function throws an error if m is odd.
3465 regress_test_torture_signature_1 (int x,
3475 *q = g_utf8_strlen (foo, -1) + m;
3478 g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, "m is odd");
3483 * regress_test_torture_signature_2:
3496 regress_test_torture_signature_2 (int x,
3497 RegressTestCallbackUserData callback,
3499 GDestroyNotify notify,
3508 *q = g_utf8_strlen (foo, -1) + m;
3513 * regress_test_date_in_gvalue:
3515 * Returns: (transfer full):
3518 regress_test_date_in_gvalue (void)
3520 GValue *value = g_new0 (GValue, 1);
3521 GDate *date = g_date_new_dmy (5, 12, 1984);
3523 g_value_init (value, G_TYPE_DATE);
3524 g_value_take_boxed (value, date);
3530 * regress_test_strv_in_gvalue:
3532 * Returns: (transfer full):
3535 regress_test_strv_in_gvalue (void)
3537 GValue *value = g_new0 (GValue, 1);
3538 const char *strv[] = { "one", "two", "three", NULL };
3540 g_value_init (value, G_TYPE_STRV);
3541 g_value_set_boxed (value, strv);
3547 * regress_test_multiline_doc_comments:
3549 * This is a function.
3551 * It has multiple lines in the documentation.
3555 * You will give me your credit card number.
3558 regress_test_multiline_doc_comments (void)
3563 * regress_test_nested_parameter:
3570 * <entry>Syntax</entry>
3571 * <entry>Explanation</entry>
3572 * <entry>Examples</entry>
3577 * <entry>rgb(@r, @g, @b)</entry>
3578 * <entry>An opaque color; @r, @g, @b can be either integers between
3579 * 0 and 255 or percentages</entry>
3580 * <entry><literallayout>rgb(128, 10, 54)
3581 * rgb(20%, 30%, 0%)</literallayout></entry>
3584 * <entry>rgba(@r, @g, @b, @a)</entry>
3585 * <entry>A translucent color; @r, @g, @b are as in the previous row,
3586 * @a is a floating point number between 0 and 1</entry>
3587 * <entry><literallayout>rgba(255, 255, 0, 0.5)</literallayout></entry>
3593 * What we're testing here is that the scanner ignores the @a nested inside XML.
3596 regress_test_nested_parameter (int a)
3601 * regress_introspectable_via_alias:
3605 regress_introspectable_via_alias (RegressPtrArrayAlias *data)
3610 * regress_not_introspectable_via_alias:
3614 regress_not_introspectable_via_alias (RegressVaListAlias ok)
3619 * regress_aliased_caller_alloc:
3622 void regress_aliased_caller_alloc (RegressAliasedTestBoxed *boxed)
3624 boxed->priv = g_slice_new0 (RegressTestBoxedPrivate);
3625 boxed->priv->magic = 0xdeadbeef;
3629 regress_test_struct_fixed_array_frob (RegressTestStructFixedArray *str)
3634 for (i = 0; i < G_N_ELEMENTS(str->array); i++)
3635 str->array[i] = 42 + i;
3639 * regress_has_parameter_named_attrs:
3641 * @attributes: (type guint32) (array fixed-size=32): list of attributes
3643 * This test case mirrors GnomeKeyringPasswordSchema from
3647 regress_has_parameter_named_attrs (int foo,
3648 gpointer attributes)