Fix handling of pad probe info data for real

The miniobjects passed are never going to be writeable due to the
additional reference, but can safely be replaced.
This commit is contained in:
Sebastian Dröge 2017-07-29 13:52:46 +01:00
parent 69e1fdd529
commit 5afa1858ed

View file

@ -19,8 +19,7 @@ use std::mem::transmute;
use std::ptr; use std::ptr;
use glib::{IsA, StaticType}; use glib::{IsA, StaticType};
use glib::translate::{ToGlib, FromGlib, from_glib, from_glib_none, from_glib_borrow, use glib::translate::{ToGlib, FromGlib, from_glib, from_glib_none, from_glib_full};
from_glib_full};
use glib::source::CallbackGuard; use glib::source::CallbackGuard;
use glib_ffi::gpointer; use glib_ffi::gpointer;
@ -165,12 +164,12 @@ unsafe extern "C" fn trampoline_pad_probe(
if (*data).type_ == Buffer::static_type().to_glib() { if (*data).type_ == Buffer::static_type().to_glib() {
data_type = Some(Buffer::static_type()); data_type = Some(Buffer::static_type());
Some(PadProbeData::Buffer( Some(PadProbeData::Buffer(
from_glib_borrow(data as *const ffi::GstBuffer), from_glib_none(data as *const ffi::GstBuffer),
)) ))
} else if (*data).type_ == BufferList::static_type().to_glib() { } else if (*data).type_ == BufferList::static_type().to_glib() {
data_type = Some(BufferList::static_type()); data_type = Some(BufferList::static_type());
Some(PadProbeData::BufferList( Some(PadProbeData::BufferList(
from_glib_borrow(data as *const ffi::GstBufferList), from_glib_none(data as *const ffi::GstBufferList),
)) ))
} else { } else {
Some(PadProbeData::Unknown) Some(PadProbeData::Unknown)