mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-25 21:46:14 +01:00
Bug 551738 - Associate classes with their structs
Inside glibtransformer, we now look at structures ending in "Class" and see if they have an associated GlibObject (i.e. a structure of the same name without the "Class" suffix). If found, pair them up. The .gir file for <class> gains an attribute denoting its associated class struct. Any <record> many now have a glib:is-class-struct-for annotation which tells which (if any) <class> for which it defines the layout. In the .typelib, we record the association between the class and its structure. Generic structures however just have a boolean saying whether they're a class struct. (Going from a generic class struct to its class should not be necessary). Finally, we expose GIRepository APIs to access both bits of information from the .typelib. svn path=/trunk/; revision=1088
This commit is contained in:
parent
981e55ef57
commit
d90d14cf67
@ -566,6 +566,7 @@ write_struct_info (const gchar *namespace,
|
|||||||
const gchar *type_name;
|
const gchar *type_name;
|
||||||
const gchar *type_init;
|
const gchar *type_init;
|
||||||
gboolean deprecated;
|
gboolean deprecated;
|
||||||
|
gboolean is_class_struct;
|
||||||
gint i;
|
gint i;
|
||||||
int n_elts;
|
int n_elts;
|
||||||
|
|
||||||
@ -592,6 +593,10 @@ write_struct_info (const gchar *namespace,
|
|||||||
if (deprecated)
|
if (deprecated)
|
||||||
xml_printf (file, " deprecated=\"1\"");
|
xml_printf (file, " deprecated=\"1\"");
|
||||||
|
|
||||||
|
is_class_struct = g_struct_info_is_class_struct (info);
|
||||||
|
if (is_class_struct)
|
||||||
|
xml_printf (file, " glib:is-class-struct=\"1\"");
|
||||||
|
|
||||||
n_elts = g_struct_info_get_n_fields (info) + g_struct_info_get_n_methods (info);
|
n_elts = g_struct_info_get_n_fields (info) + g_struct_info_get_n_methods (info);
|
||||||
if (n_elts > 0)
|
if (n_elts > 0)
|
||||||
{
|
{
|
||||||
@ -904,6 +909,7 @@ write_object_info (const gchar *namespace,
|
|||||||
gboolean deprecated;
|
gboolean deprecated;
|
||||||
gboolean is_abstract;
|
gboolean is_abstract;
|
||||||
GIObjectInfo *pnode;
|
GIObjectInfo *pnode;
|
||||||
|
GIStructInfo *class_struct;
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
name = g_base_info_get_name ((GIBaseInfo *)info);
|
name = g_base_info_get_name ((GIBaseInfo *)info);
|
||||||
@ -922,6 +928,13 @@ write_object_info (const gchar *namespace,
|
|||||||
g_base_info_unref ((GIBaseInfo *)pnode);
|
g_base_info_unref ((GIBaseInfo *)pnode);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class_struct = g_object_info_get_class_struct (info);
|
||||||
|
if (class_struct)
|
||||||
|
{
|
||||||
|
write_type_name_attribute (namespace, (GIBaseInfo*) class_struct, "glib:class-struct", file);
|
||||||
|
g_base_info_unref ((GIBaseInfo*)class_struct);
|
||||||
|
}
|
||||||
|
|
||||||
if (is_abstract)
|
if (is_abstract)
|
||||||
xml_printf (file, " abstract=\"1\"");
|
xml_printf (file, " abstract=\"1\"");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user