Commit 39bbccdf authored by Olivier Crête's avatar Olivier Crête
Browse files

pulsedevicemonitor: Index are per facility, not global

So need to keep the type of device in the device object
parent 6c8e4294
......@@ -282,7 +282,11 @@ context_subscribe_cb (pa_context * context, pa_subscription_event_type_t type,
for (item = monitor->devices; item; item = item->next) {
dev = item->data;
if (dev->device_index == idx) {
if (((facility == PA_SUBSCRIPTION_EVENT_SOURCE &&
dev->type == GST_PULSE_DEVICE_TYPE_SOURCE) ||
(facility == PA_SUBSCRIPTION_EVENT_SINK &&
dev->type == GST_PULSE_DEVICE_TYPE_SINK)) &&
dev->device_index == idx) {
gst_object_ref (dev);
break;
}
......@@ -629,6 +633,7 @@ gst_pulse_device_new (guint device_index, const gchar * device_name,
"display-name", device_name, "caps", caps, "klass", klass,
"internal-name", internal_name, NULL);
gstdev->type = type;
gstdev->device_index = device_index;
gstdev->element = element;
......
......@@ -83,6 +83,7 @@ typedef struct _GstPulseDeviceClass GstPulseDeviceClass;
struct _GstPulseDevice {
GstDevice parent;
GstPulseDeviceType type;
guint device_index;
gchar *internal_name;
const gchar *element;
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment