ximagesink: fix navigation event leak
authorVineeth T M <vineeth.tm@samsung.com>
Tue, 7 Jul 2015 10:35:40 +0000 (19:35 +0900)
committerLuis de Bethencourt <luis@debethencourt.com>
Tue, 7 Jul 2015 10:56:23 +0000 (11:56 +0100)
Create event only when pad is created
and send the event to pad.

https://bugzilla.gnome.org/show_bug.cgi?id=752041

sys/ximage/ximagesink.c

index 5be691d..a0eb5b4 100644 (file)
@@ -1525,12 +1525,9 @@ gst_x_image_sink_navigation_send_event (GstNavigation * navigation,
     GstStructure * structure)
 {
   GstXImageSink *ximagesink = GST_X_IMAGE_SINK (navigation);
-  GstEvent *event;
+  GstEvent *event = NULL;
   gint x_offset, y_offset;
   gdouble x, y;
-  GstPad *pad = NULL;
-
-  event = gst_event_new_navigation (structure);
 
   /* We are not converting the pointer coordinates as there's no hardware
      scaling done here. The only possible scaling is done by videoscale and
@@ -1560,13 +1557,9 @@ gst_x_image_sink_navigation_send_event (GstNavigation * navigation,
     gst_structure_set (structure, "pointer_y", G_TYPE_DOUBLE, y, NULL);
   }
 
-  pad = gst_pad_get_peer (GST_VIDEO_SINK_PAD (ximagesink));
-
-  if (GST_IS_PAD (pad) && GST_IS_EVENT (event)) {
-    gst_pad_send_event (pad, event);
-
-    gst_object_unref (pad);
-  }
+  event = gst_event_new_navigation (structure);
+  if (event)
+    gst_pad_push_event (GST_VIDEO_SINK_PAD (ximagesink), event);
 }
 
 static void