summaryrefslogtreecommitdiff
path: root/devel/glib20/files/patch-gio_kqueue_kqueue-helper.c
diff options
context:
space:
mode:
Diffstat (limited to 'devel/glib20/files/patch-gio_kqueue_kqueue-helper.c')
-rw-r--r--devel/glib20/files/patch-gio_kqueue_kqueue-helper.c96
1 files changed, 0 insertions, 96 deletions
diff --git a/devel/glib20/files/patch-gio_kqueue_kqueue-helper.c b/devel/glib20/files/patch-gio_kqueue_kqueue-helper.c
deleted file mode 100644
index 0b6b00f91e3b..000000000000
--- a/devel/glib20/files/patch-gio_kqueue_kqueue-helper.c
+++ /dev/null
@@ -1,96 +0,0 @@
-This bug combines serveral patches:
-https://bugzilla.gnome.org/show_bug.cgi?id=778515
-and
-https://bugzilla.gnome.org/show_bug.cgi?id=739424
-https://bug739424.bugzilla-attachments.gnome.org/attachment.cgi?id=351191
-
-https://bugzilla.gnome.org/show_bug.cgi?id=776147
-https://git.gnome.org/browse/glib/commit/?id=76072a2dde4a4acc8be8d3c47efbc6811ebe0c1e
-
---- gio/kqueue/kqueue-helper.c.orig 2018-01-28 21:18:25.213606000 +0100
-+++ gio/kqueue/kqueue-helper.c 2018-01-28 21:18:34.964780000 +0100
-@@ -43,7 +43,7 @@ static gboolean kh_debug_enabled = FALSE;
- #define KH_W if (kh_debug_enabled) g_warning
-
- static GHashTable *subs_hash_table = NULL;
--G_LOCK_DEFINE_STATIC (hash_lock);
-+G_LOCK_DEFINE (hash_lock);
-
- static int kqueue_descriptor = -1;
- static int kqueue_socket_pair[] = {-1, -1};
-@@ -97,8 +97,10 @@ convert_kqueue_events_to_gio (uint32_t flags, gboolean
- }
- if (flags & NOTE_RENAME)
- {
-+ /* Since there’s apparently no way to get the new name of the file out of
-+ * kqueue(), all we can do is say that this one has been deleted. */
- *done = TRUE;
-- return G_FILE_MONITOR_EVENT_MOVED;
-+ return G_FILE_MONITOR_EVENT_DELETED;
- }
- if (flags & NOTE_REVOKE)
- {
-@@ -291,10 +293,10 @@ process_kqueue_notifications (GIOChannel *gioc,
-
- G_LOCK (hash_lock);
- sub = (kqueue_sub *) g_hash_table_lookup (subs_hash_table, GINT_TO_POINTER (n.fd));
-- G_UNLOCK (hash_lock);
-
- if (sub == NULL)
- {
-+ G_UNLOCK (hash_lock);
- KH_W ("Got a notification for a deleted or non-existing subscription %d",
- n.fd);
- return TRUE;
-@@ -336,6 +338,7 @@ process_kqueue_notifications (GIOChannel *gioc,
- g_file_monitor_source_handle_event (source, mask, NULL, NULL, NULL, g_get_monotonic_time ());
- }
-
-+ G_UNLOCK (hash_lock);
- return TRUE;
- }
-
-@@ -451,13 +454,14 @@ _kh_start_watching (kqueue_sub *sub)
-
- G_LOCK (hash_lock);
- g_hash_table_insert (subs_hash_table, GINT_TO_POINTER (sub->fd), sub);
-- G_UNLOCK (hash_lock);
-
- _kqueue_thread_push_fd (sub->fd);
-
- /* Bump the kqueue thread. It will pick up a new sub entry to monitor */
- if (!_ku_write (kqueue_socket_pair[0], "A", 1))
- KH_W ("Failed to bump the kqueue thread (add fd, error %d)", errno);
-+ G_UNLOCK (hash_lock);
-+
- return TRUE;
- }
-
-@@ -498,22 +502,15 @@ _kh_add_sub (kqueue_sub *sub)
- gboolean
- _kh_cancel_sub (kqueue_sub *sub)
- {
-- gboolean missing = FALSE;
-+ gboolean removed = FALSE;
- g_assert (kqueue_socket_pair[0] != -1);
- g_assert (sub != NULL);
-
-- G_LOCK (hash_lock);
-- missing = !g_hash_table_remove (subs_hash_table, GINT_TO_POINTER (sub->fd));
-- G_UNLOCK (hash_lock);
-+ _km_remove (sub);
-
-- if (missing)
-- {
-- /* If there were no fd for this subscription, file is still
-- * missing. */
-- KH_W ("Removing subscription from missing");
-- _km_remove (sub);
-- }
-- else
-+ removed = g_hash_table_remove (subs_hash_table, GINT_TO_POINTER (sub->fd));
-+
-+ if (removed)
- {
- /* fd will be closed in the kqueue thread */
- _kqueue_thread_remove_fd (sub->fd);