From 5fa28d1b7e08fafbb521084b379cd27f95d1ce43 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:33:49 +0000 Subject: [PATCH 01/22] girepository: Rename GIArgInfo methods to be clearer MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Indicate that they return an argument index, not the argument itself. This is an API break, but libgirepository has not been in a stable GLib release yet, so that’s fine. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/giarginfo.c | 8 ++++---- girepository/giarginfo.h | 4 ++-- girepository/girwriter.c | 8 ++++---- 3 files changed, 10 insertions(+), 10 deletions(-) diff --git a/girepository/giarginfo.c b/girepository/giarginfo.c index 04c67c019..bf8890078 100644 --- a/girepository/giarginfo.c +++ b/girepository/giarginfo.c @@ -246,7 +246,7 @@ gi_arg_info_get_scope (GIArgInfo *info) } /** - * gi_arg_info_get_closure: + * gi_arg_info_get_closure_index: * @info: a #GIArgInfo * * Obtain the index of the user data argument. This is only valid @@ -255,7 +255,7 @@ gi_arg_info_get_scope (GIArgInfo *info) * Returns: index of the user data argument or -1 if there is none */ gint -gi_arg_info_get_closure (GIArgInfo *info) +gi_arg_info_get_closure_index (GIArgInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ArgBlob *blob; @@ -269,7 +269,7 @@ gi_arg_info_get_closure (GIArgInfo *info) } /** - * gi_arg_info_get_destroy: + * gi_arg_info_get_destroy_index: * @info: a #GIArgInfo * * Obtains the index of the #GDestroyNotify argument. This is only valid @@ -278,7 +278,7 @@ gi_arg_info_get_closure (GIArgInfo *info) * Returns: index of the #GDestroyNotify argument or -1 if there is none */ gint -gi_arg_info_get_destroy (GIArgInfo *info) +gi_arg_info_get_destroy_index (GIArgInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ArgBlob *blob; diff --git a/girepository/giarginfo.h b/girepository/giarginfo.h index eaff5f5c8..be08d9759 100644 --- a/girepository/giarginfo.h +++ b/girepository/giarginfo.h @@ -67,10 +67,10 @@ GI_AVAILABLE_IN_ALL GIScopeType gi_arg_info_get_scope (GIArgInfo *info); GI_AVAILABLE_IN_ALL -gint gi_arg_info_get_closure (GIArgInfo *info); +gint gi_arg_info_get_closure_index (GIArgInfo *info); GI_AVAILABLE_IN_ALL -gint gi_arg_info_get_destroy (GIArgInfo *info); +gint gi_arg_info_get_destroy_index (GIArgInfo *info); GI_AVAILABLE_IN_ALL GITypeInfo * gi_arg_info_get_type_info (GIArgInfo *info); diff --git a/girepository/girwriter.c b/girepository/girwriter.c index fdbe9a23a..f356f8cd5 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -544,11 +544,11 @@ write_callable_info (const gchar *ns, g_assert_not_reached (); } - if (gi_arg_info_get_closure (arg) >= 0) - xml_printf (file, " closure=\"%d\"", gi_arg_info_get_closure (arg)); + if (gi_arg_info_get_closure_index (arg) >= 0) + xml_printf (file, " closure=\"%d\"", gi_arg_info_get_closure_index (arg)); - if (gi_arg_info_get_destroy (arg) >= 0) - xml_printf (file, " destroy=\"%d\"", gi_arg_info_get_destroy (arg)); + if (gi_arg_info_get_destroy_index (arg) >= 0) + xml_printf (file, " destroy=\"%d\"", gi_arg_info_get_destroy_index (arg)); if (gi_arg_info_is_skip (arg)) xml_printf (file, " skip=\"1\""); From 825581756adbaba10458c73f6be4acbe966765bb Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:34:48 +0000 Subject: [PATCH 02/22] girepository: constify iterator arguments MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This is an API break, but libgirepository has not been in a stable release yet, so that’s fine. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gibaseinfo.c | 14 +++++++------- girepository/gibaseinfo.h | 4 ++-- girepository/gicallableinfo.c | 10 +++++----- girepository/gicallableinfo.h | 4 ++-- girepository/girwriter.c | 4 ++-- 5 files changed, 18 insertions(+), 18 deletions(-) diff --git a/girepository/gibaseinfo.c b/girepository/gibaseinfo.c index f89b4d15e..7c6eba9b0 100644 --- a/girepository/gibaseinfo.c +++ b/girepository/gibaseinfo.c @@ -747,7 +747,7 @@ gi_base_info_get_attribute (GIBaseInfo *info, const gchar *name) { GIAttributeIter iter = { 0, }; - gchar *curname, *curvalue; + const char *curname, *curvalue; while (gi_base_info_iterate_attributes (info, &iter, &curname, &curvalue)) { if (strcmp (name, curname) == 0) @@ -832,8 +832,8 @@ _attribute_blob_find_first (GIBaseInfo *info, * print_attributes (GIBaseInfo *info) * { * GIAttributeIter iter = { 0, }; - * char *name; - * char *value; + * const char *name; + * const char *value; * while (gi_base_info_iterate_attributes (info, &iter, &name, &value)) * { * g_print ("attribute name: %s value: %s", name, value); @@ -846,8 +846,8 @@ _attribute_blob_find_first (GIBaseInfo *info, gboolean gi_base_info_iterate_attributes (GIBaseInfo *info, GIAttributeIter *iterator, - gchar **name, - gchar **value) + const gchar **name, + const gchar **value) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header = (Header *)rinfo->typelib->data; @@ -864,8 +864,8 @@ gi_base_info_iterate_attributes (GIBaseInfo *info, if (next == NULL || next->offset != rinfo->offset || next >= after) return FALSE; - *name = (gchar*) gi_typelib_get_string (rinfo->typelib, next->name); - *value = (gchar*) gi_typelib_get_string (rinfo->typelib, next->value); + *name = gi_typelib_get_string (rinfo->typelib, next->name); + *value = gi_typelib_get_string (rinfo->typelib, next->value); iterator->data = next + 1; return TRUE; diff --git a/girepository/gibaseinfo.h b/girepository/gibaseinfo.h index 96f6fa694..681b8a03b 100644 --- a/girepository/gibaseinfo.h +++ b/girepository/gibaseinfo.h @@ -79,8 +79,8 @@ const gchar * gi_base_info_get_attribute (GIBaseInfo *info, GI_AVAILABLE_IN_ALL gboolean gi_base_info_iterate_attributes (GIBaseInfo *info, GIAttributeIter *iterator, - char **name, - char **value); + const char **name, + const char **value); GI_AVAILABLE_IN_ALL GIBaseInfo * gi_base_info_get_container (GIBaseInfo *info); diff --git a/girepository/gicallableinfo.c b/girepository/gicallableinfo.c index 1d0e001cd..ce72ef802 100644 --- a/girepository/gicallableinfo.c +++ b/girepository/gicallableinfo.c @@ -411,7 +411,7 @@ gi_callable_info_get_return_attribute (GICallableInfo *info, const gchar *name) { GIAttributeIter iter = { 0, }; - gchar *curname, *curvalue; + const char *curname, *curvalue; while (gi_callable_info_iterate_return_attributes (info, &iter, &curname, &curvalue)) { if (g_strcmp0 (name, curname) == 0) @@ -443,8 +443,8 @@ gi_callable_info_get_return_attribute (GICallableInfo *info, gboolean gi_callable_info_iterate_return_attributes (GICallableInfo *info, GIAttributeIter *iterator, - char **name, - char **value) + const char **name, + const char **value) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header = (Header *)rinfo->typelib->data; @@ -464,8 +464,8 @@ gi_callable_info_iterate_return_attributes (GICallableInfo *info, if (next == NULL || next->offset != blob_offset || next >= after) return FALSE; - *name = (gchar*) gi_typelib_get_string (rinfo->typelib, next->name); - *value = (gchar*) gi_typelib_get_string (rinfo->typelib, next->value); + *name = gi_typelib_get_string (rinfo->typelib, next->name); + *value = gi_typelib_get_string (rinfo->typelib, next->value); iterator->data = next + 1; return TRUE; diff --git a/girepository/gicallableinfo.h b/girepository/gicallableinfo.h index 9c56d9404..47c72ca20 100644 --- a/girepository/gicallableinfo.h +++ b/girepository/gicallableinfo.h @@ -65,8 +65,8 @@ const gchar * gi_callable_info_get_return_attribute (GICallableInfo *in GI_AVAILABLE_IN_ALL gboolean gi_callable_info_iterate_return_attributes (GICallableInfo *info, GIAttributeIter *iterator, - char **name, - char **value); + const char **name, + const char **value); GI_AVAILABLE_IN_ALL GITransfer gi_callable_info_get_caller_owns (GICallableInfo *info); diff --git a/girepository/girwriter.c b/girepository/girwriter.c index f356f8cd5..3d2ce0e6c 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -352,7 +352,7 @@ write_attributes (Xml *file, GIBaseInfo *info) { GIAttributeIter iter = { 0, }; - char *name, *value; + const char *name, *value; while (gi_base_info_iterate_attributes (info, &iter, &name, &value)) { @@ -367,7 +367,7 @@ write_return_value_attributes (Xml *file, GICallableInfo *info) { GIAttributeIter iter = { 0, }; - char *name, *value; + const char *name, *value; while (gi_callable_info_iterate_return_attributes (info, &iter, &name, &value)) { From 5cb8b9b826865a42376ed5f84bf189b6bb611dd6 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:40:07 +0000 Subject: [PATCH 03/22] gicallableinfo: Fix int signedness in APIs These ints can never be negative, so should be unsigned. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gicallableinfo.c | 12 ++++++------ girepository/gicallableinfo.h | 10 +++++----- girepository/girwriter.c | 3 +-- 3 files changed, 12 insertions(+), 13 deletions(-) diff --git a/girepository/gicallableinfo.c b/girepository/gicallableinfo.c index ce72ef802..f811fe4e3 100644 --- a/girepository/gicallableinfo.c +++ b/girepository/gicallableinfo.c @@ -322,7 +322,7 @@ gi_callable_info_get_instance_ownership_transfer (GICallableInfo *info) * * Returns: The number of arguments this callable expects. */ -gint +guint gi_callable_info_get_n_args (GICallableInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -350,7 +350,7 @@ gi_callable_info_get_n_args (GICallableInfo *info) */ GIArgInfo * gi_callable_info_get_arg (GICallableInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header; @@ -380,7 +380,7 @@ gi_callable_info_get_arg (GICallableInfo *info, */ void gi_callable_info_load_arg (GICallableInfo *info, - gint n, + guint n, GIArgInfo *arg) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -601,9 +601,9 @@ gboolean gi_callable_info_invoke (GICallableInfo *info, gpointer function, const GIArgument *in_args, - int n_in_args, + gsize n_in_args, const GIArgument *out_args, - int n_out_args, + gsize n_out_args, GIArgument *return_value, gboolean is_method, gboolean throws, @@ -616,7 +616,7 @@ gi_callable_info_invoke (GICallableInfo *info, GITypeInfo *rinfo; GITypeTag rtag; GIArgInfo *ainfo; - gint n_args, n_invoke_args, in_pos, out_pos, i; + gsize n_args, n_invoke_args, in_pos, out_pos, i; gpointer *args; gboolean success = FALSE; GError *local_error = NULL; diff --git a/girepository/gicallableinfo.h b/girepository/gicallableinfo.h index 47c72ca20..e0b80b6b6 100644 --- a/girepository/gicallableinfo.h +++ b/girepository/gicallableinfo.h @@ -78,24 +78,24 @@ GI_AVAILABLE_IN_ALL gboolean gi_callable_info_skip_return (GICallableInfo *info); GI_AVAILABLE_IN_ALL -gint gi_callable_info_get_n_args (GICallableInfo *info); +guint gi_callable_info_get_n_args (GICallableInfo *info); GI_AVAILABLE_IN_ALL GIArgInfo * gi_callable_info_get_arg (GICallableInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL void gi_callable_info_load_arg (GICallableInfo *info, - gint n, + guint n, GIArgInfo *arg); GI_AVAILABLE_IN_ALL gboolean gi_callable_info_invoke (GICallableInfo *info, gpointer function, const GIArgument *in_args, - int n_in_args, + gsize n_in_args, const GIArgument *out_args, - int n_out_args, + gsize n_out_args, GIArgument *return_value, gboolean is_method, gboolean throws, diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 3d2ce0e6c..c36df39d9 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -461,7 +461,6 @@ write_callable_info (const gchar *ns, Xml *file) { GITypeInfo *type; - gint i; if (gi_callable_info_can_throw_gerror (info)) xml_printf (file, " throws=\"1\""); @@ -490,7 +489,7 @@ write_callable_info (const gchar *ns, return; xml_start_element (file, "parameters"); - for (i = 0; i < gi_callable_info_get_n_args (info); i++) + for (guint i = 0; i < gi_callable_info_get_n_args (info); i++) { GIArgInfo *arg = gi_callable_info_get_arg (info, i); From 14e5844f3d290feea9ab6fc58d8f0d2fe08c08ca Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:42:32 +0000 Subject: [PATCH 04/22] giconstantinfo: Correctly represent a size as gsize Signed-off-by: Philip Withnall Helps: #3155 --- girepository/giconstantinfo.c | 4 ++-- girepository/giconstantinfo.h | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/girepository/giconstantinfo.c b/girepository/giconstantinfo.c index 69e103ba0..e08455809 100644 --- a/girepository/giconstantinfo.c +++ b/girepository/giconstantinfo.c @@ -108,9 +108,9 @@ gi_constant_info_free_value (GIConstantInfo *info, * The size of the constant value stored in @argument will be returned. * Free the value with gi_constant_info_free_value(). * - * Returns: size of the constant + * Returns: size of the constant, in bytes */ -gint +gsize gi_constant_info_get_value (GIConstantInfo *info, GIArgument *value) { diff --git a/girepository/giconstantinfo.h b/girepository/giconstantinfo.h index 56c2cc85d..4b4b882a2 100644 --- a/girepository/giconstantinfo.h +++ b/girepository/giconstantinfo.h @@ -50,6 +50,6 @@ void gi_constant_info_free_value (GIConstantInfo *info, GIArgument *value); GI_AVAILABLE_IN_ALL -gint gi_constant_info_get_value (GIConstantInfo *info, +gsize gi_constant_info_get_value (GIConstantInfo *info, GIArgument *value); G_END_DECLS From e4ed11baa4828af6bdc4bd07ad878d232320ca92 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:44:49 +0000 Subject: [PATCH 05/22] gienuminfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gienuminfo.c | 8 ++++---- girepository/gienuminfo.h | 8 ++++---- girepository/girwriter.c | 3 +-- 3 files changed, 9 insertions(+), 10 deletions(-) diff --git a/girepository/gienuminfo.c b/girepository/gienuminfo.c index 8daa3ff5b..09fdf3aa2 100644 --- a/girepository/gienuminfo.c +++ b/girepository/gienuminfo.c @@ -54,7 +54,7 @@ * * Returns: the number of enumeration values */ -gint +guint gi_enum_info_get_n_values (GIEnumInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -108,7 +108,7 @@ gi_enum_info_get_error_domain (GIEnumInfo *info) */ GIValueInfo * gi_enum_info_get_value (GIEnumInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header; @@ -133,7 +133,7 @@ gi_enum_info_get_value (GIEnumInfo *info, * Returns: number of methods * Since: 2.80 */ -gint +guint gi_enum_info_get_n_methods (GIEnumInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -160,7 +160,7 @@ gi_enum_info_get_n_methods (GIEnumInfo *info) */ GIFunctionInfo * gi_enum_info_get_method (GIEnumInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; diff --git a/girepository/gienuminfo.h b/girepository/gienuminfo.h index d8aec74c7..d0a095ea9 100644 --- a/girepository/gienuminfo.h +++ b/girepository/gienuminfo.h @@ -53,18 +53,18 @@ G_BEGIN_DECLS GI_AVAILABLE_IN_ALL -gint gi_enum_info_get_n_values (GIEnumInfo *info); +guint gi_enum_info_get_n_values (GIEnumInfo *info); GI_AVAILABLE_IN_ALL GIValueInfo * gi_enum_info_get_value (GIEnumInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_enum_info_get_n_methods (GIEnumInfo *info); +guint gi_enum_info_get_n_methods (GIEnumInfo *info); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_enum_info_get_method (GIEnumInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GITypeTag gi_enum_info_get_storage_type (GIEnumInfo *info); diff --git a/girepository/girwriter.c b/girepository/girwriter.c index c36df39d9..90d97030c 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -839,7 +839,6 @@ write_enum_info (const gchar *ns, const gchar *type_init; const gchar *error_domain; gboolean deprecated; - gint i; name = gi_base_info_get_name ((GIBaseInfo *)info); deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); @@ -864,7 +863,7 @@ write_enum_info (const gchar *ns, write_attributes (file, (GIBaseInfo*) info); - for (i = 0; i < gi_enum_info_get_n_values (info); i++) + for (guint i = 0; i < gi_enum_info_get_n_values (info); i++) { GIValueInfo *value = gi_enum_info_get_value (info, i); write_value_info (ns, value, file); From 81d6173d7475a6c76b1a87acee7529d75a233fb1 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:46:21 +0000 Subject: [PATCH 06/22] gifieldinfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gifieldinfo.c | 4 ++-- girepository/gifieldinfo.h | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/girepository/gifieldinfo.c b/girepository/gifieldinfo.c index 649fb426d..4d5358751 100644 --- a/girepository/gifieldinfo.c +++ b/girepository/gifieldinfo.c @@ -95,7 +95,7 @@ gi_field_info_get_flags (GIFieldInfo *info) * Returns: the field size, in bits * Since: 2.80 */ -gint +gsize gi_field_info_get_size (GIFieldInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -119,7 +119,7 @@ gi_field_info_get_size (GIFieldInfo *info) * Returns: the field offset, in bytes * Since: 2.80 */ -gint +gsize gi_field_info_get_offset (GIFieldInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; diff --git a/girepository/gifieldinfo.h b/girepository/gifieldinfo.h index 1b807460b..222751222 100644 --- a/girepository/gifieldinfo.h +++ b/girepository/gifieldinfo.h @@ -48,10 +48,10 @@ GI_AVAILABLE_IN_ALL GIFieldInfoFlags gi_field_info_get_flags (GIFieldInfo *info); GI_AVAILABLE_IN_ALL -gint gi_field_info_get_size (GIFieldInfo *info); +gsize gi_field_info_get_size (GIFieldInfo *info); GI_AVAILABLE_IN_ALL -gint gi_field_info_get_offset (GIFieldInfo *info); +gsize gi_field_info_get_offset (GIFieldInfo *info); GI_AVAILABLE_IN_ALL GITypeInfo * gi_field_info_get_type_info (GIFieldInfo *info); From 417c42ba21e1419236fd917cfe98ae54abc2523f Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:47:44 +0000 Subject: [PATCH 07/22] gifunctioninfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gifunctioninfo.c | 4 ++-- girepository/gifunctioninfo.h | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/girepository/gifunctioninfo.c b/girepository/gifunctioninfo.c index abab97906..ca8333f9e 100644 --- a/girepository/gifunctioninfo.c +++ b/girepository/gifunctioninfo.c @@ -256,9 +256,9 @@ gi_invoke_error_quark (void) gboolean gi_function_info_invoke (GIFunctionInfo *info, const GIArgument *in_args, - int n_in_args, + gsize n_in_args, const GIArgument *out_args, - int n_out_args, + gsize n_out_args, GIArgument *return_value, GError **error) { diff --git a/girepository/gifunctioninfo.h b/girepository/gifunctioninfo.h index 3f95fe680..80ec94d54 100644 --- a/girepository/gifunctioninfo.h +++ b/girepository/gifunctioninfo.h @@ -87,9 +87,9 @@ typedef enum GI_AVAILABLE_IN_ALL gboolean gi_function_info_invoke (GIFunctionInfo *info, const GIArgument *in_args, - int n_in_args, + gsize n_in_args, const GIArgument *out_args, - int n_out_args, + gsize n_out_args, GIArgument *return_value, GError **error); From a00389343ad567982450d61aa0d4cbb882dc7fd0 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:51:07 +0000 Subject: [PATCH 08/22] giinterfaceinfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/giinterfaceinfo.c | 29 ++++++++++++++--------------- girepository/giinterfaceinfo.h | 24 ++++++++++++------------ girepository/girwriter.c | 13 ++++++------- 3 files changed, 32 insertions(+), 34 deletions(-) diff --git a/girepository/giinterfaceinfo.c b/girepository/giinterfaceinfo.c index 17ffeb4da..8f3a70af5 100644 --- a/girepository/giinterfaceinfo.c +++ b/girepository/giinterfaceinfo.c @@ -53,7 +53,7 @@ * * Returns: number of prerequisites */ -gint +guint gi_interface_info_get_n_prerequisites (GIInterfaceInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -79,7 +79,7 @@ gi_interface_info_get_n_prerequisites (GIInterfaceInfo *info) */ GIBaseInfo * gi_interface_info_get_prerequisite (GIInterfaceInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; InterfaceBlob *blob; @@ -102,7 +102,7 @@ gi_interface_info_get_prerequisite (GIInterfaceInfo *info, * * Returns: number of properties */ -gint +guint gi_interface_info_get_n_properties (GIInterfaceInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -128,7 +128,7 @@ gi_interface_info_get_n_properties (GIInterfaceInfo *info) */ GIPropertyInfo * gi_interface_info_get_property (GIInterfaceInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -157,7 +157,7 @@ gi_interface_info_get_property (GIInterfaceInfo *info, * * Returns: number of methods */ -gint +guint gi_interface_info_get_n_methods (GIInterfaceInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -183,7 +183,7 @@ gi_interface_info_get_n_methods (GIInterfaceInfo *info) */ GIFunctionInfo * gi_interface_info_get_method (GIInterfaceInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -240,7 +240,7 @@ gi_interface_info_find_method (GIInterfaceInfo *info, * * Returns: number of signals */ -gint +guint gi_interface_info_get_n_signals (GIInterfaceInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -266,7 +266,7 @@ gi_interface_info_get_n_signals (GIInterfaceInfo *info) */ GISignalInfo * gi_interface_info_get_signal (GIInterfaceInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -304,11 +304,10 @@ GISignalInfo * gi_interface_info_find_signal (GIInterfaceInfo *info, const gchar *name) { - gint n_signals; - gint i; + guint n_signals; n_signals = gi_interface_info_get_n_signals (info); - for (i = 0; i < n_signals; i++) + for (guint i = 0; i < n_signals; i++) { GISignalInfo *siginfo = gi_interface_info_get_signal (info, i); @@ -331,7 +330,7 @@ gi_interface_info_find_signal (GIInterfaceInfo *info, * * Returns: number of virtual functions */ -gint +guint gi_interface_info_get_n_vfuncs (GIInterfaceInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -357,7 +356,7 @@ gi_interface_info_get_n_vfuncs (GIInterfaceInfo *info) */ GIVFuncInfo * gi_interface_info_get_vfunc (GIInterfaceInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -424,7 +423,7 @@ gi_interface_info_find_vfunc (GIInterfaceInfo *info, * * Returns: number of constants */ -gint +guint gi_interface_info_get_n_constants (GIInterfaceInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -450,7 +449,7 @@ gi_interface_info_get_n_constants (GIInterfaceInfo *info) */ GIConstantInfo * gi_interface_info_get_constant (GIInterfaceInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; diff --git a/girepository/giinterfaceinfo.h b/girepository/giinterfaceinfo.h index 7334f76c7..c90d7087c 100644 --- a/girepository/giinterfaceinfo.h +++ b/girepository/giinterfaceinfo.h @@ -43,58 +43,58 @@ G_BEGIN_DECLS GI_AVAILABLE_IN_ALL -gint gi_interface_info_get_n_prerequisites (GIInterfaceInfo *info); +guint gi_interface_info_get_n_prerequisites (GIInterfaceInfo *info); GI_AVAILABLE_IN_ALL GIBaseInfo * gi_interface_info_get_prerequisite (GIInterfaceInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_interface_info_get_n_properties (GIInterfaceInfo *info); +guint gi_interface_info_get_n_properties (GIInterfaceInfo *info); GI_AVAILABLE_IN_ALL GIPropertyInfo * gi_interface_info_get_property (GIInterfaceInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_interface_info_get_n_methods (GIInterfaceInfo *info); +guint gi_interface_info_get_n_methods (GIInterfaceInfo *info); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_interface_info_get_method (GIInterfaceInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_interface_info_find_method (GIInterfaceInfo *info, const gchar *name); GI_AVAILABLE_IN_ALL -gint gi_interface_info_get_n_signals (GIInterfaceInfo *info); +guint gi_interface_info_get_n_signals (GIInterfaceInfo *info); GI_AVAILABLE_IN_ALL GISignalInfo * gi_interface_info_get_signal (GIInterfaceInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GISignalInfo * gi_interface_info_find_signal (GIInterfaceInfo *info, const gchar *name); GI_AVAILABLE_IN_ALL -gint gi_interface_info_get_n_vfuncs (GIInterfaceInfo *info); +guint gi_interface_info_get_n_vfuncs (GIInterfaceInfo *info); GI_AVAILABLE_IN_ALL GIVFuncInfo * gi_interface_info_get_vfunc (GIInterfaceInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIVFuncInfo * gi_interface_info_find_vfunc (GIInterfaceInfo *info, const gchar *name); GI_AVAILABLE_IN_ALL -gint gi_interface_info_get_n_constants (GIInterfaceInfo *info); +guint gi_interface_info_get_n_constants (GIInterfaceInfo *info); GI_AVAILABLE_IN_ALL GIConstantInfo * gi_interface_info_get_constant (GIInterfaceInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 90d97030c..129f0ca6f 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -1166,7 +1166,6 @@ write_interface_info (const gchar *ns, const gchar *type_init; GIStructInfo *class_struct; gboolean deprecated; - gint i; name = gi_base_info_get_name ((GIBaseInfo *)info); deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); @@ -1191,7 +1190,7 @@ write_interface_info (const gchar *ns, if (gi_interface_info_get_n_prerequisites (info) > 0) { - for (i = 0; i < gi_interface_info_get_n_prerequisites (info); i++) + for (guint i = 0; i < gi_interface_info_get_n_prerequisites (info); i++) { GIBaseInfo *req = gi_interface_info_get_prerequisite (info, i); @@ -1203,35 +1202,35 @@ write_interface_info (const gchar *ns, } } - for (i = 0; i < gi_interface_info_get_n_methods (info); i++) + for (guint i = 0; i < gi_interface_info_get_n_methods (info); i++) { GIFunctionInfo *function = gi_interface_info_get_method (info, i); write_function_info (ns, function, file); gi_base_info_unref ((GIBaseInfo *)function); } - for (i = 0; i < gi_interface_info_get_n_properties (info); i++) + for (guint i = 0; i < gi_interface_info_get_n_properties (info); i++) { GIPropertyInfo *prop = gi_interface_info_get_property (info, i); write_property_info (ns, prop, file); gi_base_info_unref ((GIBaseInfo *)prop); } - for (i = 0; i < gi_interface_info_get_n_signals (info); i++) + for (guint i = 0; i < gi_interface_info_get_n_signals (info); i++) { GISignalInfo *signal = gi_interface_info_get_signal (info, i); write_signal_info (ns, signal, file); gi_base_info_unref ((GIBaseInfo *)signal); } - for (i = 0; i < gi_interface_info_get_n_vfuncs (info); i++) + for (guint i = 0; i < gi_interface_info_get_n_vfuncs (info); i++) { GIVFuncInfo *vfunc = gi_interface_info_get_vfunc (info, i); write_vfunc_info (ns, vfunc, file); gi_base_info_unref ((GIBaseInfo *)vfunc); } - for (i = 0; i < gi_interface_info_get_n_constants (info); i++) + for (guint i = 0; i < gi_interface_info_get_n_constants (info); i++) { GIConstantInfo *constant = gi_interface_info_get_constant (info, i); write_constant_info (ns, constant, file); From 693f11cd423388aabf14ed6191c5353c88c8631d Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 17:54:19 +0000 Subject: [PATCH 09/22] girepository: Rename get_type_init() methods to get_type_init_function_name() Because they return the function name, not a `GIFunctionInfo` for the function, or anything else. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/giobjectinfo.c | 4 ++-- girepository/giobjectinfo.h | 2 +- girepository/giregisteredtypeinfo.c | 6 +++--- girepository/giregisteredtypeinfo.h | 2 +- girepository/girwriter.c | 10 +++++----- 5 files changed, 12 insertions(+), 12 deletions(-) diff --git a/girepository/giobjectinfo.c b/girepository/giobjectinfo.c index 5afeafb1c..d44816c8f 100644 --- a/girepository/giobjectinfo.c +++ b/girepository/giobjectinfo.c @@ -204,7 +204,7 @@ gi_object_info_get_type_name (GIObjectInfo *info) } /** - * gi_object_info_get_type_init: + * gi_object_info_get_type_init_function_name: * @info: a #GIObjectInfo * * Obtain the function which when called will return the GType @@ -213,7 +213,7 @@ gi_object_info_get_type_name (GIObjectInfo *info) * Returns: the type init function */ const gchar * -gi_object_info_get_type_init (GIObjectInfo *info) +gi_object_info_get_type_init_function_name (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ObjectBlob *blob; diff --git a/girepository/giobjectinfo.h b/girepository/giobjectinfo.h index 4b661cbd4..943a1baa0 100644 --- a/girepository/giobjectinfo.h +++ b/girepository/giobjectinfo.h @@ -83,7 +83,7 @@ GI_AVAILABLE_IN_ALL const gchar * gi_object_info_get_type_name (GIObjectInfo *info); GI_AVAILABLE_IN_ALL -const gchar * gi_object_info_get_type_init (GIObjectInfo *info); +const gchar * gi_object_info_get_type_init_function_name (GIObjectInfo *info); GI_AVAILABLE_IN_ALL gboolean gi_object_info_get_abstract (GIObjectInfo *info); diff --git a/girepository/giregisteredtypeinfo.c b/girepository/giregisteredtypeinfo.c index d3274c867..c89d068bc 100644 --- a/girepository/giregisteredtypeinfo.c +++ b/girepository/giregisteredtypeinfo.c @@ -78,7 +78,7 @@ gi_registered_type_info_get_type_name (GIRegisteredTypeInfo *info) } /** - * gi_registered_type_info_get_type_init: + * gi_registered_type_info_get_type_init_function_name: * @info: a #GIRegisteredTypeInfo * * Obtain the type init function for @info. The type init function is the @@ -90,7 +90,7 @@ gi_registered_type_info_get_type_name (GIRegisteredTypeInfo *info) * passing into g_module_symbol(). */ const gchar * -gi_registered_type_info_get_type_init (GIRegisteredTypeInfo *info) +gi_registered_type_info_get_type_init_function_name (GIRegisteredTypeInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; RegisteredTypeBlob *blob; @@ -127,7 +127,7 @@ gi_registered_type_info_get_g_type (GIRegisteredTypeInfo *info) g_return_val_if_fail (info != NULL, G_TYPE_INVALID); g_return_val_if_fail (GI_IS_REGISTERED_TYPE_INFO (info), G_TYPE_INVALID); - type_init = gi_registered_type_info_get_type_init (info); + type_init = gi_registered_type_info_get_type_init_function_name (info); if (type_init == NULL) return G_TYPE_NONE; diff --git a/girepository/giregisteredtypeinfo.h b/girepository/giregisteredtypeinfo.h index c0707f3e4..02d021832 100644 --- a/girepository/giregisteredtypeinfo.h +++ b/girepository/giregisteredtypeinfo.h @@ -53,7 +53,7 @@ GI_AVAILABLE_IN_ALL const gchar * gi_registered_type_info_get_type_name (GIRegisteredTypeInfo *info); GI_AVAILABLE_IN_ALL -const gchar * gi_registered_type_info_get_type_init (GIRegisteredTypeInfo *info); +const gchar * gi_registered_type_info_get_type_init_function_name (GIRegisteredTypeInfo *info); GI_AVAILABLE_IN_ALL GType gi_registered_type_info_get_g_type (GIRegisteredTypeInfo *info); diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 129f0ca6f..0741807ab 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -658,7 +658,7 @@ write_struct_info (const gchar *ns, deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); type_name = gi_registered_type_info_get_type_name ((GIRegisteredTypeInfo*)info); - type_init = gi_registered_type_info_get_type_init ((GIRegisteredTypeInfo*)info); + type_init = gi_registered_type_info_get_type_init_function_name ((GIRegisteredTypeInfo*)info); if (gi_base_info_get_info_type ((GIBaseInfo *) info) == GI_INFO_TYPE_BOXED) { @@ -844,7 +844,7 @@ write_enum_info (const gchar *ns, deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); type_name = gi_registered_type_info_get_type_name ((GIRegisteredTypeInfo*)info); - type_init = gi_registered_type_info_get_type_init ((GIRegisteredTypeInfo*)info); + type_init = gi_registered_type_info_get_type_init_function_name ((GIRegisteredTypeInfo*)info); error_domain = gi_enum_info_get_error_domain (info); if (gi_base_info_get_info_type ((GIBaseInfo *) info) == GI_INFO_TYPE_ENUM) @@ -1049,7 +1049,7 @@ write_object_info (const gchar *ns, is_final = gi_object_info_get_final (info); type_name = gi_registered_type_info_get_type_name ((GIRegisteredTypeInfo*)info); - type_init = gi_registered_type_info_get_type_init ((GIRegisteredTypeInfo*)info); + type_init = gi_registered_type_info_get_type_init_function_name ((GIRegisteredTypeInfo*)info); xml_start_element (file, "class"); xml_printf (file, " name=\"%s\"", name); @@ -1171,7 +1171,7 @@ write_interface_info (const gchar *ns, deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); type_name = gi_registered_type_info_get_type_name ((GIRegisteredTypeInfo*)info); - type_init = gi_registered_type_info_get_type_init ((GIRegisteredTypeInfo*)info); + type_init = gi_registered_type_info_get_type_init_function_name ((GIRegisteredTypeInfo*)info); xml_start_element (file, "interface"); xml_printf (file, " name=\"%s\" glib:type-name=\"%s\" glib:get-type=\"%s\"", name, type_name, type_init); @@ -1257,7 +1257,7 @@ write_union_info (const gchar *ns, deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); type_name = gi_registered_type_info_get_type_name ((GIRegisteredTypeInfo*)info); - type_init = gi_registered_type_info_get_type_init ((GIRegisteredTypeInfo*)info); + type_init = gi_registered_type_info_get_type_init_function_name ((GIRegisteredTypeInfo*)info); xml_start_element (file, "union"); xml_printf (file, " name=\"%s\"", name); From 030f4f003cb86a4569ac159f9d7a21ee5a83b9a9 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:07:25 +0000 Subject: [PATCH 10/22] giobjectinfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/giobjectinfo.c | 38 ++++++++++++++++++------------------- girepository/giobjectinfo.h | 28 +++++++++++++-------------- girepository/girwriter.c | 15 +++++++-------- 3 files changed, 39 insertions(+), 42 deletions(-) diff --git a/girepository/giobjectinfo.c b/girepository/giobjectinfo.c index d44816c8f..846505b7d 100644 --- a/girepository/giobjectinfo.c +++ b/girepository/giobjectinfo.c @@ -60,19 +60,18 @@ */ static gint32 gi_object_info_get_field_offset (GIObjectInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header = (Header *)rinfo->typelib->data; ObjectBlob *blob = (ObjectBlob *)&rinfo->typelib->data[rinfo->offset]; guint32 offset; - gint i; FieldBlob *field_blob; offset = rinfo->offset + header->object_blob_size + (blob->n_interfaces + blob->n_interfaces % 2) * 2; - for (i = 0; i < n; i++) + for (guint i = 0; i < n; i++) { field_blob = (FieldBlob *)&rinfo->typelib->data[offset]; offset += header->field_blob_size; @@ -234,7 +233,7 @@ gi_object_info_get_type_init_function_name (GIObjectInfo *info) * * Returns: number of interfaces */ -gint +guint gi_object_info_get_n_interfaces (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -260,7 +259,7 @@ gi_object_info_get_n_interfaces (GIObjectInfo *info) */ GIInterfaceInfo * gi_object_info_get_interface (GIObjectInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; ObjectBlob *blob; @@ -282,7 +281,7 @@ gi_object_info_get_interface (GIObjectInfo *info, * * Returns: number of fields */ -gint +guint gi_object_info_get_n_fields (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -308,7 +307,7 @@ gi_object_info_get_n_fields (GIObjectInfo *info) */ GIFieldInfo * gi_object_info_get_field (GIObjectInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -329,7 +328,7 @@ gi_object_info_get_field (GIObjectInfo *info, * * Returns: number of properties */ -gint +guint gi_object_info_get_n_properties (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -354,7 +353,7 @@ gi_object_info_get_n_properties (GIObjectInfo *info) */ GIPropertyInfo * gi_object_info_get_property (GIObjectInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -385,7 +384,7 @@ gi_object_info_get_property (GIObjectInfo *info, * * Returns: number of methods */ -gint +guint gi_object_info_get_n_methods (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -411,7 +410,7 @@ gi_object_info_get_n_methods (GIObjectInfo *info) */ GIFunctionInfo * gi_object_info_get_method (GIObjectInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -536,7 +535,7 @@ gi_object_info_find_method_using_interfaces (GIObjectInfo *info, * * Returns: number of signals */ -gint +guint gi_object_info_get_n_signals (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -562,7 +561,7 @@ gi_object_info_get_n_signals (GIObjectInfo *info) */ GISignalInfo * gi_object_info_get_signal (GIObjectInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -600,11 +599,10 @@ GISignalInfo * gi_object_info_find_signal (GIObjectInfo *info, const gchar *name) { - gint n_signals; - gint i; + guint n_signals; n_signals = gi_object_info_get_n_signals (info); - for (i = 0; i < n_signals; i++) + for (guint i = 0; i < n_signals; i++) { GISignalInfo *siginfo = gi_object_info_get_signal (info, i); @@ -628,7 +626,7 @@ gi_object_info_find_signal (GIObjectInfo *info, * * Returns: number of virtual functions */ -gint +guint gi_object_info_get_n_vfuncs (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -654,7 +652,7 @@ gi_object_info_get_n_vfuncs (GIObjectInfo *info) */ GIVFuncInfo * gi_object_info_get_vfunc (GIObjectInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; @@ -790,7 +788,7 @@ gi_object_info_find_vfunc_using_interfaces (GIObjectInfo *info, * * Returns: number of constants */ -gint +guint gi_object_info_get_n_constants (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -816,7 +814,7 @@ gi_object_info_get_n_constants (GIObjectInfo *info) */ GIConstantInfo * gi_object_info_get_constant (GIObjectInfo *info, - gint n) + guint n) { gint offset; GIRealInfo *rinfo = (GIRealInfo *)info; diff --git a/girepository/giobjectinfo.h b/girepository/giobjectinfo.h index 943a1baa0..c0d4bc5f7 100644 --- a/girepository/giobjectinfo.h +++ b/girepository/giobjectinfo.h @@ -98,32 +98,32 @@ GI_AVAILABLE_IN_ALL GIObjectInfo * gi_object_info_get_parent (GIObjectInfo *info); GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_interfaces (GIObjectInfo *info); +guint gi_object_info_get_n_interfaces (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIInterfaceInfo * gi_object_info_get_interface (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_fields (GIObjectInfo *info); +guint gi_object_info_get_n_fields (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIFieldInfo * gi_object_info_get_field (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_properties (GIObjectInfo *info); +guint gi_object_info_get_n_properties (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIPropertyInfo * gi_object_info_get_property (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_methods (GIObjectInfo *info); +guint gi_object_info_get_n_methods (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_object_info_get_method (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_object_info_find_method (GIObjectInfo *info, @@ -137,11 +137,11 @@ GIFunctionInfo * gi_object_info_find_method_using_interfaces (GIObjectInfo *in GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_signals (GIObjectInfo *info); +guint gi_object_info_get_n_signals (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GISignalInfo * gi_object_info_get_signal (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL @@ -150,11 +150,11 @@ GISignalInfo * gi_object_info_find_signal (GIObjectInfo *info, GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_vfuncs (GIObjectInfo *info); +guint gi_object_info_get_n_vfuncs (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIVFuncInfo * gi_object_info_get_vfunc (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIVFuncInfo * gi_object_info_find_vfunc (GIObjectInfo *info, @@ -166,11 +166,11 @@ GIVFuncInfo * gi_object_info_find_vfunc_using_interfaces (GIObjectInfo *inf GIObjectInfo **implementor); GI_AVAILABLE_IN_ALL -gint gi_object_info_get_n_constants (GIObjectInfo *info); +guint gi_object_info_get_n_constants (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIConstantInfo * gi_object_info_get_constant (GIObjectInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIStructInfo * gi_object_info_get_class_struct (GIObjectInfo *info); diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 0741807ab..164031f32 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -1040,7 +1040,6 @@ write_object_info (const gchar *ns, gboolean is_final; GIObjectInfo *pnode; GIStructInfo *class_struct; - gint i; name = gi_base_info_get_name ((GIBaseInfo *)info); deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); @@ -1101,7 +1100,7 @@ write_object_info (const gchar *ns, if (gi_object_info_get_n_interfaces (info) > 0) { - for (i = 0; i < gi_object_info_get_n_interfaces (info); i++) + for (guint i = 0; i < gi_object_info_get_n_interfaces (info); i++) { GIInterfaceInfo *imp = gi_object_info_get_interface (info, i); xml_start_element (file, "implements"); @@ -1111,42 +1110,42 @@ write_object_info (const gchar *ns, } } - for (i = 0; i < gi_object_info_get_n_fields (info); i++) + for (guint i = 0; i < gi_object_info_get_n_fields (info); i++) { GIFieldInfo *field = gi_object_info_get_field (info, i); write_field_info (ns, field, NULL, file); gi_base_info_unref ((GIBaseInfo *)field); } - for (i = 0; i < gi_object_info_get_n_methods (info); i++) + for (guint i = 0; i < gi_object_info_get_n_methods (info); i++) { GIFunctionInfo *function = gi_object_info_get_method (info, i); write_function_info (ns, function, file); gi_base_info_unref ((GIBaseInfo *)function); } - for (i = 0; i < gi_object_info_get_n_properties (info); i++) + for (guint i = 0; i < gi_object_info_get_n_properties (info); i++) { GIPropertyInfo *prop = gi_object_info_get_property (info, i); write_property_info (ns, prop, file); gi_base_info_unref ((GIBaseInfo *)prop); } - for (i = 0; i < gi_object_info_get_n_signals (info); i++) + for (guint i = 0; i < gi_object_info_get_n_signals (info); i++) { GISignalInfo *signal = gi_object_info_get_signal (info, i); write_signal_info (ns, signal, file); gi_base_info_unref ((GIBaseInfo *)signal); } - for (i = 0; i < gi_object_info_get_n_vfuncs (info); i++) + for (guint i = 0; i < gi_object_info_get_n_vfuncs (info); i++) { GIVFuncInfo *vfunc = gi_object_info_get_vfunc (info, i); write_vfunc_info (ns, vfunc, file); gi_base_info_unref ((GIBaseInfo *)vfunc); } - for (i = 0; i < gi_object_info_get_n_constants (info); i++) + for (guint i = 0; i < gi_object_info_get_n_constants (info); i++) { GIConstantInfo *constant = gi_object_info_get_constant (info, i); write_constant_info (ns, constant, file); From 15660b49b5a7a90062414bfdd4b682ad0064cc11 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:07:50 +0000 Subject: [PATCH 11/22] giobjectinfo: Rename get_*_function() methods to get_*_function_name() Because they return the function name, not a `GIFunctionInfo` or anything else. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/giobjectinfo.c | 32 ++++++++++++++++---------------- girepository/giobjectinfo.h | 8 ++++---- girepository/girwriter.c | 8 ++++---- 3 files changed, 24 insertions(+), 24 deletions(-) diff --git a/girepository/giobjectinfo.c b/girepository/giobjectinfo.c index 846505b7d..908e64e17 100644 --- a/girepository/giobjectinfo.c +++ b/girepository/giobjectinfo.c @@ -904,18 +904,18 @@ _get_func(GIObjectInfo *info, } /** - * gi_object_info_get_ref_function: + * gi_object_info_get_ref_function_name: * @info: a #GIObjectInfo * * Obtain the symbol name of the function that should be called to ref this * object type. It's mainly used fundamental types. The type signature for * the symbol is %GIObjectInfoRefFunction, to fetch the function pointer - * see gi_object_info_get_ref_function(). + * see gi_object_info_get_ref_function_name(). * * Returns: (nullable): the symbol or %NULL */ const char * -gi_object_info_get_ref_function (GIObjectInfo *info) +gi_object_info_get_ref_function_name (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ObjectBlob *blob; @@ -948,22 +948,22 @@ gi_object_info_get_ref_function_pointer (GIObjectInfo *info) g_return_val_if_fail (info != NULL, NULL); g_return_val_if_fail (GI_IS_OBJECT_INFO (info), NULL); - return (GIObjectInfoRefFunction)_get_func(info, (SymbolGetter)gi_object_info_get_ref_function); + return (GIObjectInfoRefFunction)_get_func(info, (SymbolGetter)gi_object_info_get_ref_function_name); } /** - * gi_object_info_get_unref_function: + * gi_object_info_get_unref_function_name: * @info: a #GIObjectInfo * * Obtain the symbol name of the function that should be called to unref this * object type. It's mainly used fundamental types. The type signature for * the symbol is %GIObjectInfoUnrefFunction, to fetch the function pointer - * see gi_object_info_get_unref_function(). + * see gi_object_info_get_unref_function_name(). * * Returns: (nullable): the symbol or %NULL */ const char * -gi_object_info_get_unref_function (GIObjectInfo *info) +gi_object_info_get_unref_function_name (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ObjectBlob *blob; @@ -996,23 +996,23 @@ gi_object_info_get_unref_function_pointer (GIObjectInfo *info) g_return_val_if_fail (info != NULL, NULL); g_return_val_if_fail (GI_IS_OBJECT_INFO (info), NULL); - return (GIObjectInfoUnrefFunction)_get_func(info, (SymbolGetter)gi_object_info_get_unref_function); + return (GIObjectInfoUnrefFunction)_get_func(info, (SymbolGetter)gi_object_info_get_unref_function_name); } /** - * gi_object_info_get_set_value_function: + * gi_object_info_get_set_value_function_name: * @info: a #GIObjectInfo * * Obtain the symbol name of the function that should be called to convert * set a GValue giving an object instance pointer of this object type. * I's mainly used fundamental types. The type signature for the symbol * is %GIObjectInfoSetValueFunction, to fetch the function pointer - * see gi_object_info_get_set_value_function(). + * see gi_object_info_get_set_value_function_name(). * * Returns: (nullable): the symbol or %NULL */ const char * -gi_object_info_get_set_value_function (GIObjectInfo *info) +gi_object_info_get_set_value_function_name (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ObjectBlob *blob; @@ -1045,23 +1045,23 @@ gi_object_info_get_set_value_function_pointer (GIObjectInfo *info) g_return_val_if_fail (info != NULL, NULL); g_return_val_if_fail (GI_IS_OBJECT_INFO (info), NULL); - return (GIObjectInfoSetValueFunction)_get_func(info, (SymbolGetter)gi_object_info_get_set_value_function); + return (GIObjectInfoSetValueFunction)_get_func(info, (SymbolGetter)gi_object_info_get_set_value_function_name); } /** - * gi_object_info_get_get_value_function: + * gi_object_info_get_get_value_function_name: * @info: a #GIObjectInfo * * Obtain the symbol name of the function that should be called to convert * an object instance pointer of this object type to a GValue. * I's mainly used fundamental types. The type signature for the symbol * is %GIObjectInfoGetValueFunction, to fetch the function pointer - * see gi_object_info_get_get_value_function(). + * see gi_object_info_get_get_value_function_name(). * * Returns: (nullable): the symbol or %NULL */ const char * -gi_object_info_get_get_value_function (GIObjectInfo *info) +gi_object_info_get_get_value_function_name (GIObjectInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; ObjectBlob *blob; @@ -1094,7 +1094,7 @@ gi_object_info_get_get_value_function_pointer (GIObjectInfo *info) g_return_val_if_fail (info != NULL, NULL); g_return_val_if_fail (GI_IS_OBJECT_INFO (info), NULL); - return (GIObjectInfoGetValueFunction)_get_func(info, (SymbolGetter)gi_object_info_get_get_value_function); + return (GIObjectInfoGetValueFunction)_get_func(info, (SymbolGetter)gi_object_info_get_get_value_function_name); } void diff --git a/girepository/giobjectinfo.h b/girepository/giobjectinfo.h index c0d4bc5f7..d6ec9023b 100644 --- a/girepository/giobjectinfo.h +++ b/girepository/giobjectinfo.h @@ -177,28 +177,28 @@ GIStructInfo * gi_object_info_get_class_struct (GIObjectInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_object_info_get_ref_function (GIObjectInfo *info); +const char * gi_object_info_get_ref_function_name (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIObjectInfoRefFunction gi_object_info_get_ref_function_pointer (GIObjectInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_object_info_get_unref_function (GIObjectInfo *info); +const char * gi_object_info_get_unref_function_name (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIObjectInfoUnrefFunction gi_object_info_get_unref_function_pointer (GIObjectInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_object_info_get_set_value_function (GIObjectInfo *info); +const char * gi_object_info_get_set_value_function_name (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIObjectInfoSetValueFunction gi_object_info_get_set_value_function_pointer (GIObjectInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_object_info_get_get_value_function (GIObjectInfo *info); +const char * gi_object_info_get_get_value_function_name (GIObjectInfo *info); GI_AVAILABLE_IN_ALL GIObjectInfoGetValueFunction gi_object_info_get_get_value_function_pointer (GIObjectInfo *info); diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 164031f32..535c4f293 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -1077,19 +1077,19 @@ write_object_info (const gchar *ns, if (is_fundamental) xml_printf (file, " glib:fundamental=\"1\""); - func = gi_object_info_get_unref_function (info); + func = gi_object_info_get_unref_function_name (info); if (func) xml_printf (file, " glib:unref-function=\"%s\"", func); - func = gi_object_info_get_ref_function (info); + func = gi_object_info_get_ref_function_name (info); if (func) xml_printf (file, " glib:ref-function=\"%s\"", func); - func = gi_object_info_get_set_value_function (info); + func = gi_object_info_get_set_value_function_name (info); if (func) xml_printf (file, " glib:set-value-function=\"%s\"", func); - func = gi_object_info_get_get_value_function (info); + func = gi_object_info_get_get_value_function_name (info); if (func) xml_printf (file, " glib:get-value-function=\"%s\"", func); From f3a02314c98d6c9b5184129f542479c160051564 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:12:17 +0000 Subject: [PATCH 12/22] girepository: Fix int signedess in repository APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girepository.c | 12 ++++++------ girepository/girepository.h | 6 +++--- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/girepository/girepository.c b/girepository/girepository.c index 1acfff26d..7ceadad81 100644 --- a/girepository/girepository.c +++ b/girepository/girepository.c @@ -719,12 +719,12 @@ gi_repository_new (void) * * Returns: number of metadata entries */ -gint +guint gi_repository_get_n_infos (GIRepository *repository, const gchar *namespace) { GITypelib *typelib; - gint n_interfaces = 0; + guint n_interfaces = 0; g_return_val_if_fail (namespace != NULL, -1); @@ -744,7 +744,7 @@ gi_repository_get_n_infos (GIRepository *repository, * @repository: (allow-none): A #GIRepository or %NULL for the singleton * process-global default #GIRepository * @namespace_: Namespace to inspect - * @index: 0-based offset into namespace metadata for entry + * @idx: 0-based offset into namespace metadata for entry * * This function returns a particular metadata entry in the * given namespace @namespace_. The namespace must have @@ -757,7 +757,7 @@ gi_repository_get_n_infos (GIRepository *repository, GIBaseInfo * gi_repository_get_info (GIRepository *repository, const gchar *namespace, - gint index) + guint idx) { GITypelib *typelib; DirEntry *entry; @@ -770,7 +770,7 @@ gi_repository_get_info (GIRepository *repository, g_return_val_if_fail (typelib != NULL, NULL); - entry = gi_typelib_get_dir_entry (typelib, index + 1); + entry = gi_typelib_get_dir_entry (typelib, idx + 1); if (entry == NULL) return NULL; return gi_info_new_full (entry->blob_type, @@ -1026,7 +1026,7 @@ gi_repository_find_by_error_domain (GIRepository *repository, void gi_repository_get_object_gtype_interfaces (GIRepository *repository, GType gtype, - guint *n_interfaces_out, + gsize *n_interfaces_out, GIInterfaceInfo ***interfaces_out) { GTypeInterfaceCache *cache; diff --git a/girepository/girepository.h b/girepository/girepository.h index 21f9d0030..3bca038a4 100644 --- a/girepository/girepository.h +++ b/girepository/girepository.h @@ -168,17 +168,17 @@ GIBaseInfo * gi_repository_find_by_gtype (GIRepository *repository, GI_AVAILABLE_IN_ALL void gi_repository_get_object_gtype_interfaces (GIRepository *repository, GType gtype, - guint *n_interfaces_out, + gsize *n_interfaces_out, GIInterfaceInfo ***interfaces_out); GI_AVAILABLE_IN_ALL -gint gi_repository_get_n_infos (GIRepository *repository, +guint gi_repository_get_n_infos (GIRepository *repository, const gchar *namespace_); GI_AVAILABLE_IN_ALL GIBaseInfo * gi_repository_get_info (GIRepository *repository, const gchar *namespace_, - gint index); + guint idx); GI_AVAILABLE_IN_ALL GIEnumInfo * gi_repository_find_by_error_domain (GIRepository *repository, From e4332bc78de1d45e0ee822dc79cc3f8dabf3a955 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:13:59 +0000 Subject: [PATCH 13/22] girepository: Fix int signedness in private GIBaseInfo APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gifunctioninfo.c | 5 ++--- girepository/girepository-private.h | 4 ++-- girepository/givfuncinfo.c | 5 ++--- 3 files changed, 6 insertions(+), 8 deletions(-) diff --git a/girepository/gifunctioninfo.c b/girepository/gifunctioninfo.c index ca8333f9e..cd31fc1f0 100644 --- a/girepository/gifunctioninfo.c +++ b/girepository/gifunctioninfo.c @@ -51,15 +51,14 @@ GIFunctionInfo * gi_base_info_find_method (GIBaseInfo *base, guint32 offset, - gint n_methods, + guint n_methods, const gchar *name) { /* FIXME hash */ GIRealInfo *rinfo = (GIRealInfo*)base; Header *header = (Header *)rinfo->typelib->data; - gint i; - for (i = 0; i < n_methods; i++) + for (guint i = 0; i < n_methods; i++) { FunctionBlob *fblob = (FunctionBlob *)&rinfo->typelib->data[offset]; const gchar *fname = (const gchar *)&rinfo->typelib->data[fblob->name]; diff --git a/girepository/girepository-private.h b/girepository/girepository-private.h index 83b9c1ef5..0146fcdf0 100644 --- a/girepository/girepository-private.h +++ b/girepository/girepository-private.h @@ -238,10 +238,10 @@ void gi_type_info_init (GIBaseInfo *info, GIFunctionInfo * gi_base_info_find_method (GIBaseInfo *base, guint32 offset, - gint n_methods, + guint n_methods, const gchar *name); GIVFuncInfo * gi_base_info_find_vfunc (GIRealInfo *rinfo, guint32 offset, - gint n_vfuncs, + guint n_vfuncs, const gchar *name); diff --git a/girepository/givfuncinfo.c b/girepository/givfuncinfo.c index 45587ab53..b581c1782 100644 --- a/girepository/givfuncinfo.c +++ b/girepository/givfuncinfo.c @@ -48,14 +48,13 @@ GIVFuncInfo * gi_base_info_find_vfunc (GIRealInfo *rinfo, guint32 offset, - gint n_vfuncs, + guint n_vfuncs, const gchar *name) { /* FIXME hash */ Header *header = (Header *)rinfo->typelib->data; - gint i; - for (i = 0; i < n_vfuncs; i++) + for (guint i = 0; i < n_vfuncs; i++) { VFuncBlob *fblob = (VFuncBlob *)&rinfo->typelib->data[offset]; const gchar *fname = (const gchar *)&rinfo->typelib->data[fblob->name]; From cacf8cc93b1d78b91fd55fa3b6cb3f1410af7942 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:18:20 +0000 Subject: [PATCH 14/22] gistructinfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girwriter.c | 7 +++---- girepository/gistructinfo.c | 13 ++++++------- girepository/gistructinfo.h | 8 ++++---- 3 files changed, 13 insertions(+), 15 deletions(-) diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 535c4f293..a070ec50c 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -650,9 +650,8 @@ write_struct_info (const gchar *ns, gboolean deprecated; gboolean is_gtype_struct; gboolean foreign; - gint i; gint size; - int n_elts; + guint n_elts; name = gi_base_info_get_name ((GIBaseInfo *)info); deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); @@ -702,14 +701,14 @@ write_struct_info (const gchar *ns, n_elts = gi_struct_info_get_n_fields (info) + gi_struct_info_get_n_methods (info); if (n_elts > 0) { - for (i = 0; i < gi_struct_info_get_n_fields (info); i++) + for (guint i = 0; i < gi_struct_info_get_n_fields (info); i++) { GIFieldInfo *field = gi_struct_info_get_field (info, i); write_field_info (ns, field, NULL, file); gi_base_info_unref ((GIBaseInfo *)field); } - for (i = 0; i < gi_struct_info_get_n_methods (info); i++) + for (guint i = 0; i < gi_struct_info_get_n_methods (info); i++) { GIFunctionInfo *function = gi_struct_info_get_method (info, i); write_function_info (ns, function, file); diff --git a/girepository/gistructinfo.c b/girepository/gistructinfo.c index eda380f2e..38d818f0f 100644 --- a/girepository/gistructinfo.c +++ b/girepository/gistructinfo.c @@ -52,7 +52,7 @@ * * Returns: number of fields */ -gint +guint gi_struct_info_get_n_fields (GIStructInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -72,15 +72,14 @@ gi_struct_info_get_n_fields (GIStructInfo *info) */ static gint32 gi_struct_get_field_offset (GIStructInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header = (Header *)rinfo->typelib->data; guint32 offset = rinfo->offset + header->struct_blob_size; - gint i; FieldBlob *field_blob; - for (i = 0; i < n; i++) + for (guint i = 0; i < n; i++) { field_blob = (FieldBlob *)&rinfo->typelib->data[offset]; offset += header->field_blob_size; @@ -103,7 +102,7 @@ gi_struct_get_field_offset (GIStructInfo *info, */ GIFieldInfo * gi_struct_info_get_field (GIStructInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -161,7 +160,7 @@ gi_struct_info_find_field (GIStructInfo *info, * * Returns: number of methods */ -gint +guint gi_struct_info_get_n_methods (GIStructInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -182,7 +181,7 @@ gi_struct_info_get_n_methods (GIStructInfo *info) */ GIFunctionInfo * gi_struct_info_get_method (GIStructInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; StructBlob *blob = (StructBlob *)&rinfo->typelib->data[rinfo->offset]; diff --git a/girepository/gistructinfo.h b/girepository/gistructinfo.h index a1c9eedbc..23067a553 100644 --- a/girepository/gistructinfo.h +++ b/girepository/gistructinfo.h @@ -43,22 +43,22 @@ G_BEGIN_DECLS GI_AVAILABLE_IN_ALL -gint gi_struct_info_get_n_fields (GIStructInfo *info); +guint gi_struct_info_get_n_fields (GIStructInfo *info); GI_AVAILABLE_IN_ALL GIFieldInfo * gi_struct_info_get_field (GIStructInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIFieldInfo * gi_struct_info_find_field (GIStructInfo *info, const gchar *name); GI_AVAILABLE_IN_ALL -gint gi_struct_info_get_n_methods (GIStructInfo *info); +guint gi_struct_info_get_n_methods (GIStructInfo *info); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_struct_info_get_method (GIStructInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_struct_info_find_method (GIStructInfo *info, From e1382877690b0e68615a750c993a1b6fbdb6654c Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:18:51 +0000 Subject: [PATCH 15/22] gistructinfo: Rename get_*_function() methods to get_*_function_name() Because they return the function name, not a `GIFunctionInfo` or anything else. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girwriter.c | 4 ++-- girepository/gistructinfo.c | 8 ++++---- girepository/gistructinfo.h | 4 ++-- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/girepository/girwriter.c b/girepository/girwriter.c index a070ec50c..6ce9caf48 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -680,11 +680,11 @@ write_struct_info (const gchar *ns, if (is_gtype_struct) xml_printf (file, " glib:is-gtype-struct=\"1\""); - func = gi_struct_info_get_copy_function (info); + func = gi_struct_info_get_copy_function_name (info); if (func) xml_printf (file, " copy-function=\"%s\"", func); - func = gi_struct_info_get_free_function (info); + func = gi_struct_info_get_free_function_name (info); if (func) xml_printf (file, " free-function=\"%s\"", func); diff --git a/girepository/gistructinfo.c b/girepository/gistructinfo.c index 38d818f0f..a9a944892 100644 --- a/girepository/gistructinfo.c +++ b/girepository/gistructinfo.c @@ -286,7 +286,7 @@ gi_struct_info_is_gtype_struct (GIStructInfo *info) } /** - * gi_struct_info_get_copy_function: + * gi_struct_info_get_copy_function_name: * @info: a struct information blob * * Retrieves the name of the copy function for @info, if any is set. @@ -296,7 +296,7 @@ gi_struct_info_is_gtype_struct (GIStructInfo *info) * Since: 2.80 */ const char * -gi_struct_info_get_copy_function (GIStructInfo *info) +gi_struct_info_get_copy_function_name (GIStructInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; StructBlob *blob; @@ -313,7 +313,7 @@ gi_struct_info_get_copy_function (GIStructInfo *info) } /** - * gi_struct_info_get_free_function: + * gi_struct_info_get_free_function_name: * @info: a struct information blob * * Retrieves the name of the free function for @info, if any is set. @@ -323,7 +323,7 @@ gi_struct_info_get_copy_function (GIStructInfo *info) * Since: 2.80 */ const char * -gi_struct_info_get_free_function (GIStructInfo *info) +gi_struct_info_get_free_function_name (GIStructInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; StructBlob *blob; diff --git a/girepository/gistructinfo.h b/girepository/gistructinfo.h index 23067a553..f124cc191 100644 --- a/girepository/gistructinfo.h +++ b/girepository/gistructinfo.h @@ -77,9 +77,9 @@ GI_AVAILABLE_IN_ALL gboolean gi_struct_info_is_foreign (GIStructInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_struct_info_get_copy_function (GIStructInfo *info); +const char * gi_struct_info_get_copy_function_name (GIStructInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_struct_info_get_free_function (GIStructInfo *info); +const char * gi_struct_info_get_free_function_name (GIStructInfo *info); G_END_DECLS From 23d9a79c620d3f4c38d3057027efcb41b1931c36 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:22:38 +0000 Subject: [PATCH 16/22] gitypeinfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girwriter.c | 5 +++-- girepository/gitypeinfo.c | 4 ++-- girepository/gitypeinfo.h | 4 ++-- 3 files changed, 7 insertions(+), 6 deletions(-) diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 6ce9caf48..3572d4d72 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -244,7 +244,8 @@ write_type_info (const gchar *ns, } else if (tag == GI_TYPE_TAG_ARRAY) { - gint length, size; + gint length; + gssize size; const char *name = NULL; xml_start_element (file, "array"); @@ -276,7 +277,7 @@ write_type_info (const gchar *ns, size = gi_type_info_get_array_fixed_size (info); if (size >= 0) - xml_printf (file, " fixed-size=\"%d\"", size); + xml_printf (file, " fixed-size=\"%" G_GSSIZE_FORMAT "\"", size); if (gi_type_info_is_zero_terminated (info)) xml_printf (file, " zero-terminated=\"1\""); diff --git a/girepository/gitypeinfo.c b/girepository/gitypeinfo.c index 71605ca65..7bb6f30b8 100644 --- a/girepository/gitypeinfo.c +++ b/girepository/gitypeinfo.c @@ -135,7 +135,7 @@ gi_type_info_get_tag (GITypeInfo *info) */ GITypeInfo * gi_type_info_get_param_type (GITypeInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; SimpleTypeBlob *type; @@ -270,7 +270,7 @@ gi_type_info_get_array_length (GITypeInfo *info) * Returns: the size or `-1` if the type is not an array * Since: 2.80 */ -gint +gssize gi_type_info_get_array_fixed_size (GITypeInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; diff --git a/girepository/gitypeinfo.h b/girepository/gitypeinfo.h index e92e82837..d493574a6 100644 --- a/girepository/gitypeinfo.h +++ b/girepository/gitypeinfo.h @@ -90,7 +90,7 @@ GITypeTag gi_type_info_get_tag (GITypeInfo *info); GI_AVAILABLE_IN_ALL GITypeInfo * gi_type_info_get_param_type (GITypeInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIBaseInfo * gi_type_info_get_interface (GITypeInfo *info); @@ -99,7 +99,7 @@ GI_AVAILABLE_IN_ALL gint gi_type_info_get_array_length (GITypeInfo *info); GI_AVAILABLE_IN_ALL -gint gi_type_info_get_array_fixed_size(GITypeInfo *info); +gssize gi_type_info_get_array_fixed_size (GITypeInfo *info); GI_AVAILABLE_IN_ALL gboolean gi_type_info_is_zero_terminated (GITypeInfo *info); From 299315007f9df2ecf0b2da71a99fe95ec4dafd9f Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:23:05 +0000 Subject: [PATCH 17/22] gitypeinfo: Rename get_array_length() to get_array_length_index() It returns the index of the array length argument, not the length itself. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girwriter.c | 2 +- girepository/gitypeinfo.c | 6 +++--- girepository/gitypeinfo.h | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 3572d4d72..77a1693f2 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -271,7 +271,7 @@ write_type_info (const gchar *ns, type = gi_type_info_get_param_type (info, 0); - length = gi_type_info_get_array_length (info); + length = gi_type_info_get_array_length_index (info); if (length >= 0) xml_printf (file, " length=\"%d\"", length); diff --git a/girepository/gitypeinfo.c b/girepository/gitypeinfo.c index 7bb6f30b8..37dbe62d2 100644 --- a/girepository/gitypeinfo.c +++ b/girepository/gitypeinfo.c @@ -226,17 +226,17 @@ gi_type_info_get_interface (GITypeInfo *info) } /** - * gi_type_info_get_array_length: + * gi_type_info_get_array_length_index: * @info: a #GITypeInfo * * Obtain the position of the argument which gives the array length of the type. * The type tag must be a `GI_TYPE_TAG_ARRAY` or `-1` will be returned. * - * Returns: the array length, or `-1` if the type is not an array + * Returns: the array length argument index, or `-1` if the type is not an array * Since: 2.80 */ gint -gi_type_info_get_array_length (GITypeInfo *info) +gi_type_info_get_array_length_index (GITypeInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; SimpleTypeBlob *type; diff --git a/girepository/gitypeinfo.h b/girepository/gitypeinfo.h index d493574a6..7076fdf46 100644 --- a/girepository/gitypeinfo.h +++ b/girepository/gitypeinfo.h @@ -96,7 +96,7 @@ GI_AVAILABLE_IN_ALL GIBaseInfo * gi_type_info_get_interface (GITypeInfo *info); GI_AVAILABLE_IN_ALL -gint gi_type_info_get_array_length (GITypeInfo *info); +gint gi_type_info_get_array_length_index (GITypeInfo *info); GI_AVAILABLE_IN_ALL gssize gi_type_info_get_array_fixed_size (GITypeInfo *info); From 5db23afe142e80b152efe797de0d14dee55c9965 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:23:40 +0000 Subject: [PATCH 18/22] gitypeinfo: Fix some precondition return values Signed-off-by: Philip Withnall --- girepository/gitypeinfo.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/girepository/gitypeinfo.c b/girepository/gitypeinfo.c index 37dbe62d2..e32f20b42 100644 --- a/girepository/gitypeinfo.c +++ b/girepository/gitypeinfo.c @@ -276,8 +276,8 @@ gi_type_info_get_array_fixed_size (GITypeInfo *info) GIRealInfo *rinfo = (GIRealInfo *)info; SimpleTypeBlob *type; - g_return_val_if_fail (info != NULL, 0); - g_return_val_if_fail (GI_IS_TYPE_INFO (info), 0); + g_return_val_if_fail (info != NULL, -1); + g_return_val_if_fail (GI_IS_TYPE_INFO (info), -1); type = (SimpleTypeBlob *)&rinfo->typelib->data[rinfo->offset]; From b10b5a2fe6ef6496fd68326840f1e256c7a7e90b Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:39:22 +0000 Subject: [PATCH 19/22] giunioninfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girwriter.c | 13 ++++++------- girepository/giunioninfo.c | 12 ++++++------ girepository/giunioninfo.h | 12 ++++++------ 3 files changed, 18 insertions(+), 19 deletions(-) diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 77a1693f2..4bde3ff59 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -1249,8 +1249,7 @@ write_union_info (const gchar *ns, const gchar *type_init; const gchar *func; gboolean deprecated; - gint i; - gint size; + gsize size; name = gi_base_info_get_name ((GIBaseInfo *)info); deprecated = gi_base_info_is_deprecated ((GIBaseInfo *)info); @@ -1268,8 +1267,8 @@ write_union_info (const gchar *ns, xml_printf (file, " deprecated=\"1\""); size = gi_union_info_get_size (info); - if (file->show_all && size >= 0) - xml_printf (file, " size=\"%d\"", size); + if (file->show_all) + xml_printf (file, " size=\"%" G_GSIZE_FORMAT "\"", size); func = gi_union_info_get_copy_function (info); if (func) @@ -1283,7 +1282,7 @@ write_union_info (const gchar *ns, if (gi_union_info_is_discriminated (info)) { - gint offset; + guint offset; GITypeInfo *type; offset = gi_union_info_get_discriminator_offset (info); @@ -1296,7 +1295,7 @@ write_union_info (const gchar *ns, gi_base_info_unref ((GIBaseInfo *)type); } - for (i = 0; i < gi_union_info_get_n_fields (info); i++) + for (guint i = 0; i < gi_union_info_get_n_fields (info); i++) { GIFieldInfo *field = gi_union_info_get_field (info, i); GIConstantInfo *constant = gi_union_info_get_discriminator (info, i); @@ -1306,7 +1305,7 @@ write_union_info (const gchar *ns, gi_base_info_unref ((GIBaseInfo *)constant); } - for (i = 0; i < gi_union_info_get_n_methods (info); i++) + for (guint i = 0; i < gi_union_info_get_n_methods (info); i++) { GIFunctionInfo *function = gi_union_info_get_method (info, i); write_function_info (ns, function, file); diff --git a/girepository/giunioninfo.c b/girepository/giunioninfo.c index d1133554d..84db7f5dd 100644 --- a/girepository/giunioninfo.c +++ b/girepository/giunioninfo.c @@ -53,7 +53,7 @@ * Returns: number of fields * Since: 2.80 */ -gint +guint gi_union_info_get_n_fields (GIUnionInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -75,7 +75,7 @@ gi_union_info_get_n_fields (GIUnionInfo *info) */ GIFieldInfo * gi_union_info_get_field (GIUnionInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; Header *header = (Header *)rinfo->typelib->data; @@ -94,7 +94,7 @@ gi_union_info_get_field (GIUnionInfo *info, * Returns: number of methods * Since: 2.80 */ -gint +guint gi_union_info_get_n_methods (GIUnionInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -116,7 +116,7 @@ gi_union_info_get_n_methods (GIUnionInfo *info) */ GIFunctionInfo * gi_union_info_get_method (GIUnionInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; UnionBlob *blob = (UnionBlob *)&rinfo->typelib->data[rinfo->offset]; @@ -157,7 +157,7 @@ gi_union_info_is_discriminated (GIUnionInfo *info) * Returns: offset, in bytes, of the discriminator * Since: 2.80 */ -gint +guint gi_union_info_get_discriminator_offset (GIUnionInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -201,7 +201,7 @@ gi_union_info_get_discriminator_type (GIUnionInfo *info) */ GIConstantInfo * gi_union_info_get_discriminator (GIUnionInfo *info, - gint n) + guint n) { GIRealInfo *rinfo = (GIRealInfo *)info; UnionBlob *blob = (UnionBlob *)&rinfo->typelib->data[rinfo->offset]; diff --git a/girepository/giunioninfo.h b/girepository/giunioninfo.h index b1d0ffe3d..74e79b00a 100644 --- a/girepository/giunioninfo.h +++ b/girepository/giunioninfo.h @@ -44,31 +44,31 @@ G_BEGIN_DECLS (gi_base_info_get_info_type ((GIBaseInfo*) info) == GI_INFO_TYPE_UNION) GI_AVAILABLE_IN_ALL -gint gi_union_info_get_n_fields (GIUnionInfo *info); +guint gi_union_info_get_n_fields (GIUnionInfo *info); GI_AVAILABLE_IN_ALL GIFieldInfo * gi_union_info_get_field (GIUnionInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL -gint gi_union_info_get_n_methods (GIUnionInfo *info); +guint gi_union_info_get_n_methods (GIUnionInfo *info); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_union_info_get_method (GIUnionInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL gboolean gi_union_info_is_discriminated (GIUnionInfo *info); GI_AVAILABLE_IN_ALL -gint gi_union_info_get_discriminator_offset (GIUnionInfo *info); +guint gi_union_info_get_discriminator_offset (GIUnionInfo *info); GI_AVAILABLE_IN_ALL GITypeInfo * gi_union_info_get_discriminator_type (GIUnionInfo *info); GI_AVAILABLE_IN_ALL GIConstantInfo * gi_union_info_get_discriminator (GIUnionInfo *info, - gint n); + guint n); GI_AVAILABLE_IN_ALL GIFunctionInfo * gi_union_info_find_method (GIUnionInfo *info, From 83c41fe09ed176ceadc1c5d1a5b19eb9a1e370f7 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:41:07 +0000 Subject: [PATCH 20/22] giunioninfo: Rename get_*_function() methods to get_*_function_name() Because they return the function name, not a `GIFunctionInfo` or anything else. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/girwriter.c | 4 ++-- girepository/giunioninfo.c | 8 ++++---- girepository/giunioninfo.h | 4 ++-- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/girepository/girwriter.c b/girepository/girwriter.c index 4bde3ff59..155bbfcc8 100644 --- a/girepository/girwriter.c +++ b/girepository/girwriter.c @@ -1270,11 +1270,11 @@ write_union_info (const gchar *ns, if (file->show_all) xml_printf (file, " size=\"%" G_GSIZE_FORMAT "\"", size); - func = gi_union_info_get_copy_function (info); + func = gi_union_info_get_copy_function_name (info); if (func) xml_printf (file, " copy-function=\"%s\"", func); - func = gi_union_info_get_free_function (info); + func = gi_union_info_get_free_function_name (info); if (func) xml_printf (file, " free-function=\"%s\"", func); diff --git a/girepository/giunioninfo.c b/girepository/giunioninfo.c index 84db7f5dd..bab59db6b 100644 --- a/girepository/giunioninfo.c +++ b/girepository/giunioninfo.c @@ -286,7 +286,7 @@ gi_union_info_get_alignment (GIUnionInfo *info) } /** - * gi_union_info_get_copy_function: + * gi_union_info_get_copy_function_name: * @info: a union information blob * * Retrieves the name of the copy function for @info, if any is set. @@ -296,7 +296,7 @@ gi_union_info_get_alignment (GIUnionInfo *info) * Since: 2.80 */ const char * -gi_union_info_get_copy_function (GIUnionInfo *info) +gi_union_info_get_copy_function_name (GIUnionInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; UnionBlob *blob; @@ -313,7 +313,7 @@ gi_union_info_get_copy_function (GIUnionInfo *info) } /** - * gi_union_info_get_free_function: + * gi_union_info_get_free_function_name: * @info: a union information blob * * Retrieves the name of the free function for @info, if any is set. @@ -323,7 +323,7 @@ gi_union_info_get_copy_function (GIUnionInfo *info) * Since: 2.80 */ const char * -gi_union_info_get_free_function (GIUnionInfo *info) +gi_union_info_get_free_function_name (GIUnionInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; UnionBlob *blob; diff --git a/girepository/giunioninfo.h b/girepository/giunioninfo.h index 74e79b00a..f0e0bbdd9 100644 --- a/girepository/giunioninfo.h +++ b/girepository/giunioninfo.h @@ -81,9 +81,9 @@ GI_AVAILABLE_IN_ALL gsize gi_union_info_get_alignment (GIUnionInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_union_info_get_copy_function (GIUnionInfo *info); +const char * gi_union_info_get_copy_function_name (GIUnionInfo *info); GI_AVAILABLE_IN_ALL -const char * gi_union_info_get_free_function (GIUnionInfo *info); +const char * gi_union_info_get_free_function_name (GIUnionInfo *info); G_END_DECLS From 9b47344f3cdbe8ce9836871e63e1cb8f94c623a2 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 18:44:37 +0000 Subject: [PATCH 21/22] givfuncinfo: Fix int signedness in APIs Signed-off-by: Philip Withnall Helps: #3155 --- girepository/givfuncinfo.c | 6 +++--- girepository/givfuncinfo.h | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/girepository/givfuncinfo.c b/girepository/givfuncinfo.c index b581c1782..4c4b0d315 100644 --- a/girepository/givfuncinfo.c +++ b/girepository/givfuncinfo.c @@ -120,7 +120,7 @@ gi_vfunc_info_get_flags (GIVFuncInfo *info) * Returns: the struct offset or `0xFFFF` if it’s unknown * Since: 2.80 */ -gint +guint gi_vfunc_info_get_offset (GIVFuncInfo *info) { GIRealInfo *rinfo = (GIRealInfo *)info; @@ -336,9 +336,9 @@ gboolean gi_vfunc_info_invoke (GIVFuncInfo *info, GType implementor, const GIArgument *in_args, - int n_in_args, + gsize n_in_args, const GIArgument *out_args, - int n_out_args, + gsize n_out_args, GIArgument *return_value, GError **error) { diff --git a/girepository/givfuncinfo.h b/girepository/givfuncinfo.h index 598064e96..f5bcc2d58 100644 --- a/girepository/givfuncinfo.h +++ b/girepository/givfuncinfo.h @@ -47,7 +47,7 @@ GI_AVAILABLE_IN_ALL GIVFuncInfoFlags gi_vfunc_info_get_flags (GIVFuncInfo *info); GI_AVAILABLE_IN_ALL -gint gi_vfunc_info_get_offset (GIVFuncInfo *info); +guint gi_vfunc_info_get_offset (GIVFuncInfo *info); GI_AVAILABLE_IN_ALL GISignalInfo * gi_vfunc_info_get_signal (GIVFuncInfo *info); @@ -64,9 +64,9 @@ GI_AVAILABLE_IN_ALL gboolean gi_vfunc_info_invoke (GIVFuncInfo *info, GType implementor, const GIArgument *in_args, - int n_in_args, + gsize n_in_args, const GIArgument *out_args, - int n_out_args, + gsize n_out_args, GIArgument *return_value, GError **error); From f55b18e11e88bd58f20ce9d7f3c29ccf9e17514e Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 12 Dec 2023 22:43:11 +0000 Subject: [PATCH 22/22] girepository: Split arguments of gi_repository_dump() Accepting two filenames as a string comma-separated string seems like a layering violation: this is a public API which could be used in places other than directly off a set of command line arguments. Move the command line argument parsing to the command line callback. Signed-off-by: Philip Withnall Helps: #3155 --- girepository/gdump.c | 42 ++++++++++++++++++++----------------- girepository/girepository.c | 7 +++++-- girepository/girepository.h | 4 +++- 3 files changed, 31 insertions(+), 22 deletions(-) diff --git a/girepository/gdump.c b/girepository/gdump.c index 416d7c3f3..883cb5dfb 100644 --- a/girepository/gdump.c +++ b/girepository/gdump.c @@ -521,33 +521,41 @@ dump_error_quark (GQuark quark, const char *symbol, GOutputStream *out) /** * gi_repository_dump: - * @arg: Comma-separated pair of input and output filenames + * @input_filename: (type filename): Input filename (for example `input.txt`) + * @output_filename: (type filename): Output filename (for example `output.xml`) * @error: a %GError * - * Argument specified is a comma-separated pair of filenames; i.e. of - * the form "input.txt,output.xml". The input file should be a + * Dump the introspection data from the types specified in @input_filename to + * @output_filename. + * + * The input file should be a * UTF-8 Unix-line-ending text file, with each line containing either - * "get-type:" followed by the name of a GType _get_type function, or - * "error-quark:" followed by the name of an error quark function. No - * extra whitespace is allowed. + * `get-type:` followed by the name of a [type@GObject.Type] `_get_type` + * function, or `error-quark:` followed by the name of an error quark function. + * No extra whitespace is allowed. * - * The output file should already exist, but be empty. This function will - * overwrite its contents. + * This function will overwrite the contents of the output file. * - * Returns: %TRUE on success, %FALSE on error + * Returns: true on success, false on error + * Since: 2.80 */ #ifndef GI_COMPILATION static gboolean -dump_irepository (const char *arg, GError **error) G_GNUC_UNUSED; +dump_irepository (const char *input_filename, + const char *output_filename, + GError **error) G_GNUC_UNUSED; static gboolean -dump_irepository (const char *arg, GError **error) +dump_irepository (const char *input_filename, + const char *output_filename, + GError **error) #else gboolean -gi_repository_dump (const char *arg, GError **error) +gi_repository_dump (const char *input_filename, + const char *output_filename, + GError **error) #endif { GHashTable *output_types; - char **args; GFile *input_file; GFile *output_file; GFileInputStream *input; @@ -567,12 +575,8 @@ gi_repository_dump (const char *arg, GError **error) return FALSE; } - args = g_strsplit (arg, ",", 2); - - input_file = g_file_new_for_path (args[0]); - output_file = g_file_new_for_path (args[1]); - - g_strfreev (args); + input_file = g_file_new_for_path (input_filename); + output_file = g_file_new_for_path (output_filename); input = g_file_read (input_file, NULL, error); g_object_unref (input_file); diff --git a/girepository/girepository.c b/girepository/girepository.c index 7ceadad81..43e48c3fd 100644 --- a/girepository/girepository.c +++ b/girepository/girepository.c @@ -1740,8 +1740,11 @@ gi_repository_introspect_cb (const char *option_name, GError **error) { GError *tmp_error = NULL; - gboolean ret = gi_repository_dump (value, &tmp_error); - if (!ret) + char **args; + + args = g_strsplit (value, ",", 2); + + if (!gi_repository_dump (args[0], args[1], &tmp_error)) { g_error ("Failed to extract GType data: %s", tmp_error->message); diff --git a/girepository/girepository.h b/girepository/girepository.h index 3bca038a4..61586d6fd 100644 --- a/girepository/girepository.h +++ b/girepository/girepository.h @@ -203,7 +203,9 @@ GOptionGroup * gi_repository_get_option_group (void); GI_AVAILABLE_IN_ALL -gboolean gi_repository_dump (const char *arg, GError **error); +gboolean gi_repository_dump (const char *input_filename, + const char *output_filename, + GError **error); /** * GIRepositoryError: