diff options
author | Bastian Winkler <buz@netbuz.org> | 2012-04-20 14:01:18 +0200 |
---|---|---|
committer | Martin Pitt <martinpitt@gnome.org> | 2012-04-20 15:14:13 +0200 |
commit | d4b37b82ac49eacb17c3e7e2acf54533e27a11e4 (patch) | |
tree | 3e3f0dacaa80faa961a414423d15fcf90c660ac7 | |
parent | 7b8ef1e9b3ae3c616c03c3b8d9571f5dba026923 (diff) | |
download | gobject-introspection-d4b37b82ac49eacb17c3e7e2acf54533e27a11e4.tar.gz |
tests: Add array marshalling test for array without length argument
A test case with an array in-argument that is neither zero terminated,
nor fixed length, nor blessed with a length argument.
This is, for example, the case in clutter_texture_set_from_rgb_data()
https://bugzilla.gnome.org/show_bug.cgi?id=674271
Signed-off-by: Martin Pitt <martinpitt@gnome.org>
-rw-r--r-- | tests/gimarshallingtests.c | 14 | ||||
-rw-r--r-- | tests/gimarshallingtests.h | 2 |
2 files changed, 16 insertions, 0 deletions
diff --git a/tests/gimarshallingtests.c b/tests/gimarshallingtests.c index fcbad694..f2cfc352 100644 --- a/tests/gimarshallingtests.c +++ b/tests/gimarshallingtests.c @@ -1530,6 +1530,20 @@ gi_marshalling_tests_array_inout_etc (gint first, gint **ints, gint *length, gin } /** + * gi_marshalling_tests_array_in_nonzero_nonlen: + * @first: + * @chars: (array): + */ +void +gi_marshalling_tests_array_in_nonzero_nonlen (gint first, const guint8 *chars) +{ + g_assert(chars[0] == 'a'); + g_assert(chars[1] == 'b'); + g_assert(chars[2] == 'c'); + g_assert(chars[3] == 'd'); +} + +/** * gi_marshalling_tests_array_zero_terminated_return: * * Returns: (array zero-terminated=1) (transfer none): diff --git a/tests/gimarshallingtests.h b/tests/gimarshallingtests.h index 6fa1b089..2d3e1f65 100644 --- a/tests/gimarshallingtests.h +++ b/tests/gimarshallingtests.h @@ -398,6 +398,8 @@ void gi_marshalling_tests_array_out_etc (gint first, gint **ints, gint *length, void gi_marshalling_tests_array_inout (gint **ints, gint *length); void gi_marshalling_tests_array_inout_etc (gint first, gint **ints, gint *length, gint last, gint *sum); +void gi_marshalling_tests_array_in_nonzero_nonlen (gint first, const guint8 *chars); + /* Zero-terminated */ gchar **gi_marshalling_tests_array_zero_terminated_return (void); |