mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2024-11-22 01:21:05 +00:00
Get rid of unnecessary option wrapping
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/-/merge_requests/1187>
This commit is contained in:
parent
da2eb50dd3
commit
1b022a6b7c
4 changed files with 74 additions and 66 deletions
|
@ -10,7 +10,7 @@ pub enum Writable {}
|
|||
pub struct AudioBuffer<T> {
|
||||
// Has to be boxed because it contains self-references
|
||||
audio_buffer: Box<ffi::GstAudioBuffer>,
|
||||
buffer: Option<gst::Buffer>,
|
||||
buffer: gst::Buffer,
|
||||
info: crate::AudioInfo,
|
||||
phantom: PhantomData<T>,
|
||||
}
|
||||
|
@ -34,8 +34,8 @@ impl<T> AudioBuffer<T> {
|
|||
&self.info
|
||||
}
|
||||
|
||||
pub fn into_buffer(mut self) -> gst::Buffer {
|
||||
self.buffer.take().unwrap()
|
||||
pub fn into_buffer(self) -> gst::Buffer {
|
||||
unsafe { ptr::read(&mem::ManuallyDrop::new(self).buffer) }
|
||||
}
|
||||
|
||||
pub fn format(&self) -> crate::AudioFormat {
|
||||
|
@ -114,9 +114,9 @@ impl<T> AudioBuffer<T> {
|
|||
let info = self.info.clone();
|
||||
AudioBufferRef {
|
||||
audio_buffer: AudioBufferPtr::Borrowed(ptr::NonNull::from(&*self.audio_buffer)),
|
||||
buffer: Some(self.buffer()),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -159,7 +159,7 @@ impl AudioBuffer<Readable> {
|
|||
);
|
||||
Ok(Self {
|
||||
audio_buffer,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -194,7 +194,7 @@ impl AudioBuffer<Writable> {
|
|||
);
|
||||
Ok(Self {
|
||||
audio_buffer,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -225,9 +225,9 @@ impl AudioBuffer<Writable> {
|
|||
let info = self.info.clone();
|
||||
AudioBufferRef {
|
||||
audio_buffer: AudioBufferPtr::Borrowed(ptr::NonNull::from(&mut *self.audio_buffer)),
|
||||
buffer: Some(self.buffer_mut()),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -266,9 +266,9 @@ impl ops::DerefMut for AudioBufferPtr {
|
|||
pub struct AudioBufferRef<T> {
|
||||
// Has to be boxed because it contains self-references
|
||||
audio_buffer: AudioBufferPtr,
|
||||
buffer: Option<T>,
|
||||
info: crate::AudioInfo,
|
||||
unmap: bool,
|
||||
phantom: PhantomData<T>,
|
||||
}
|
||||
|
||||
impl<T> AudioBufferRef<T> {
|
||||
|
@ -360,14 +360,13 @@ impl<'a> AudioBufferRef<&'a gst::BufferRef> {
|
|||
let info = crate::AudioInfo::from_glib_none(
|
||||
&(*audio_buffer).info as *const _ as *mut ffi::GstAudioInfo,
|
||||
);
|
||||
let buffer = gst::BufferRef::from_ptr((*audio_buffer).buffer);
|
||||
Borrowed::new(Self {
|
||||
audio_buffer: AudioBufferPtr::Borrowed(ptr::NonNull::new_unchecked(
|
||||
audio_buffer as *mut _,
|
||||
)),
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
|
||||
|
@ -396,16 +395,16 @@ impl<'a> AudioBufferRef<&'a gst::BufferRef> {
|
|||
);
|
||||
Ok(Self {
|
||||
audio_buffer: AudioBufferPtr::Owned(audio_buffer),
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn buffer(&self) -> &gst::BufferRef {
|
||||
self.buffer.as_ref().unwrap()
|
||||
unsafe { gst::BufferRef::from_ptr(self.audio_buffer.buffer) }
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -416,12 +415,11 @@ impl<'a> AudioBufferRef<&'a mut gst::BufferRef> {
|
|||
let info = crate::AudioInfo::from_glib_none(
|
||||
&(*audio_buffer).info as *const _ as *mut ffi::GstAudioInfo,
|
||||
);
|
||||
let buffer = gst::BufferRef::from_mut_ptr((*audio_buffer).buffer);
|
||||
Borrowed::new(Self {
|
||||
audio_buffer: AudioBufferPtr::Borrowed(ptr::NonNull::new_unchecked(audio_buffer)),
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
|
||||
|
@ -450,16 +448,16 @@ impl<'a> AudioBufferRef<&'a mut gst::BufferRef> {
|
|||
);
|
||||
Ok(Self {
|
||||
audio_buffer: AudioBufferPtr::Owned(audio_buffer),
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn buffer_mut(&mut self) -> &mut gst::BufferRef {
|
||||
self.buffer.as_mut().unwrap()
|
||||
unsafe { gst::BufferRef::from_mut_ptr(self.audio_buffer.buffer) }
|
||||
}
|
||||
|
||||
pub fn plane_data_mut(&mut self, plane: u32) -> Result<&mut [u8], glib::BoolError> {
|
||||
|
|
|
@ -9,7 +9,7 @@ pub enum Writable {}
|
|||
|
||||
pub struct VideoFrame<T> {
|
||||
frame: ffi::GstVideoFrame,
|
||||
buffer: Option<gst::Buffer>,
|
||||
buffer: gst::Buffer,
|
||||
info: crate::VideoInfo,
|
||||
phantom: PhantomData<T>,
|
||||
}
|
||||
|
@ -41,8 +41,9 @@ impl<T> VideoFrame<T> {
|
|||
self.frame.id
|
||||
}
|
||||
|
||||
pub fn into_buffer(mut self) -> gst::Buffer {
|
||||
self.buffer.take().unwrap()
|
||||
pub fn into_buffer(self) -> gst::Buffer {
|
||||
let s = mem::ManuallyDrop::new(self);
|
||||
unsafe { ptr::read(&s.buffer) }
|
||||
}
|
||||
|
||||
#[doc(alias = "gst_video_frame_copy")]
|
||||
|
@ -223,7 +224,7 @@ impl<T> VideoFrame<T> {
|
|||
let buffer = gst::Buffer::from_glib_none(frame.buffer);
|
||||
Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
|
@ -234,9 +235,9 @@ impl<T> VideoFrame<T> {
|
|||
let info = self.info.clone();
|
||||
VideoFrameRef {
|
||||
frame,
|
||||
buffer: Some(self.buffer()),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -245,9 +246,7 @@ impl<T> VideoFrame<T> {
|
|||
}
|
||||
|
||||
pub fn into_raw(self) -> ffi::GstVideoFrame {
|
||||
let mut s = mem::ManuallyDrop::new(self);
|
||||
s.buffer = None;
|
||||
s.frame
|
||||
mem::ManuallyDrop::new(self).frame
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -284,7 +283,7 @@ impl VideoFrame<Readable> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -318,7 +317,7 @@ impl VideoFrame<Readable> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -358,7 +357,7 @@ impl VideoFrame<Writable> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -394,7 +393,7 @@ impl VideoFrame<Writable> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
buffer,
|
||||
info,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -452,9 +451,9 @@ impl VideoFrame<Writable> {
|
|||
let info = self.info.clone();
|
||||
VideoFrameRef {
|
||||
frame,
|
||||
buffer: Some(self.buffer_mut()),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -466,9 +465,9 @@ impl VideoFrame<Writable> {
|
|||
#[derive(Debug)]
|
||||
pub struct VideoFrameRef<T> {
|
||||
frame: ffi::GstVideoFrame,
|
||||
buffer: Option<T>,
|
||||
info: crate::VideoInfo,
|
||||
unmap: bool,
|
||||
phantom: PhantomData<T>,
|
||||
}
|
||||
|
||||
impl<T> VideoFrameRef<T> {
|
||||
|
@ -667,23 +666,21 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
|||
|
||||
let frame = ptr::read(frame);
|
||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
let buffer = gst::BufferRef::from_ptr(frame.buffer);
|
||||
Borrowed::new(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
|
||||
pub unsafe fn from_glib_full(frame: ffi::GstVideoFrame) -> Self {
|
||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
let buffer = gst::BufferRef::from_ptr(frame.buffer);
|
||||
Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -711,9 +708,9 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -745,16 +742,16 @@ impl<'a> VideoFrameRef<&'a gst::BufferRef> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn buffer(&self) -> &gst::BufferRef {
|
||||
self.buffer.as_ref().unwrap()
|
||||
unsafe { gst::BufferRef::from_ptr(self.frame.buffer) }
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -764,23 +761,21 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
|||
|
||||
let frame = ptr::read(frame);
|
||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
let buffer = gst::BufferRef::from_mut_ptr(frame.buffer);
|
||||
Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: false,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
pub unsafe fn from_glib_full_mut(frame: ffi::GstVideoFrame) -> Self {
|
||||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
let buffer = gst::BufferRef::from_mut_ptr(frame.buffer);
|
||||
Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -810,9 +805,9 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -846,16 +841,16 @@ impl<'a> VideoFrameRef<&'a mut gst::BufferRef> {
|
|||
let info = crate::VideoInfo(ptr::read(&frame.info));
|
||||
Ok(Self {
|
||||
frame,
|
||||
buffer: Some(buffer),
|
||||
info,
|
||||
unmap: true,
|
||||
phantom: PhantomData,
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn buffer_mut(&mut self) -> &mut gst::BufferRef {
|
||||
self.buffer.as_mut().unwrap()
|
||||
unsafe { gst::BufferRef::from_mut_ptr(self.frame.buffer) }
|
||||
}
|
||||
|
||||
pub fn comp_data_mut(&mut self, component: u32) -> Result<&mut [u8], glib::BoolError> {
|
||||
|
|
|
@ -28,7 +28,7 @@ pub struct BufferMap<'a, T> {
|
|||
}
|
||||
|
||||
pub struct MappedBuffer<T> {
|
||||
buffer: Option<Buffer>,
|
||||
buffer: Buffer,
|
||||
map_info: ffi::GstMapInfo,
|
||||
phantom: PhantomData<T>,
|
||||
}
|
||||
|
@ -118,7 +118,7 @@ impl Buffer {
|
|||
));
|
||||
if res {
|
||||
Ok(MappedBuffer {
|
||||
buffer: Some(self),
|
||||
buffer: self,
|
||||
map_info: map_info.assume_init(),
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -139,7 +139,7 @@ impl Buffer {
|
|||
));
|
||||
if res {
|
||||
Ok(MappedBuffer {
|
||||
buffer: Some(self),
|
||||
buffer: self,
|
||||
map_info: map_info.assume_init(),
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -1179,13 +1179,14 @@ impl<T> MappedBuffer<T> {
|
|||
|
||||
#[doc(alias = "get_buffer")]
|
||||
pub fn buffer(&self) -> &BufferRef {
|
||||
self.buffer.as_ref().unwrap().as_ref()
|
||||
self.buffer.as_ref()
|
||||
}
|
||||
|
||||
pub fn into_buffer(mut self) -> Buffer {
|
||||
let buffer = self.buffer.take().unwrap();
|
||||
pub fn into_buffer(self) -> Buffer {
|
||||
let mut s = mem::ManuallyDrop::new(self);
|
||||
let buffer = unsafe { ptr::read(&s.buffer) };
|
||||
unsafe {
|
||||
ffi::gst_buffer_unmap(buffer.as_mut_ptr(), &mut self.map_info);
|
||||
ffi::gst_buffer_unmap(buffer.as_mut_ptr(), &mut s.map_info);
|
||||
}
|
||||
|
||||
buffer
|
||||
|
@ -1229,10 +1230,8 @@ impl ops::DerefMut for MappedBuffer<Writable> {
|
|||
|
||||
impl<T> Drop for MappedBuffer<T> {
|
||||
fn drop(&mut self) {
|
||||
if let Some(ref buffer) = self.buffer {
|
||||
unsafe {
|
||||
ffi::gst_buffer_unmap(buffer.as_mut_ptr(), &mut self.map_info);
|
||||
}
|
||||
unsafe {
|
||||
ffi::gst_buffer_unmap(self.buffer.as_mut_ptr(), &mut self.map_info);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -23,7 +23,7 @@ pub struct MemoryMap<'a, T> {
|
|||
}
|
||||
|
||||
pub struct MappedMemory<T> {
|
||||
memory: Option<Memory>,
|
||||
memory: Memory,
|
||||
map_info: ffi::GstMapInfo,
|
||||
phantom: PhantomData<T>,
|
||||
}
|
||||
|
@ -133,7 +133,7 @@ impl Memory {
|
|||
));
|
||||
if res {
|
||||
Ok(MappedMemory {
|
||||
memory: Some(self),
|
||||
memory: self,
|
||||
map_info: map_info.assume_init(),
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -153,7 +153,7 @@ impl Memory {
|
|||
));
|
||||
if res {
|
||||
Ok(MappedMemory {
|
||||
memory: Some(self),
|
||||
memory: self,
|
||||
map_info: map_info.assume_init(),
|
||||
phantom: PhantomData,
|
||||
})
|
||||
|
@ -418,13 +418,14 @@ impl<T> MappedMemory<T> {
|
|||
|
||||
#[doc(alias = "get_memory")]
|
||||
pub fn memory(&self) -> &MemoryRef {
|
||||
self.memory.as_ref().unwrap().as_ref()
|
||||
self.memory.as_ref()
|
||||
}
|
||||
|
||||
pub fn into_memory(mut self) -> Memory {
|
||||
let memory = self.memory.take().unwrap();
|
||||
pub fn into_memory(self) -> Memory {
|
||||
let mut s = mem::ManuallyDrop::new(self);
|
||||
let memory = unsafe { ptr::read(&s.memory) };
|
||||
unsafe {
|
||||
ffi::gst_memory_unmap(memory.as_mut_ptr(), &mut self.map_info);
|
||||
ffi::gst_memory_unmap(memory.as_mut_ptr(), &mut s.map_info);
|
||||
}
|
||||
|
||||
memory
|
||||
|
@ -468,10 +469,8 @@ impl DerefMut for MappedMemory<Writable> {
|
|||
|
||||
impl<T> Drop for MappedMemory<T> {
|
||||
fn drop(&mut self) {
|
||||
if let Some(ref memory) = self.memory {
|
||||
unsafe {
|
||||
ffi::gst_memory_unmap(memory.as_mut_ptr(), &mut self.map_info);
|
||||
}
|
||||
unsafe {
|
||||
ffi::gst_memory_unmap(self.memory.as_mut_ptr(), &mut self.map_info);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -879,6 +878,23 @@ macro_rules! memory_object_wrapper {
|
|||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
#[test]
|
||||
fn test_map() {
|
||||
crate::init().unwrap();
|
||||
|
||||
let mem = crate::Memory::from_slice(vec![1, 2, 3, 4]);
|
||||
let map = mem.map_readable().unwrap();
|
||||
assert_eq!(map.as_slice(), &[1, 2, 3, 4]);
|
||||
drop(map);
|
||||
|
||||
let mem = mem.into_mapped_memory_readable().unwrap();
|
||||
assert_eq!(mem.as_slice(), &[1, 2, 3, 4]);
|
||||
|
||||
let mem = mem.into_memory();
|
||||
let map = mem.map_readable().unwrap();
|
||||
assert_eq!(map.as_slice(), &[1, 2, 3, 4]);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_dump() {
|
||||
crate::init().unwrap();
|
||||
|
|
Loading…
Reference in a new issue