summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorРуслан Ижбулатов <lrn1986@gmail.com>2014-07-31 10:12:59 +0000
committerРуслан Ижбулатов <lrn1986@gmail.com>2014-07-31 10:39:54 +0000
commit905a8e655c4f50f655cbd90455b26a37b977c563 (patch)
tree92d056a2a492a9dc4f23eb03f6e5951dbf412cd5
parentad4f7846569980c54c29aac55ace01b20ba9b3d2 (diff)
Ensure critial sections are released before returning
https://bugzilla.gnome.org/show_bug.cgi?id=734035
-rw-r--r--gio/gregistrysettingsbackend.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/gio/gregistrysettingsbackend.c b/gio/gregistrysettingsbackend.c
index 396159cda..cf9da0b79 100644
--- a/gio/gregistrysettingsbackend.c
+++ b/gio/gregistrysettingsbackend.c
@@ -1754,8 +1754,12 @@ watch_add_notify (GRegistryBackend *self,
EnterCriticalSection (self->cache_lock);
cache_node = registry_cache_get_node_for_key (self->cache_root, gsettings_prefix, TRUE);
- g_return_val_if_fail (cache_node != NULL, FALSE);
- g_return_val_if_fail (cache_node->data != NULL, FALSE);
+ if (cache_node == NULL || cache_node->data == NULL)
+ {
+ LeaveCriticalSection (self->cache_lock);
+ g_warn_if_reached ();
+ return FALSE;
+ }
cache_item = cache_node->data;
@@ -1764,6 +1768,7 @@ watch_add_notify (GRegistryBackend *self,
{
trace ("watch_add_notify: prefix %s already watched, %i subscribers.\n",
gsettings_prefix, cache_item->subscription_count);
+ LeaveCriticalSection (self->cache_lock);
return FALSE;
}