mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2024-05-20 17:28:26 +00:00
3282c77a6d
This fixes various memory-safety issues caused by broken reference counting. We have to handle pre-1.14 and post-1.14 differently in constructors. See https://bugzilla.gnome.org/show_bug.cgi?id=743062#c30
69 lines
1.8 KiB
Rust
69 lines
1.8 KiB
Rust
// This file was generated by gir (https://github.com/gtk-rs/gir @ fe7a6ff)
|
|
// from gir-files (https://github.com/gtk-rs/gir-files @ ???)
|
|
// DO NOT EDIT
|
|
|
|
use Object;
|
|
use ffi;
|
|
use glib;
|
|
use glib::object::IsA;
|
|
use glib::translate::*;
|
|
use glib_ffi;
|
|
use gobject_ffi;
|
|
use std::mem;
|
|
use std::ptr;
|
|
|
|
glib_wrapper! {
|
|
pub struct BufferPool(Object<ffi::GstBufferPool, ffi::GstBufferPoolClass>): Object;
|
|
|
|
match fn {
|
|
get_type => || ffi::gst_buffer_pool_get_type(),
|
|
}
|
|
}
|
|
|
|
unsafe impl Send for BufferPool {}
|
|
unsafe impl Sync for BufferPool {}
|
|
|
|
pub trait BufferPoolExt {
|
|
fn get_options(&self) -> Vec<String>;
|
|
|
|
fn has_option(&self, option: &str) -> bool;
|
|
|
|
fn is_active(&self) -> bool;
|
|
|
|
fn set_active(&self, active: bool) -> Result<(), glib::error::BoolError>;
|
|
|
|
fn set_flushing(&self, flushing: bool);
|
|
}
|
|
|
|
impl<O: IsA<BufferPool>> BufferPoolExt for O {
|
|
fn get_options(&self) -> Vec<String> {
|
|
unsafe {
|
|
FromGlibPtrContainer::from_glib_none(ffi::gst_buffer_pool_get_options(self.to_glib_none().0))
|
|
}
|
|
}
|
|
|
|
fn has_option(&self, option: &str) -> bool {
|
|
unsafe {
|
|
from_glib(ffi::gst_buffer_pool_has_option(self.to_glib_none().0, option.to_glib_none().0))
|
|
}
|
|
}
|
|
|
|
fn is_active(&self) -> bool {
|
|
unsafe {
|
|
from_glib(ffi::gst_buffer_pool_is_active(self.to_glib_none().0))
|
|
}
|
|
}
|
|
|
|
fn set_active(&self, active: bool) -> Result<(), glib::error::BoolError> {
|
|
unsafe {
|
|
glib::error::BoolError::from_glib(ffi::gst_buffer_pool_set_active(self.to_glib_none().0, active.to_glib()), "Failed to activate buffer pool")
|
|
}
|
|
}
|
|
|
|
fn set_flushing(&self, flushing: bool) {
|
|
unsafe {
|
|
ffi::gst_buffer_pool_set_flushing(self.to_glib_none().0, flushing.to_glib());
|
|
}
|
|
}
|
|
}
|