mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2024-12-27 07:56:14 +01:00
girepository: Fix leak in g_callable_info_invoke
Found by Coverity. https://bugzilla.redhat.com/show_bug.cgi?id=1938731
This commit is contained in:
parent
c2ded0a667
commit
62b1ebd822
@ -638,6 +638,7 @@ g_callable_info_invoke (GIFunctionInfo *info,
|
||||
case GI_DIRECTION_IN:
|
||||
tinfo = g_arg_info_get_type (ainfo);
|
||||
atypes[i+offset] = g_type_info_get_ffi_type (tinfo);
|
||||
g_base_info_unref ((GIBaseInfo *)ainfo);
|
||||
g_base_info_unref ((GIBaseInfo *)tinfo);
|
||||
|
||||
if (in_pos >= n_in_args)
|
||||
@ -655,6 +656,7 @@ g_callable_info_invoke (GIFunctionInfo *info,
|
||||
break;
|
||||
case GI_DIRECTION_OUT:
|
||||
atypes[i+offset] = &ffi_type_pointer;
|
||||
g_base_info_unref ((GIBaseInfo *)ainfo);
|
||||
|
||||
if (out_pos >= n_out_args)
|
||||
{
|
||||
@ -670,6 +672,7 @@ g_callable_info_invoke (GIFunctionInfo *info,
|
||||
break;
|
||||
case GI_DIRECTION_INOUT:
|
||||
atypes[i+offset] = &ffi_type_pointer;
|
||||
g_base_info_unref ((GIBaseInfo *)ainfo);
|
||||
|
||||
if (in_pos >= n_in_args)
|
||||
{
|
||||
@ -694,9 +697,9 @@ g_callable_info_invoke (GIFunctionInfo *info,
|
||||
out_pos++;
|
||||
break;
|
||||
default:
|
||||
g_base_info_unref ((GIBaseInfo *)ainfo);
|
||||
g_assert_not_reached ();
|
||||
}
|
||||
g_base_info_unref ((GIBaseInfo *)ainfo);
|
||||
}
|
||||
|
||||
if (throws)
|
||||
|
Loading…
Reference in New Issue
Block a user