Fix accessing structure fields that are arrays

We need to distinguish inline arrays inside structures, and arrays
that are pointers and annotations, and we can do it with
g_type_info_is_pointer(), setting it to FALSE for fixed size arrays.
As a side effect, (array fixed-size=N) on a pointer type has no longer
the expected result.

https://bugzilla.gnome.org/show_bug.cgi?id=646635
This commit is contained in:
Giovanni Campagna 2011-06-05 20:57:01 +02:00
parent 343c76431a
commit fef2a7b8dd
3 changed files with 10 additions and 23 deletions

View File

@ -193,14 +193,7 @@ g_field_info_get_field (GIFieldInfo *field_info,
if (g_type_info_is_pointer (type_info)) if (g_type_info_is_pointer (type_info))
{ {
if (g_type_info_get_array_type (type_info) == GI_ARRAY_TYPE_C && value->v_pointer = G_STRUCT_MEMBER (gpointer, mem, offset);
g_type_info_get_array_fixed_size (type_info) >= 0)
{
/* Consider fixed-size arrays as embedded inside the struct */
value->v_pointer = G_STRUCT_MEMBER_P ((mem), (offset));
}
else
value->v_pointer = G_STRUCT_MEMBER (gpointer, mem, offset);
result = TRUE; result = TRUE;
} }
else else
@ -248,9 +241,14 @@ g_field_info_get_field (GIFieldInfo *field_info,
value->v_double = G_STRUCT_MEMBER (gdouble, mem, offset); value->v_double = G_STRUCT_MEMBER (gdouble, mem, offset);
result = TRUE; result = TRUE;
break; break;
case GI_TYPE_TAG_ARRAY:
/* We don't check the array type and that it is fixed-size,
we trust g-ir-compiler to do the right thing */
value->v_pointer = G_STRUCT_MEMBER_P (mem, offset);
result = TRUE;
break;
case GI_TYPE_TAG_UTF8: case GI_TYPE_TAG_UTF8:
case GI_TYPE_TAG_FILENAME: case GI_TYPE_TAG_FILENAME:
case GI_TYPE_TAG_ARRAY:
case GI_TYPE_TAG_GLIST: case GI_TYPE_TAG_GLIST:
case GI_TYPE_TAG_GSLIST: case GI_TYPE_TAG_GSLIST:
case GI_TYPE_TAG_GHASH: case GI_TYPE_TAG_GHASH:

View File

@ -1242,6 +1242,8 @@ serialize_type (GIrTypelibBuild *build,
node->has_length ? "," : ""); node->has_length ? "," : "");
g_string_append (str, "]"); g_string_append (str, "]");
if (node->is_pointer)
g_string_append (str, "*");
} }
else if (node->array_type == GI_ARRAY_TYPE_BYTE_ARRAY) else if (node->array_type == GI_ARRAY_TYPE_BYTE_ARRAY)
{ {
@ -1476,7 +1478,7 @@ _g_ir_node_build_typelib (GIrNode *node,
ArrayTypeBlob *array = (ArrayTypeBlob *)&data[*offset2]; ArrayTypeBlob *array = (ArrayTypeBlob *)&data[*offset2];
guint32 pos; guint32 pos;
array->pointer = 1; array->pointer = type->is_pointer;
array->reserved = 0; array->reserved = 0;
array->tag = type->tag; array->tag = type->tag;
array->zero_terminated = type->zero_terminated; array->zero_terminated = type->zero_terminated;

View File

@ -523,19 +523,6 @@ validate_array_type_blob (GITypelib *typelib,
gboolean return_type, gboolean return_type,
GError **error) GError **error)
{ {
ArrayTypeBlob *blob;
blob = (ArrayTypeBlob*)&typelib->data[offset];
if (!blob->pointer)
{
g_set_error (error,
G_TYPELIB_ERROR,
G_TYPELIB_ERROR_INVALID_BLOB,
"Pointer type exected for tag %d", blob->tag);
return FALSE;
}
/* FIXME validate length */ /* FIXME validate length */
if (!validate_type_blob (typelib, if (!validate_type_blob (typelib,