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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// This file was generated by gir (https://github.com/gtk-rs/gir)
// from gir-files (https://github.com/gtk-rs/gir-files)
// from gst-gir-files (https://gitlab.freedesktop.org/gstreamer/gir-files-rs.git)
// DO NOT EDIT

use crate::{ffi, VideoAggregatorPad};
use glib::{prelude::*, translate::*};

glib::wrapper! {
    /// An implementation of GstPad that can be used with [`VideoAggregator`][crate::VideoAggregator].
    ///
    /// See [`VideoAggregator`][crate::VideoAggregator] for more details.
    ///
    /// ## Properties
    ///
    ///
    /// #### `converter-config`
    ///  Readable | Writeable
    /// <details><summary><h4>VideoAggregatorPad</h4></summary>
    ///
    ///
    /// #### `max-last-buffer-repeat`
    ///  Readable | Writeable
    ///
    ///
    /// #### `repeat-after-eos`
    ///  Readable | Writeable
    ///
    ///
    /// #### `zorder`
    ///  Readable | Writeable
    /// </details>
    /// <details><summary><h4>AggregatorPad</h4></summary>
    ///
    ///
    /// #### `emit-signals`
    ///  Enables the emission of signals such as [`buffer-consumed`][struct@crate::gst_base::AggregatorPad#buffer-consumed]
    ///
    /// Readable | Writeable
    /// </details>
    /// <details><summary><h4>Pad</h4></summary>
    ///
    ///
    /// #### `caps`
    ///  Readable
    ///
    ///
    /// #### `direction`
    ///  Readable | Writeable | Construct Only
    ///
    ///
    /// #### `offset`
    ///  The offset that will be applied to the running time of the pad.
    ///
    /// Readable | Writeable
    ///
    ///
    /// #### `template`
    ///  Readable | Writeable
    /// </details>
    /// <details><summary><h4>Object</h4></summary>
    ///
    ///
    /// #### `name`
    ///  Readable | Writeable | Construct
    ///
    ///
    /// #### `parent`
    ///  The parent of the object. Please note, that when changing the 'parent'
    /// property, we don't emit [`notify`][struct@crate::glib::Object#notify] and [`deep-notify`][struct@crate::gst::Object#deep-notify]
    /// signals due to locking issues. In some cases one can use
    /// `GstBin::element-added` or `GstBin::element-removed` signals on the parent to
    /// achieve a similar effect.
    ///
    /// Readable | Writeable
    /// </details>
    ///
    /// # Implements
    ///
    /// [`VideoAggregatorConvertPadExt`][trait@crate::prelude::VideoAggregatorConvertPadExt], [`VideoAggregatorPadExt`][trait@crate::prelude::VideoAggregatorPadExt], [`trait@gst_base::prelude::AggregatorPadExt`], [`trait@gst::prelude::PadExt`], [`trait@gst::prelude::ObjectExt`], [`trait@glib::ObjectExt`]
    #[doc(alias = "GstVideoAggregatorConvertPad")]
    pub struct VideoAggregatorConvertPad(Object<ffi::GstVideoAggregatorConvertPad, ffi::GstVideoAggregatorConvertPadClass>) @extends VideoAggregatorPad, gst_base::AggregatorPad, gst::Pad, gst::Object;

    match fn {
        type_ => || ffi::gst_video_aggregator_convert_pad_get_type(),
    }
}

impl VideoAggregatorConvertPad {
    pub const NONE: Option<&'static VideoAggregatorConvertPad> = None;
}

unsafe impl Send for VideoAggregatorConvertPad {}
unsafe impl Sync for VideoAggregatorConvertPad {}

mod sealed {
    pub trait Sealed {}
    impl<T: super::IsA<super::VideoAggregatorConvertPad>> Sealed for T {}
}

/// Trait containing all [`struct@VideoAggregatorConvertPad`] methods.
///
/// # Implementors
///
/// [`VideoAggregatorConvertPad`][struct@crate::VideoAggregatorConvertPad], [`VideoAggregatorParallelConvertPad`][struct@crate::VideoAggregatorParallelConvertPad]
pub trait VideoAggregatorConvertPadExt:
    IsA<VideoAggregatorConvertPad> + sealed::Sealed + 'static
{
    /// Requests the pad to check and update the converter before the next usage to
    /// update for any changes that have happened.
    #[doc(alias = "gst_video_aggregator_convert_pad_update_conversion_info")]
    fn update_conversion_info(&self) {
        unsafe {
            ffi::gst_video_aggregator_convert_pad_update_conversion_info(
                self.as_ref().to_glib_none().0,
            );
        }
    }
}

impl<O: IsA<VideoAggregatorConvertPad>> VideoAggregatorConvertPadExt for O {}