mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-28 15:06:15 +01:00
gvariant-core: Use gatomicrefcount for GVariant reference count
This commit is contained in:
parent
a3ad5a2ce0
commit
6d108587a4
@ -28,6 +28,7 @@
|
|||||||
#include <glib/gbytes.h>
|
#include <glib/gbytes.h>
|
||||||
#include <glib/gslice.h>
|
#include <glib/gslice.h>
|
||||||
#include <glib/gmem.h>
|
#include <glib/gmem.h>
|
||||||
|
#include <glib/grefcount.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
@ -74,7 +75,7 @@ struct _GVariant
|
|||||||
} contents;
|
} contents;
|
||||||
|
|
||||||
gint state;
|
gint state;
|
||||||
gint ref_count;
|
gatomicrefcount ref_count;
|
||||||
gsize depth;
|
gsize depth;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -488,7 +489,7 @@ g_variant_alloc (const GVariantType *type,
|
|||||||
(trusted ? STATE_TRUSTED : 0) |
|
(trusted ? STATE_TRUSTED : 0) |
|
||||||
STATE_FLOATING;
|
STATE_FLOATING;
|
||||||
value->size = (gssize) -1;
|
value->size = (gssize) -1;
|
||||||
value->ref_count = 1;
|
g_atomic_ref_count_init (&value->ref_count);
|
||||||
value->depth = 0;
|
value->depth = 0;
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
@ -632,9 +633,8 @@ void
|
|||||||
g_variant_unref (GVariant *value)
|
g_variant_unref (GVariant *value)
|
||||||
{
|
{
|
||||||
g_return_if_fail (value != NULL);
|
g_return_if_fail (value != NULL);
|
||||||
g_return_if_fail (value->ref_count > 0);
|
|
||||||
|
|
||||||
if (g_atomic_int_dec_and_test (&value->ref_count))
|
if (g_atomic_ref_count_dec (&value->ref_count))
|
||||||
{
|
{
|
||||||
if G_UNLIKELY (value->state & STATE_LOCKED)
|
if G_UNLIKELY (value->state & STATE_LOCKED)
|
||||||
g_critical ("attempting to free a locked GVariant instance. "
|
g_critical ("attempting to free a locked GVariant instance. "
|
||||||
@ -668,9 +668,8 @@ GVariant *
|
|||||||
g_variant_ref (GVariant *value)
|
g_variant_ref (GVariant *value)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (value != NULL, NULL);
|
g_return_val_if_fail (value != NULL, NULL);
|
||||||
g_return_val_if_fail (value->ref_count > 0, NULL);
|
|
||||||
|
|
||||||
g_atomic_int_inc (&value->ref_count);
|
g_atomic_ref_count_inc (&value->ref_count);
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
@ -710,7 +709,7 @@ GVariant *
|
|||||||
g_variant_ref_sink (GVariant *value)
|
g_variant_ref_sink (GVariant *value)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (value != NULL, NULL);
|
g_return_val_if_fail (value != NULL, NULL);
|
||||||
g_return_val_if_fail (value->ref_count > 0, NULL);
|
g_return_val_if_fail (!g_atomic_ref_count_compare (&value->ref_count, 0), NULL);
|
||||||
|
|
||||||
g_variant_lock (value);
|
g_variant_lock (value);
|
||||||
|
|
||||||
@ -767,7 +766,7 @@ GVariant *
|
|||||||
g_variant_take_ref (GVariant *value)
|
g_variant_take_ref (GVariant *value)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (value != NULL, NULL);
|
g_return_val_if_fail (value != NULL, NULL);
|
||||||
g_return_val_if_fail (value->ref_count > 0, NULL);
|
g_return_val_if_fail (!g_atomic_ref_count_compare (&value->ref_count, 0), NULL);
|
||||||
|
|
||||||
g_atomic_int_and (&value->state, ~STATE_FLOATING);
|
g_atomic_int_and (&value->state, ~STATE_FLOATING);
|
||||||
|
|
||||||
@ -1043,7 +1042,7 @@ g_variant_get_child_value (GVariant *value,
|
|||||||
child->state = (value->state & STATE_TRUSTED) |
|
child->state = (value->state & STATE_TRUSTED) |
|
||||||
STATE_SERIALISED;
|
STATE_SERIALISED;
|
||||||
child->size = s_child.size;
|
child->size = s_child.size;
|
||||||
child->ref_count = 1;
|
g_atomic_ref_count_init (&child->ref_count);
|
||||||
child->depth = value->depth + 1;
|
child->depth = value->depth + 1;
|
||||||
child->contents.serialised.bytes =
|
child->contents.serialised.bytes =
|
||||||
g_bytes_ref (value->contents.serialised.bytes);
|
g_bytes_ref (value->contents.serialised.bytes);
|
||||||
|
Loading…
Reference in New Issue
Block a user