Add unset_*_flags functions

Implemented for element, object, pad, and pipeline

https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/issues/104
This commit is contained in:
Vivia Nikolaidou 2019-05-11 15:51:33 +03:00
parent 6403c06990
commit 1a65c674a9
4 changed files with 40 additions and 0 deletions

View file

@ -141,6 +141,8 @@ pub trait ElementExtManual: 'static {
fn set_element_flags(&self, flags: ElementFlags); fn set_element_flags(&self, flags: ElementFlags);
fn unset_element_flags(&self, flags: ElementFlags);
fn get_element_flags(&self) -> ElementFlags; fn get_element_flags(&self) -> ElementFlags;
#[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg(any(feature = "v1_10", feature = "dox"))]
@ -321,6 +323,14 @@ impl<O: IsA<Element>> ElementExtManual for O {
} }
} }
fn unset_element_flags(&self, flags: ElementFlags) {
unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;
let _guard = ::utils::MutexGuard::lock(&(*ptr).lock);
(*ptr).flags &= !flags.to_glib();
}
}
fn get_element_flags(&self) -> ElementFlags { fn get_element_flags(&self) -> ElementFlags {
unsafe { unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _; let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;

View file

@ -29,6 +29,8 @@ pub trait GstObjectExtManual: 'static {
fn set_object_flags(&self, flags: ObjectFlags); fn set_object_flags(&self, flags: ObjectFlags);
fn unset_object_flags(&self, flags: ObjectFlags);
fn get_object_flags(&self) -> ObjectFlags; fn get_object_flags(&self) -> ObjectFlags;
} }
@ -76,6 +78,14 @@ impl<O: IsA<::Object>> GstObjectExtManual for O {
} }
} }
fn unset_object_flags(&self, flags: ObjectFlags) {
unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;
let _guard = ::utils::MutexGuard::lock(&(*ptr).lock);
(*ptr).flags &= !flags.to_glib();
}
}
fn get_object_flags(&self) -> ObjectFlags { fn get_object_flags(&self) -> ObjectFlags {
unsafe { unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _; let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;

View file

@ -270,6 +270,8 @@ pub trait PadExtManual: 'static {
fn set_bin_flags(&self, flags: BinFlags); fn set_bin_flags(&self, flags: BinFlags);
fn unset_bin_flags(&self, flags: BinFlags);
fn get_bin_flags(&self) -> BinFlags; fn get_bin_flags(&self) -> BinFlags;
} }
@ -1009,6 +1011,14 @@ impl<O: IsA<Pad>> PadExtManual for O {
} }
} }
fn unset_bin_flags(&self, flags: BinFlags) {
unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;
let _guard = ::utils::MutexGuard::lock(&(*ptr).lock);
(*ptr).flags &= !flags.to_glib();
}
}
fn get_bin_flags(&self) -> BinFlags { fn get_bin_flags(&self) -> BinFlags {
unsafe { unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _; let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;

View file

@ -19,6 +19,8 @@ use PipelineFlags;
pub trait GstPipelineExtManual: 'static { pub trait GstPipelineExtManual: 'static {
fn set_pipeline_flags(&self, flags: PipelineFlags); fn set_pipeline_flags(&self, flags: PipelineFlags);
fn unset_pipeline_flags(&self, flags: PipelineFlags);
fn get_pipeline_flags(&self) -> PipelineFlags; fn get_pipeline_flags(&self) -> PipelineFlags;
} }
@ -31,6 +33,14 @@ impl<O: IsA<::Pipeline>> GstPipelineExtManual for O {
} }
} }
fn unset_pipeline_flags(&self, flags: PipelineFlags) {
unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;
let _guard = ::utils::MutexGuard::lock(&(*ptr).lock);
(*ptr).flags &= !flags.to_glib();
}
}
fn get_pipeline_flags(&self) -> PipelineFlags { fn get_pipeline_flags(&self) -> PipelineFlags {
unsafe { unsafe {
let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _; let ptr: *mut gst_sys::GstObject = self.as_ptr() as *mut _;