gclosure: do not copy and leak when generically marshalling return value

https://bugzilla.gnome.org/show_bug.cgi?id=674800
This commit is contained in:
Mark Nauwelaerts 2012-04-25 14:21:06 +02:00 committed by Tim-Philipp Müller
parent 24b9f61ee4
commit 10fc00b385

View File

@ -1231,7 +1231,7 @@ value_from_ffi_type (GValue *gvalue, gpointer *value)
g_value_set_boolean (gvalue, (gboolean) *int_val); g_value_set_boolean (gvalue, (gboolean) *int_val);
break; break;
case G_TYPE_STRING: case G_TYPE_STRING:
g_value_set_string (gvalue, *(gchar**)value); g_value_take_string (gvalue, *(gchar**)value);
break; break;
case G_TYPE_CHAR: case G_TYPE_CHAR:
g_value_set_schar (gvalue, (gint8) *int_val); g_value_set_schar (gvalue, (gint8) *int_val);
@ -1258,7 +1258,7 @@ value_from_ffi_type (GValue *gvalue, gpointer *value)
g_value_set_uint64 (gvalue, (guint64) *int_val); g_value_set_uint64 (gvalue, (guint64) *int_val);
break; break;
case G_TYPE_BOXED: case G_TYPE_BOXED:
g_value_set_boxed (gvalue, *(gpointer*)value); g_value_take_boxed (gvalue, *(gpointer*)value);
break; break;
case G_TYPE_ENUM: case G_TYPE_ENUM:
g_value_set_enum (gvalue, (gint) *int_val); g_value_set_enum (gvalue, (gint) *int_val);
@ -1267,13 +1267,13 @@ value_from_ffi_type (GValue *gvalue, gpointer *value)
g_value_set_flags (gvalue, (guint) *int_val); g_value_set_flags (gvalue, (guint) *int_val);
break; break;
case G_TYPE_PARAM: case G_TYPE_PARAM:
g_value_set_param (gvalue, *(gpointer*)value); g_value_take_param (gvalue, *(gpointer*)value);
break; break;
case G_TYPE_OBJECT: case G_TYPE_OBJECT:
g_value_set_object (gvalue, *(gpointer*)value); g_value_take_object (gvalue, *(gpointer*)value);
break; break;
case G_TYPE_VARIANT: case G_TYPE_VARIANT:
g_value_set_variant (gvalue, *(gpointer*)value); g_value_take_variant (gvalue, *(gpointer*)value);
break; break;
default: default:
g_warning ("value_from_ffi_type: Unsupported fundamental type: %s", g_warning ("value_from_ffi_type: Unsupported fundamental type: %s",