Make the g_value_set_x_take_ownership() functions "official" part of the

2003-09-12  Matthias Clasen  <maclas@gmx.de>

	Make the g_value_set_x_take_ownership() functions "official"
	part of the API (#100948):

	* gvaluetypes.[hc]: Add g_value_take_string() (synonym to the
	now deprecated g_value_set_string_take_ownership()).

	* gparam.[hc]: Add g_value_take_param() (synonym to the
	now deprecated g_value_set_param_take_ownership()).

	* gobject.[hc]: Add g_value_take_object() (synonym to the
	now deprecated g_value_set_object_take_ownership()).

	* gboxed.[hc]: Add g_value_take_boxed() (synonym to the
	now deprecated g_value_set_boxed_take_ownership()).

	* gobject/gobject-sections.txt: Add new g_value_take_x() functions.

	* gobject/tmpl/param_value_types.sgml: Document new g_value_take_x()
	functions.  (#100948)
This commit is contained in:
Matthias Clasen 2003-09-12 20:11:38 +00:00 committed by Matthias Clasen
parent 7c9f0a10f5
commit c3acb9da0c
12 changed files with 127 additions and 9 deletions

View File

@ -1,3 +1,10 @@
2003-09-12 Matthias Clasen <maclas@gmx.de>
* gobject/gobject-sections.txt: Add new g_value_take_x() functions.
* gobject/tmpl/param_value_types.sgml: Document new g_value_take_x()
functions. (#100948)
2003-08-05 Matthias Clasen <maclas@gmx.de> 2003-08-05 Matthias Clasen <maclas@gmx.de>
* glib/tmpl/string_utils.sgml: Add note about in-place editing to g_strdelimit() doc. * glib/tmpl/string_utils.sgml: Add note about in-place editing to g_strdelimit() doc.

View File

@ -525,6 +525,7 @@ gchararray
g_param_spec_string g_param_spec_string
g_value_set_string g_value_set_string
g_value_set_static_string g_value_set_static_string
g_value_take_string
g_value_set_string_take_ownership g_value_set_string_take_ownership
g_value_get_string g_value_get_string
g_value_dup_string g_value_dup_string
@ -537,6 +538,7 @@ G_TYPE_PARAM_PARAM
GParamSpecParam GParamSpecParam
g_param_spec_param g_param_spec_param
g_value_set_param g_value_set_param
g_value_take_param
g_value_set_param_take_ownership g_value_set_param_take_ownership
g_value_get_param g_value_get_param
g_value_dup_param g_value_dup_param
@ -550,6 +552,7 @@ GParamSpecBoxed
g_param_spec_boxed g_param_spec_boxed
g_value_set_boxed g_value_set_boxed
g_value_set_static_boxed g_value_set_static_boxed
g_value_take_boxed
g_value_set_boxed_take_ownership g_value_set_boxed_take_ownership
g_value_get_boxed g_value_get_boxed
g_value_dup_boxed g_value_dup_boxed
@ -572,6 +575,7 @@ G_TYPE_PARAM_OBJECT
GParamSpecObject GParamSpecObject
g_param_spec_object g_param_spec_object
g_value_set_object g_value_set_object
g_value_take_object
g_value_set_object_take_ownership g_value_set_object_take_ownership
g_value_get_object g_value_get_object
g_value_dup_object g_value_dup_object

View File

@ -1102,6 +1102,16 @@ when setting the #GValue.
@v_string: static string to be set @v_string: static string to be set
<!-- ##### FUNCTION g_value_take_string ##### -->
<para>
Sets the contents of a %G_TYPE_STRING #GValue to @v_string.
</para>
@value: a valid #GValue of type %G_TYPE_STRING
@v_string: duplicated unowned string to be set
@Since: 2.4
<!-- ##### FUNCTION g_value_set_string_take_ownership ##### --> <!-- ##### FUNCTION g_value_set_string_take_ownership ##### -->
<para> <para>
This is an internal function introduced mainly for C marshallers. This is an internal function introduced mainly for C marshallers.
@ -1109,9 +1119,7 @@ This is an internal function introduced mainly for C marshallers.
@value: a valid #GValue of type %G_TYPE_STRING @value: a valid #GValue of type %G_TYPE_STRING
@v_string: duplicated unowned string to be set @v_string: duplicated unowned string to be set
<!-- # Unused Parameters # --> @Deprecated: Use g_value_take_string() instead.
@value: a valid #GValue
@v_string: string to be set
<!-- ##### FUNCTION g_value_get_string ##### --> <!-- ##### FUNCTION g_value_get_string ##### -->
@ -1199,6 +1207,18 @@ Set the contents of a %G_TYPE_PARAM #GValue to @param.
@param: the #GParamSpec to be set @param: the #GParamSpec to be set
<!-- ##### FUNCTION g_value_take_param ##### -->
<para>
Sets the contents of a %G_TYPE_PARAM #GValue to @param and
takes over the ownership of the callers reference to @param;
the caller doesn't have to unref it any more.
</para>
@value: a valid #GValue of type %G_TYPE_PARAM
@param: the #GParamSpec to be set
@Since: 2.4
<!-- ##### FUNCTION g_value_set_param_take_ownership ##### --> <!-- ##### FUNCTION g_value_set_param_take_ownership ##### -->
<para> <para>
This is an internal function introduced mainly for C marshallers. This is an internal function introduced mainly for C marshallers.
@ -1206,6 +1226,7 @@ This is an internal function introduced mainly for C marshallers.
@value: a valid #GValue of type %G_TYPE_PARAM @value: a valid #GValue of type %G_TYPE_PARAM
@param: the #GParamSpec to be set @param: the #GParamSpec to be set
@Deprecated: Use g_value_take_param() instead.
<!-- ##### FUNCTION g_value_get_param ##### --> <!-- ##### FUNCTION g_value_get_param ##### -->
@ -1301,6 +1322,18 @@ when setting the #GValue.
@v_boxed: static boxed value to be set @v_boxed: static boxed value to be set
<!-- ##### FUNCTION g_value_take_boxed ##### -->
<para>
Sets the contents of a %G_TYPE_BOXED derived #GValue to @v_boxed and
takes over the ownership of the callers reference to @v_boxed;
the caller doesn't have to unref it any more.
</para>
@value: a valid #GValue of %G_TYPE_BOXED derived type
@v_boxed: duplicated unowned boxed value to be set
@Since: 2.4
<!-- ##### FUNCTION g_value_set_boxed_take_ownership ##### --> <!-- ##### FUNCTION g_value_set_boxed_take_ownership ##### -->
<para> <para>
This is an internal function introduced mainly for C marshallers. This is an internal function introduced mainly for C marshallers.
@ -1308,6 +1341,7 @@ This is an internal function introduced mainly for C marshallers.
@value: a valid #GValue of %G_TYPE_BOXED derived type @value: a valid #GValue of %G_TYPE_BOXED derived type
@v_boxed: duplicated unowned boxed value to be set @v_boxed: duplicated unowned boxed value to be set
@Deprecated: Use g_value_take_boxed() instead.
<!-- ##### FUNCTION g_value_get_boxed ##### --> <!-- ##### FUNCTION g_value_get_boxed ##### -->
@ -1465,6 +1499,18 @@ Set the contents of a %G_TYPE_OBJECT derived #GValue to @v_object.
@v_object: object value to be set @v_object: object value to be set
<!-- ##### FUNCTION g_value_take_object ##### -->
<para>
Sets the contents of a %G_TYPE_OBJECT derived #GValue to @v_object
and takes over the ownership of the callers reference to @v_object;
the caller doesn't have to unref it any more.
</para>
@value: a valid #GValue of %G_TYPE_OBJECT derived type
@v_object: object value to be set
@Since: 2.4
<!-- ##### FUNCTION g_value_set_object_take_ownership ##### --> <!-- ##### FUNCTION g_value_set_object_take_ownership ##### -->
<para> <para>
This is an internal function introduced mainly for C marshallers. This is an internal function introduced mainly for C marshallers.
@ -1472,6 +1518,7 @@ This is an internal function introduced mainly for C marshallers.
@value: a valid #GValue of %G_TYPE_OBJECT derived type @value: a valid #GValue of %G_TYPE_OBJECT derived type
@v_object: object value to be set @v_object: object value to be set
@Deprecated: Use g_value_take_object() instead.
<!-- ##### FUNCTION g_value_get_object ##### --> <!-- ##### FUNCTION g_value_get_object ##### -->

View File

@ -1,3 +1,20 @@
2003-09-12 Matthias Clasen <maclas@gmx.de>
Make the g_value_set_x_take_ownership() functions "official"
part of the API (#100948):
* gvaluetypes.[hc]: Add g_value_take_string() (synonym to the
now deprecated g_value_set_string_take_ownership()).
* gparam.[hc]: Add g_value_take_param() (synonym to the
now deprecated g_value_set_param_take_ownership()).
* gobject.[hc]: Add g_value_take_object() (synonym to the
now deprecated g_value_set_object_take_ownership()).
* gboxed.[hc]: Add g_value_take_boxed() (synonym to the
now deprecated g_value_set_boxed_take_ownership()).
Tue Sep 2 19:37:21 2003 Tim Janik <timj@gtk.org> Tue Sep 2 19:37:21 2003 Tim Janik <timj@gtk.org>
* gtype.[hc]: added support for a "default vtable" per interface, * gtype.[hc]: added support for a "default vtable" per interface,
@ -72,6 +89,11 @@ Tue Aug 19 01:31:28 2003 Tim Janik <timj@gtk.org>
* gsignal.c: added optimizations to skip NOP signal emissions. * gsignal.c: added optimizations to skip NOP signal emissions.
2003-08-08 Matthias Clasen <maclas@gmx.de>
* gobject.c (object_set_property): Improve the wording of the warning for invalid
values. (#117246, Mariano Suarez-Alvarez)
Wed Aug 6 09:57:14 2003 Owen Taylor <otaylor@redhat.com> Wed Aug 6 09:57:14 2003 Owen Taylor <otaylor@redhat.com>
* testgobject.c (test_signal_accumulator): Add check * testgobject.c (test_signal_accumulator): Add check

View File

@ -503,6 +503,13 @@ g_value_set_static_boxed (GValue *value,
void void
g_value_set_boxed_take_ownership (GValue *value, g_value_set_boxed_take_ownership (GValue *value,
gconstpointer boxed) gconstpointer boxed)
{
g_value_take_boxed (value, boxed);
}
void
g_value_take_boxed (GValue *value,
gconstpointer boxed)
{ {
g_return_if_fail (G_VALUE_HOLDS_BOXED (value)); g_return_if_fail (G_VALUE_HOLDS_BOXED (value));
g_return_if_fail (G_TYPE_IS_VALUE (G_VALUE_TYPE (value))); g_return_if_fail (G_TYPE_IS_VALUE (G_VALUE_TYPE (value)));

View File

@ -63,9 +63,12 @@ GType g_boxed_type_register_static (const gchar *name,
#define G_TYPE_GSTRING (g_gstring_get_type ()) #define G_TYPE_GSTRING (g_gstring_get_type ())
/* --- internal (marshaller specific) --- */ void g_value_take_boxed (GValue *value,
gconstpointer v_boxed);
#ifndef G_DISABLE_DEPRECATED
void g_value_set_boxed_take_ownership (GValue *value, void g_value_set_boxed_take_ownership (GValue *value,
gconstpointer v_boxed); gconstpointer v_boxed);
#endif
GType g_closure_get_type (void) G_GNUC_CONST; GType g_closure_get_type (void) G_GNUC_CONST;
GType g_value_get_type (void) G_GNUC_CONST; GType g_value_get_type (void) G_GNUC_CONST;
GType g_value_array_get_type (void) G_GNUC_CONST; GType g_value_array_get_type (void) G_GNUC_CONST;

View File

@ -1532,6 +1532,13 @@ g_value_set_object (GValue *value,
void void
g_value_set_object_take_ownership (GValue *value, g_value_set_object_take_ownership (GValue *value,
gpointer v_object) gpointer v_object)
{
g_value_take_object (value, v_object);
}
void
g_value_take_object (GValue *value,
gpointer v_object)
{ {
g_return_if_fail (G_VALUE_HOLDS_OBJECT (value)); g_return_if_fail (G_VALUE_HOLDS_OBJECT (value));

View File

@ -210,10 +210,12 @@ gulong g_signal_connect_object (gpointer instance,
void g_object_run_dispose (GObject *object); void g_object_run_dispose (GObject *object);
/* --- marshaller specific --- */ void g_value_take_object (GValue *value,
gpointer v_object);
#ifndef G_DISABLE_DEPRECATED
void g_value_set_object_take_ownership (GValue *value, void g_value_set_object_take_ownership (GValue *value,
gpointer v_object); gpointer v_object);
#endif
/* --- implementation macros --- */ /* --- implementation macros --- */
#define G_OBJECT_WARN_INVALID_PSPEC(object, pname, property_id, pspec) \ #define G_OBJECT_WARN_INVALID_PSPEC(object, pname, property_id, pspec) \

View File

@ -982,6 +982,13 @@ g_value_set_param (GValue *value,
void void
g_value_set_param_take_ownership (GValue *value, g_value_set_param_take_ownership (GValue *value,
GParamSpec *param) GParamSpec *param)
{
g_value_take_param (value, param);
}
void
g_value_take_param (GValue *value,
GParamSpec *param)
{ {
g_return_if_fail (G_VALUE_HOLDS_PARAM (value)); g_return_if_fail (G_VALUE_HOLDS_PARAM (value));
if (param) if (param)

View File

@ -144,10 +144,12 @@ GParamSpec* g_value_get_param (const GValue *value);
GParamSpec* g_value_dup_param (const GValue *value); GParamSpec* g_value_dup_param (const GValue *value);
/* --- marshaller specific --- */ void g_value_take_param (GValue *value,
GParamSpec *param);
#ifndef G_DISABLE_DEPRECATED
void g_value_set_param_take_ownership (GValue *value, void g_value_set_param_take_ownership (GValue *value,
GParamSpec *param); GParamSpec *param);
#endif
/* --- convenience functions --- */ /* --- convenience functions --- */
typedef struct _GParamSpecTypeInfo GParamSpecTypeInfo; typedef struct _GParamSpecTypeInfo GParamSpecTypeInfo;

View File

@ -762,6 +762,13 @@ g_value_set_static_string (GValue *value,
void void
g_value_set_string_take_ownership (GValue *value, g_value_set_string_take_ownership (GValue *value,
gchar *v_string) gchar *v_string)
{
g_value_take_string (value, v_string);
}
void
g_value_take_string (GValue *value,
gchar *v_string)
{ {
g_return_if_fail (G_VALUE_HOLDS_STRING (value)); g_return_if_fail (G_VALUE_HOLDS_STRING (value));

View File

@ -97,9 +97,12 @@ GType g_pointer_type_register_static (const gchar *name);
gchar* g_strdup_value_contents (const GValue *value); gchar* g_strdup_value_contents (const GValue *value);
/* --- marshaller specific --- */ void g_value_take_string (GValue *value,
gchar *v_string);
#ifndef G_DISABLE_DEPRECATED
void g_value_set_string_take_ownership (GValue *value, void g_value_set_string_take_ownership (GValue *value,
gchar *v_string); gchar *v_string);
#endif
/* humpf, need a C representable type name for G_TYPE_STRING */ /* humpf, need a C representable type name for G_TYPE_STRING */