1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
// This file was generated by gir (https://github.com/gtk-rs/gir) // from gir-files (https://github.com/gtk-rs/gir-files) // DO NOT EDIT use glib::object::IsA; use glib::translate::*; use gst_sys; use Object; glib_wrapper! { /// Memory is usually created by allocators with a `AllocatorExt::alloc` /// method call. When `None` is used as the allocator, the default allocator will /// be used. /// /// New allocators can be registered with `Allocator::register`. /// Allocators are identified by name and can be retrieved with /// `Allocator::find`. `AllocatorExt::set_default` can be used to change the /// default allocator. /// /// New memory can be created with `Memory::new_wrapped` that wraps the memory /// allocated elsewhere. /// /// # Implements /// /// [`AllocatorExt`](trait.AllocatorExt.html), [`GstObjectExt`](trait.GstObjectExt.html), [`glib::object::ObjectExt`](../glib/object/trait.ObjectExt.html), [`AllocatorExtManual`](prelude/trait.AllocatorExtManual.html) pub struct Allocator(Object<gst_sys::GstAllocator, gst_sys::GstAllocatorClass, AllocatorClass>) @extends Object; match fn { get_type => || gst_sys::gst_allocator_get_type(), } } impl Allocator { /// Find a previously registered allocator with `name`. When `name` is `None`, the /// default allocator will be returned. /// ## `name` /// the name of the allocator /// /// # Returns /// /// a `Allocator` or `None` when /// the allocator with `name` was not registered. Use `GstObjectExt::unref` /// to release the allocator after usage. pub fn find(name: Option<&str>) -> Option<Allocator> { assert_initialized_main_thread!(); unsafe { from_glib_full(gst_sys::gst_allocator_find(name.to_glib_none().0)) } } /// Registers the memory `allocator` with `name`. This function takes ownership of /// `allocator`. /// ## `name` /// the name of the allocator /// ## `allocator` /// `Allocator` pub fn register<P: IsA<Allocator>>(name: &str, allocator: &P) { skip_assert_initialized!(); unsafe { gst_sys::gst_allocator_register( name.to_glib_none().0, allocator.as_ref().to_glib_full(), ); } } } unsafe impl Send for Allocator {} unsafe impl Sync for Allocator {} pub const NONE_ALLOCATOR: Option<&Allocator> = None; /// Trait containing all `Allocator` methods. /// /// # Implementors /// /// [`Allocator`](struct.Allocator.html) pub trait AllocatorExt: 'static { //fn alloc(&self, size: usize, params: /*Ignored*/Option<&mut AllocationParams>) -> /*Ignored*/Option<Memory>; //fn free(&self, memory: /*Ignored*/&Memory); /// Set the default allocator. This function takes ownership of `self`. fn set_default(&self); } impl<O: IsA<Allocator>> AllocatorExt for O { //fn alloc(&self, size: usize, params: /*Ignored*/Option<&mut AllocationParams>) -> /*Ignored*/Option<Memory> { // unsafe { TODO: call gst_sys:gst_allocator_alloc() } //} //fn free(&self, memory: /*Ignored*/&Memory) { // unsafe { TODO: call gst_sys:gst_allocator_free() } //} fn set_default(&self) { unsafe { gst_sys::gst_allocator_set_default(self.as_ref().to_glib_full()); } } }