devicemonitor: Use a sync bus handler for the provider to avoid accumulating all messages until the provider is stopped

Fixes https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/-/issues/981

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2755>
This commit is contained in:
Sebastian Dröge 2022-07-09 18:05:58 +03:00 committed by Tim-Philipp Müller
parent d4ae3ffef4
commit bc4914055f

View file

@ -257,7 +257,7 @@ update_hidden_providers_list (GList ** hidden, GstDeviceProvider * provider)
} }
} }
static void static GstBusSyncReply
bus_sync_message (GstBus * bus, GstMessage * message, bus_sync_message (GstBus * bus, GstMessage * message,
GstDeviceMonitor * monitor) GstDeviceMonitor * monitor)
{ {
@ -305,6 +305,10 @@ bus_sync_message (GstBus * bus, GstMessage * message,
if (matches) if (matches)
gst_bus_post (monitor->priv->bus, gst_message_ref (message)); gst_bus_post (monitor->priv->bus, gst_message_ref (message));
} }
gst_message_unref (message);
return GST_BUS_DROP;
} }
@ -335,7 +339,7 @@ gst_device_monitor_remove_provider (GstDeviceMonitor * self, guint i)
g_ptr_array_remove_index (self->priv->providers, i); g_ptr_array_remove_index (self->priv->providers, i);
bus = gst_device_provider_get_bus (provider); bus = gst_device_provider_get_bus (provider);
g_signal_handlers_disconnect_by_func (bus, bus_sync_message, self); gst_bus_set_sync_handler (bus, NULL, NULL, NULL);
gst_object_unref (bus); gst_object_unref (bus);
g_signal_handlers_disconnect_by_func (provider, provider_hidden, self); g_signal_handlers_disconnect_by_func (provider, provider_hidden, self);
@ -715,9 +719,8 @@ gst_device_monitor_add_filter_unlocked (GstDeviceMonitor * monitor,
(GCallback) provider_unhidden, monitor); (GCallback) provider_unhidden, monitor);
matched = TRUE; matched = TRUE;
gst_bus_enable_sync_message_emission (bus); gst_bus_set_sync_handler (bus, (GstBusSyncHandler) bus_sync_message,
g_signal_connect (bus, "sync-message", monitor, NULL);
G_CALLBACK (bus_sync_message), monitor);
gst_object_unref (bus); gst_object_unref (bus);
g_ptr_array_add (monitor->priv->providers, provider); g_ptr_array_add (monitor->priv->providers, provider);
} }