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)
    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*/&mut 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*/&mut 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());
        }
    }
}