summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Georg <mail@jensge.org>2021-07-03 23:35:34 +0200
committerJens Georg <mail@jensge.org>2021-07-03 23:41:58 +0200
commit7bef1c92bd48cd5009bac82f863dc67c2634329c (patch)
tree5544599828aaedbfeebdf62203f054754af087e4
parentd46c26bed026913b62a3f2215c268d2827630cc9 (diff)
downloadgupnp-av-7bef1c92bd48cd5009bac82f863dc67c2634329c.tar.gz
xml-util: Make AVXMLDoc a rc_box
-rw-r--r--libgupnp-av/xml-util.c24
1 files changed, 6 insertions, 18 deletions
diff --git a/libgupnp-av/xml-util.c b/libgupnp-av/xml-util.c
index b2f1a06..ba3b1d1 100644
--- a/libgupnp-av/xml-util.c
+++ b/libgupnp-av/xml-util.c
@@ -51,34 +51,22 @@ av_xml_doc_new (xmlDoc *doc)
g_return_val_if_fail (doc, NULL);
- ret = g_new0 (GUPnPAVXMLDoc, 1);
- ret->refcount = 1;
+ ret = g_rc_box_new0(GUPnPAVXMLDoc);
ret->doc = doc;
return ret;
}
-GUPnPAVXMLDoc *
-av_xml_doc_ref (GUPnPAVXMLDoc *doc)
+static void
+av_xml_doc_free (GUPnPAVXMLDoc *doc)
{
- g_return_val_if_fail (doc, NULL);
- g_return_val_if_fail (doc->refcount > 0, NULL);
- g_atomic_int_inc (&doc->refcount);
-
- return doc;
+ g_clear_pointer (&doc->doc, xmlFreeDoc);
}
void
av_xml_doc_unref (GUPnPAVXMLDoc *doc)
{
- g_return_if_fail (doc);
- g_return_if_fail (doc->refcount > 0);
-
- if (g_atomic_int_dec_and_test (&doc->refcount)) {
- xmlFreeDoc (doc->doc);
- doc->doc = NULL;
- g_free (doc);
- }
+ g_rc_box_release_full (doc, (GFreeFunc) av_xml_doc_free);
}
xmlNode *
@@ -570,4 +558,4 @@ av_xml_util_get_ns (xmlDocPtr doc, GUPnPXMLNamespace ns, xmlNsPtr *ns_out)
return tmp_ns;
}
-G_DEFINE_BOXED_TYPE (GUPnPAVXMLDoc, av_xml_doc, av_xml_doc_ref, av_xml_doc_unref)
+G_DEFINE_BOXED_TYPE (GUPnPAVXMLDoc, av_xml_doc, g_rc_box_acquire, av_xml_doc_unref)