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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
// 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;
use glib::{bitflags::bitflags, prelude::*, translate::*};

bitflags! {
    #[derive(Clone, Copy, Debug, PartialEq, Eq, Hash)]
    #[doc(alias = "GstValidateActionTypeFlags")]
    pub struct ActionTypeFlags: u32 {
        /// No special flag
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_NONE")]
        const NONE = ffi::GST_VALIDATE_ACTION_TYPE_NONE as _;
        /// The action is a config
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_CONFIG")]
        const CONFIG = ffi::GST_VALIDATE_ACTION_TYPE_CONFIG as _;
        /// The action can be executed ASYNC
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_ASYNC")]
        const ASYNC = ffi::GST_VALIDATE_ACTION_TYPE_ASYNC as _;
        /// The action can be executed asynchronously but without blocking further
        /// actions execution.
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_NON_BLOCKING")]
        const NON_BLOCKING = ffi::GST_VALIDATE_ACTION_TYPE_NON_BLOCKING as _;
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_INTERLACED")]
        const INTERLACED = ffi::GST_VALIDATE_ACTION_TYPE_INTERLACED as _;
        /// The action will be executed on 'element-added'
        ///  for a particular element type if no playback-time
        ///  is specified
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_CAN_EXECUTE_ON_ADDITION")]
        const CAN_EXECUTE_ON_ADDITION = ffi::GST_VALIDATE_ACTION_TYPE_CAN_EXECUTE_ON_ADDITION as _;
        /// The pipeline will need to be synchronized with the clock
        ///  for that action type to be used.
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_NEEDS_CLOCK")]
        const NEEDS_CLOCK = ffi::GST_VALIDATE_ACTION_TYPE_NEEDS_CLOCK as _;
        /// Do not consider the non execution of the action
        ///  as a fatal error.
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_NO_EXECUTION_NOT_FATAL")]
        const NO_EXECUTION_NOT_FATAL = ffi::GST_VALIDATE_ACTION_TYPE_NO_EXECUTION_NOT_FATAL as _;
        /// The action can use the 'optional' keyword. Such action
        ///  instances will have the [`NO_EXECUTION_NOT_FATAL`][Self::NO_EXECUTION_NOT_FATAL]
        ///  flag set and won't be considered as fatal if they fail.
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_CAN_BE_OPTIONAL")]
        const CAN_BE_OPTIONAL = ffi::GST_VALIDATE_ACTION_TYPE_CAN_BE_OPTIONAL as _;
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_DOESNT_NEED_PIPELINE")]
        const DOESNT_NEED_PIPELINE = ffi::GST_VALIDATE_ACTION_TYPE_DOESNT_NEED_PIPELINE as _;
        /// The action can be used in config files even if it is not strictly a config
        ///  action (ie. it needs a scenario to run).
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_HANDLED_IN_CONFIG")]
        const HANDLED_IN_CONFIG = ffi::GST_VALIDATE_ACTION_TYPE_HANDLED_IN_CONFIG as _;
        /// The action is checking some state from objects in the pipeline. It means that it can
        /// be used as 'check' in different action which have a `check` "sub action", such as the 'wait' action type.
        /// This implies that the action can be executed from any thread and not only from the scenario thread as other
        /// types.
        #[doc(alias = "GST_VALIDATE_ACTION_TYPE_CHECK")]
        const CHECK = ffi::GST_VALIDATE_ACTION_TYPE_CHECK as _;
    }
}

#[doc(hidden)]
impl IntoGlib for ActionTypeFlags {
    type GlibType = ffi::GstValidateActionTypeFlags;

    #[inline]
    fn into_glib(self) -> ffi::GstValidateActionTypeFlags {
        self.bits()
    }
}

#[doc(hidden)]
impl FromGlib<ffi::GstValidateActionTypeFlags> for ActionTypeFlags {
    #[inline]
    unsafe fn from_glib(value: ffi::GstValidateActionTypeFlags) -> Self {
        skip_assert_initialized!();
        Self::from_bits_truncate(value)
    }
}

impl StaticType for ActionTypeFlags {
    #[inline]
    #[doc(alias = "gst_validate_action_type_flags_get_type")]
    fn static_type() -> glib::Type {
        unsafe { from_glib(ffi::gst_validate_action_type_flags_get_type()) }
    }
}

impl glib::HasParamSpec for ActionTypeFlags {
    type ParamSpec = glib::ParamSpecFlags;
    type SetValue = Self;
    type BuilderFn = fn(&str) -> glib::ParamSpecFlagsBuilder<Self>;

    fn param_spec_builder() -> Self::BuilderFn {
        Self::ParamSpec::builder
    }
}

impl glib::value::ValueType for ActionTypeFlags {
    type Type = Self;
}

unsafe impl<'a> glib::value::FromValue<'a> for ActionTypeFlags {
    type Checker = glib::value::GenericValueTypeChecker<Self>;

    #[inline]
    unsafe fn from_value(value: &'a glib::Value) -> Self {
        skip_assert_initialized!();
        from_glib(glib::gobject_ffi::g_value_get_flags(value.to_glib_none().0))
    }
}

impl ToValue for ActionTypeFlags {
    #[inline]
    fn to_value(&self) -> glib::Value {
        let mut value = glib::Value::for_value_type::<Self>();
        unsafe {
            glib::gobject_ffi::g_value_set_flags(value.to_glib_none_mut().0, self.into_glib());
        }
        value
    }

    #[inline]
    fn value_type(&self) -> glib::Type {
        Self::static_type()
    }
}

impl From<ActionTypeFlags> for glib::Value {
    #[inline]
    fn from(v: ActionTypeFlags) -> Self {
        skip_assert_initialized!();
        ToValue::to_value(&v)
    }
}

bitflags! {
    /// GST_VALIDATE_ISSUE_FLAGS_NONE: No special flags for the issue type
    /// GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS: Always show all occurrences of the issue in full details
    /// GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE: Do not generate backtrace for the issue type
    #[derive(Clone, Copy, Debug, PartialEq, Eq, Hash)]
    #[doc(alias = "GstValidateIssueFlags")]
    pub struct IssueFlags: u32 {
        #[doc(alias = "GST_VALIDATE_ISSUE_FLAGS_NONE")]
        const NONE = ffi::GST_VALIDATE_ISSUE_FLAGS_NONE as _;
        #[doc(alias = "GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS")]
        const FULL_DETAILS = ffi::GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS as _;
        #[doc(alias = "GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE")]
        const NO_BACKTRACE = ffi::GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE as _;
        /// Always generate backtrace, even if not a critical issue
        #[doc(alias = "GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE")]
        const FORCE_BACKTRACE = ffi::GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE as _;
    }
}

#[doc(hidden)]
impl IntoGlib for IssueFlags {
    type GlibType = ffi::GstValidateIssueFlags;

    #[inline]
    fn into_glib(self) -> ffi::GstValidateIssueFlags {
        self.bits()
    }
}

#[doc(hidden)]
impl FromGlib<ffi::GstValidateIssueFlags> for IssueFlags {
    #[inline]
    unsafe fn from_glib(value: ffi::GstValidateIssueFlags) -> Self {
        skip_assert_initialized!();
        Self::from_bits_truncate(value)
    }
}

impl StaticType for IssueFlags {
    #[inline]
    #[doc(alias = "gst_validate_issue_flags_get_type")]
    fn static_type() -> glib::Type {
        unsafe { from_glib(ffi::gst_validate_issue_flags_get_type()) }
    }
}

impl glib::HasParamSpec for IssueFlags {
    type ParamSpec = glib::ParamSpecFlags;
    type SetValue = Self;
    type BuilderFn = fn(&str) -> glib::ParamSpecFlagsBuilder<Self>;

    fn param_spec_builder() -> Self::BuilderFn {
        Self::ParamSpec::builder
    }
}

impl glib::value::ValueType for IssueFlags {
    type Type = Self;
}

unsafe impl<'a> glib::value::FromValue<'a> for IssueFlags {
    type Checker = glib::value::GenericValueTypeChecker<Self>;

    #[inline]
    unsafe fn from_value(value: &'a glib::Value) -> Self {
        skip_assert_initialized!();
        from_glib(glib::gobject_ffi::g_value_get_flags(value.to_glib_none().0))
    }
}

impl ToValue for IssueFlags {
    #[inline]
    fn to_value(&self) -> glib::Value {
        let mut value = glib::Value::for_value_type::<Self>();
        unsafe {
            glib::gobject_ffi::g_value_set_flags(value.to_glib_none_mut().0, self.into_glib());
        }
        value
    }

    #[inline]
    fn value_type(&self) -> glib::Type {
        Self::static_type()
    }
}

impl From<IssueFlags> for glib::Value {
    #[inline]
    fn from(v: IssueFlags) -> Self {
        skip_assert_initialized!();
        ToValue::to_value(&v)
    }
}