Add bindings for remaining pad task functions

Especially Pad::start_task()
This commit is contained in:
Sebastian Dröge 2017-09-18 00:32:29 +03:00
parent 88f37b799c
commit dc6c7500df
5 changed files with 104 additions and 6 deletions

View file

@ -74,6 +74,7 @@ generate = [
"Gst.StackTraceFlags",
"Gst.DebugGraphDetails",
"Gst.ParseFlags",
"Gst.TaskState",
]
manual = [

View file

@ -2342,6 +2342,66 @@ impl SetValue for TagMergeMode {
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Hash)]
pub enum TaskState {
Started,
Stopped,
Paused,
#[doc(hidden)]
__Unknown(i32),
}
#[doc(hidden)]
impl ToGlib for TaskState {
type GlibType = ffi::GstTaskState;
fn to_glib(&self) -> ffi::GstTaskState {
match *self {
TaskState::Started => ffi::GST_TASK_STARTED,
TaskState::Stopped => ffi::GST_TASK_STOPPED,
TaskState::Paused => ffi::GST_TASK_PAUSED,
TaskState::__Unknown(value) => unsafe{std::mem::transmute(value)}
}
}
}
#[doc(hidden)]
impl FromGlib<ffi::GstTaskState> for TaskState {
fn from_glib(value: ffi::GstTaskState) -> Self {
skip_assert_initialized!();
match value as i32 {
0 => TaskState::Started,
1 => TaskState::Stopped,
2 => TaskState::Paused,
value => TaskState::__Unknown(value),
}
}
}
impl StaticType for TaskState {
fn static_type() -> Type {
unsafe { from_glib(ffi::gst_task_state_get_type()) }
}
}
impl<'a> FromValueOptional<'a> for TaskState {
unsafe fn from_value_optional(value: &Value) -> Option<Self> {
Some(FromValue::from_value(value))
}
}
impl<'a> FromValue<'a> for TaskState {
unsafe fn from_value(value: &Value) -> Self {
from_glib(std::mem::transmute::<i32, ffi::GstTaskState>(gobject_ffi::g_value_get_enum(value.to_glib_none().0)))
}
}
impl SetValue for TaskState {
unsafe fn set_value(value: &mut Value, this: &Self) {
gobject_ffi::g_value_set_enum(value.to_glib_none_mut().0, this.to_glib() as i32)
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Hash)]
pub enum TocEntryType {
Angle,

View file

@ -128,6 +128,7 @@ pub use self::enums::StreamError;
pub use self::enums::StreamStatusType;
pub use self::enums::StructureChangeType;
pub use self::enums::TagMergeMode;
pub use self::enums::TaskState;
pub use self::enums::TocEntryType;
pub use self::enums::TocLoopType;
pub use self::enums::TocScope;

View file

@ -15,6 +15,8 @@ use PadMode;
use PadTemplate;
#[cfg(feature = "v1_10")]
use Stream;
#[cfg(feature = "v1_12")]
use TaskState;
use ffi;
use glib;
use glib::Value;
@ -116,8 +118,8 @@ pub trait PadExt {
fn get_stream_id(&self) -> Option<String>;
//#[cfg(feature = "v1_12")]
//fn get_task_state(&self) -> /*Ignored*/TaskState;
#[cfg(feature = "v1_12")]
fn get_task_state(&self) -> TaskState;
fn has_current_caps(&self) -> bool;
@ -348,10 +350,12 @@ impl<O: IsA<Pad> + IsA<glib::object::Object>> PadExt for O {
}
}
//#[cfg(feature = "v1_12")]
//fn get_task_state(&self) -> /*Ignored*/TaskState {
// unsafe { TODO: call ffi::gst_pad_get_task_state() }
//}
#[cfg(feature = "v1_12")]
fn get_task_state(&self) -> TaskState {
unsafe {
from_glib(ffi::gst_pad_get_task_state(self.to_glib_none().0))
}
}
fn has_current_caps(&self) -> bool {
unsafe {

View file

@ -20,6 +20,7 @@ use miniobject::MiniObject;
use std::mem::transmute;
use std::ptr;
use std::mem;
use std::cell::RefCell;
use glib::{IsA, StaticType};
use glib::translate::{from_glib, from_glib_borrow, from_glib_full, from_glib_none, FromGlib,
@ -166,6 +167,8 @@ pub trait PadExtManual {
fn set_unlink_function<F>(&self, func: F)
where
F: Fn(&Pad, &::Object) + Send + Sync + 'static;
fn start_task<F: FnMut() + Send + 'static>(&self, func: F) -> bool;
}
impl<O: IsA<Pad>> PadExtManual for O {
@ -560,6 +563,17 @@ impl<O: IsA<Pad>> PadExtManual for O {
);
}
}
fn start_task<F: FnMut() + Send + 'static>(&self, func: F) -> bool {
unsafe {
from_glib(ffi::gst_pad_start_task(
self.to_glib_none().0,
Some(trampoline_pad_task),
into_raw_pad_task(func),
Some(destroy_closure_pad_task),
))
}
}
}
unsafe extern "C" fn trampoline_pad_probe(
@ -839,3 +853,21 @@ unsafe extern "C" fn destroy_closure(ptr: gpointer) {
let _guard = CallbackGuard::new();
Box::<Box<Fn()>>::from_raw(ptr as *mut _);
}
unsafe extern "C" fn trampoline_pad_task(func: gpointer) {
let _guard = CallbackGuard::new();
#[cfg_attr(feature = "cargo-clippy", allow(transmute_ptr_to_ref))]
let func: &RefCell<Box<FnMut() + Send + 'static>> = transmute(func);
(&mut *func.borrow_mut())()
}
unsafe extern "C" fn destroy_closure_pad_task(ptr: gpointer) {
let _guard = CallbackGuard::new();
Box::<RefCell<Box<FnMut() + Send + 'static>>>::from_raw(ptr as *mut _);
}
fn into_raw_pad_task<F: FnMut() + Send + 'static>(func: F) -> gpointer {
#[cfg_attr(feature = "cargo-clippy", allow(type_complexity))]
let func: Box<RefCell<Box<FnMut() + Send + 'static>>> = Box::new(RefCell::new(Box::new(func)));
Box::into_raw(func) as gpointer
}