1#![cfg_attr(docsrs, feature(doc_cfg))]
4#![allow(clippy::missing_safety_doc)]
5#![allow(clippy::manual_range_contains)]
6#![allow(clippy::manual_c_str_literals)]
7#![doc = include_str!("../README.md")]
8
9pub use glib;
11pub use gstreamer_sys as ffi;
12#[deprecated = "Use `gst::pastey` instead"]
13pub use pastey as paste;
14pub use pastey;
15
16#[doc(hidden)]
17pub static INITIALIZED: std::sync::atomic::AtomicBool = std::sync::atomic::AtomicBool::new(false);
18
19#[cold]
20#[inline(never)]
21#[track_caller]
22pub fn assert_initialized() {
23 #[allow(unused_unsafe)]
24 if unsafe { ffi::gst_is_initialized() } != glib::ffi::GTRUE {
25 panic!("GStreamer has not been initialized. Call `gst::init` first.");
26 } else {
27 crate::INITIALIZED.store(true, std::sync::atomic::Ordering::SeqCst);
28 }
29}
30
31macro_rules! assert_initialized_main_thread {
32 () => {
33 if !crate::INITIALIZED.load(std::sync::atomic::Ordering::SeqCst) {
34 $crate::assert_initialized();
35 }
36 };
37}
38
39macro_rules! skip_assert_initialized {
40 () => {};
41}
42
43#[allow(clippy::needless_borrow)]
44#[allow(clippy::let_unit_value)]
45#[allow(unused_imports)]
46mod auto;
47pub use crate::auto::*;
48
49#[macro_use]
50#[cfg(feature = "serde")]
51mod serde_macros;
52
53#[macro_use]
54pub mod log;
55#[cfg(feature = "v1_28")]
56#[cfg_attr(docsrs, doc(cfg(feature = "v1_28")))]
57pub mod log_context;
58#[cfg(feature = "log")]
59pub use crate::log::DebugCategoryLogger;
60pub use crate::log::{
61 CAT_BUFFER, CAT_BUFFER_LIST, CAT_BUS, CAT_CALL_TRACE, CAT_CAPS, CAT_CLOCK, CAT_CONTEXT,
62 CAT_DEFAULT, CAT_ELEMENT_PADS, CAT_ERROR_SYSTEM, CAT_EVENT, CAT_GST_INIT, CAT_LOCKING,
63 CAT_MEMORY, CAT_MESSAGE, CAT_META, CAT_NEGOTIATION, CAT_PADS, CAT_PARAMS, CAT_PARENTAGE,
64 CAT_PERFORMANCE, CAT_PIPELINE, CAT_PLUGIN_INFO, CAT_PLUGIN_LOADING, CAT_PROBE, CAT_PROPERTIES,
65 CAT_QOS, CAT_REFCOUNTING, CAT_REGISTRY, CAT_RUST, CAT_SCHEDULING, CAT_SIGNAL, CAT_STATES,
66 DebugCategory, DebugLogFunction, DebugLogger, DebugMessage, LoggedObject,
67};
68
69#[cfg(feature = "v1_28")]
70#[cfg_attr(docsrs, doc(cfg(feature = "v1_28")))]
71pub use crate::log_context::{LogContext, LogContextBuilder};
72
73#[cfg(target_os = "macos")]
74mod macos;
75#[cfg(all(target_os = "macos", feature = "v1_22"))]
76pub use crate::macos::*;
77
78#[macro_use]
79mod error;
80pub use crate::error::*;
81
82#[macro_use]
83pub mod miniobject;
84pub use miniobject::{MiniObject, MiniObjectRef};
85
86#[macro_use]
87mod value;
88pub use crate::value::{
89 Array, ArrayRef, Bitmask, Fraction, FractionRange, IntRange, List, ListRef,
90};
91#[cfg(feature = "v1_28")]
92#[cfg_attr(docsrs, doc(cfg(feature = "v1_28")))]
93pub use crate::value::{UniqueList, UniqueListRef};
94#[cfg(feature = "serde")]
95#[macro_use]
96mod value_serde;
97
98#[macro_use]
99mod id_str;
100pub use crate::id_str::IdStr;
101
102#[cfg(feature = "serde")]
103mod flag_serde;
104
105pub mod message;
106pub use crate::message::{Message, MessageErrorDomain, MessageRef, MessageView, MessageViewMut};
107
108pub mod structure;
109pub use crate::structure::{Structure, StructureRef};
110#[cfg(feature = "serde")]
111mod structure_serde;
112
113pub mod caps;
114pub use crate::caps::{Caps, CapsFilterMapAction, CapsRef};
115mod caps_features;
116#[cfg(feature = "serde")]
117mod caps_serde;
118pub use crate::caps_features::{
119 CAPS_FEATURE_MEMORY_SYSTEM_MEMORY, CAPS_FEATURES_MEMORY_SYSTEM_MEMORY, CapsFeatures,
120 CapsFeaturesRef,
121};
122#[cfg(feature = "serde")]
123mod caps_features_serde;
124
125pub mod tags;
126pub use crate::tags::{
127 Tag, TagList, TagListRef, tag_exists, tag_get_description, tag_get_flag, tag_get_nick,
128 tag_get_type,
129};
130#[cfg(feature = "serde")]
131mod tags_serde;
132
133#[macro_use]
134pub mod meta;
135#[cfg(feature = "v1_16")]
136#[cfg_attr(docsrs, doc(cfg(feature = "v1_16")))]
137pub use crate::meta::MetaSeqnum;
138pub use crate::meta::{
139 Meta, MetaAPI, MetaAPIExt, MetaRef, MetaRefMut, ParentBufferMeta, ProtectionMeta,
140 ReferenceTimestampMeta,
141};
142pub mod buffer;
143pub use crate::buffer::{
144 BUFFER_COPY_ALL, BUFFER_COPY_METADATA, Buffer, BufferMap, BufferRef, MappedBuffer,
145};
146mod buffer_cursor;
147pub use crate::buffer_cursor::{BufferCursor, BufferRefCursor};
148pub mod memory;
149mod memory_wrapped;
150#[cfg(feature = "v1_26")]
151#[cfg_attr(docsrs, doc(cfg(feature = "v1_26")))]
152pub use crate::memory::MemoryRefTrace;
153pub use crate::memory::{MappedMemory, Memory, MemoryMap, MemoryRef};
154pub use crate::memory_wrapped::{MemoryIntoInnerError, rust_allocator};
155#[cfg(feature = "serde")]
156mod buffer_serde;
157pub mod slice;
158
159pub mod sample;
160pub use crate::sample::{Sample, SampleRef};
161#[cfg(feature = "serde")]
162mod sample_serde;
163
164pub mod bufferlist;
165pub use crate::bufferlist::{BufferList, BufferListRef};
166#[cfg(feature = "serde")]
167mod bufferlist_serde;
168
169pub mod query;
170pub use crate::query::{Query, QueryRef, QueryView, QueryViewMut};
171pub mod event;
172pub use crate::event::{Event, EventRef, EventView, EventViewMut, GroupId, Seqnum};
173pub mod context;
174#[cfg(feature = "v1_28")]
175#[cfg_attr(docsrs, doc(cfg(feature = "v1_28")))]
176pub use crate::context::TASK_POOL_CONTEXT_TYPE;
177pub use crate::context::{Context, ContextRef};
178mod rank;
179pub use crate::rank::Rank;
180mod static_caps;
181pub use crate::static_caps::*;
182mod static_pad_template;
183pub use crate::static_pad_template::*;
184
185pub mod promise;
186pub use promise::{Promise, PromiseError};
187
188pub mod bus;
189mod element;
190pub mod element_factory;
191
192mod dynamic_type_factory;
193
194mod bin;
195pub use bin::BinBuilder;
196
197mod pipeline;
198pub use pipeline::PipelineBuilder;
199
200mod allocation_params;
201pub use self::allocation_params::AllocationParams;
202mod allocator;
203
204mod element_factory_type;
205pub use element_factory_type::*;
206
207mod tracer;
208mod tracer_factory;
209
210#[cfg(any(unix, docsrs))]
212mod bus_unix;
213#[cfg(any(windows, docsrs))]
214mod bus_windows;
215
216mod child_proxy;
217mod date_time;
218#[cfg(feature = "serde")]
219mod date_time_serde;
220mod device_monitor;
221mod device_provider;
222mod device_provider_factory;
223mod enums;
224mod ghost_pad;
225pub mod gobject;
226mod iterator;
227mod object;
228mod pad;
229pub use pad::{
230 EventForeachAction, PadBuilder, PadGetRangeSuccess, PadProbeData, PadProbeId, PadProbeInfo,
231 StreamLock,
232};
233mod control_binding;
234mod control_source;
235mod parse_context;
236mod proxy_pad;
237mod registry;
238mod tag_setter;
239pub mod task;
240pub use task::{TaskLock, TaskLockGuard};
241mod task_pool;
242pub use self::iterator::{Iterator, IteratorError, IteratorImpl, StdIterator};
243pub use crate::{
244 device_monitor::DeviceMonitorFilterId,
245 element::{
246 ELEMENT_METADATA_AUTHOR, ELEMENT_METADATA_DESCRIPTION, ELEMENT_METADATA_DOC_URI,
247 ELEMENT_METADATA_ICON_NAME, ELEMENT_METADATA_KLASS, ELEMENT_METADATA_LONGNAME,
248 ElementMessageType, NotifyWatchId,
249 },
250 enums::{
251 ClockError, ClockSuccess, FlowError, FlowReturn, FlowSuccess, MessageType, PadLinkError,
252 PadLinkReturn, PadLinkSuccess, StateChangeError, StateChangeSuccess, TagError,
253 },
254 parse_context::ParseContext,
255 task_pool::{TaskHandle, TaskPoolTaskHandle},
256};
257mod plugin_feature;
258
259mod plugin;
260pub mod stream;
261pub mod stream_collection;
262
263mod typefind;
264pub use crate::typefind::*;
265mod typefind_factory;
266
267pub mod format;
268pub use crate::format::{ClockTime, GenericFormattedValue, GenericSignedFormattedValue, Signed};
269
270mod segment;
271pub use crate::segment::*;
272#[cfg(feature = "serde")]
273mod segment_serde;
274
275mod timed_value;
276pub use crate::timed_value::TimedValue;
277
278pub mod toc;
279pub use crate::toc::{Toc, TocEntry, TocEntryRef, TocRef};
280#[cfg(feature = "serde")]
281mod toc_serde;
282
283mod clock;
284pub use crate::clock::{AtomicClockReturn, ClockId, PeriodicClockId, SingleShotClockId};
285
286mod buffer_pool;
287pub use crate::buffer_pool::{BufferPoolAcquireParams, BufferPoolConfig, BufferPoolConfigRef};
288
289mod pad_template;
290pub use pad_template::PadTemplateBuilder;
291
292pub mod param_spec;
293pub use crate::param_spec::{ParamSpecArray, ParamSpecFraction};
294
295mod functions;
296pub use crate::functions::*;
297
298mod utils;
299pub use crate::utils::ObjectLockGuard;
300
301pub mod parse;
302
303#[cfg(feature = "v1_28")]
304#[cfg_attr(docsrs, doc(cfg(feature = "v1_28")))]
305pub mod cpuid;
306
307#[cfg(feature = "v1_18")]
308mod gtype;
309
310use std::ptr;
311
312#[doc(alias = "gst_init_check")]
313pub fn init() -> Result<(), glib::Error> {
314 unsafe {
315 use glib::translate::*;
316
317 let mut error = ptr::null_mut();
318 if from_glib(ffi::gst_init_check(
319 ptr::null_mut(),
320 ptr::null_mut(),
321 &mut error,
322 )) {
323 crate::INITIALIZED.store(true, std::sync::atomic::Ordering::SeqCst);
324 Ok(())
325 } else {
326 Err(from_glib_full(error))
327 }
328 }
329}
330
331pub unsafe fn deinit() {
339 unsafe {
340 crate::INITIALIZED.store(false, std::sync::atomic::Ordering::SeqCst);
341 ffi::gst_deinit();
342 }
343}
344
345pub const PARAM_FLAG_CONTROLLABLE: glib::ParamFlags = glib::ParamFlags::USER_1;
346pub const PARAM_FLAG_MUTABLE_READY: glib::ParamFlags = glib::ParamFlags::USER_2;
347pub const PARAM_FLAG_MUTABLE_PAUSED: glib::ParamFlags = glib::ParamFlags::USER_3;
348pub const PARAM_FLAG_MUTABLE_PLAYING: glib::ParamFlags = glib::ParamFlags::USER_4;
349#[cfg(feature = "v1_18")]
350pub const PARAM_FLAG_DOC_SHOW_DEFAULT: glib::ParamFlags = glib::ParamFlags::USER_5;
351#[cfg(feature = "v1_18")]
352pub const PARAM_FLAG_CONDITIONALLY_AVAILABLE: glib::ParamFlags = glib::ParamFlags::USER_6;
353
354pub mod prelude {
357 #[doc(hidden)]
358 pub use glib::prelude::*;
359 pub use muldiv::MulDiv;
360 pub use opt_ops::prelude::*;
361
362 #[cfg(any(unix, docsrs))]
364 pub use crate::bus_unix::UnixBusExtManual;
365 #[cfg(any(windows, docsrs))]
366 pub use crate::bus_windows::WindowsBusExtManual;
367 #[cfg(feature = "v1_18")]
368 pub use crate::gtype::PluginApiExt;
369 pub use crate::{
370 auto::traits::*,
371 bin::GstBinExtManual,
372 buffer_pool::BufferPoolExtManual,
373 child_proxy::ChildProxyExtManual,
374 clock::ClockExtManual,
375 control_binding::ControlBindingExtManual,
376 control_source::ControlSourceExtManual,
377 device_monitor::DeviceMonitorExtManual,
378 device_provider::{DeviceProviderClassExt, DeviceProviderExtManual},
379 element::{ElementClassExt, ElementExtManual},
380 format::prelude::*,
381 gobject::GObjectExtManualGst,
382 log::DebugLogger,
383 memory::MemoryType,
384 message::MessageErrorDomain,
385 meta::{MetaAPI, MetaAPIExt, MetaTag},
386 miniobject::IsMiniObject,
387 object::GstObjectExtManual,
388 pad::PadExtManual,
389 param_spec::GstParamSpecBuilderExt,
390 pipeline::GstPipelineExtManual,
391 plugin_feature::PluginFeatureExtManual,
392 slice::ByteSliceExt,
393 tag_setter::TagSetterExtManual,
394 tags::{CustomTag, Tag},
395 task_pool::{TaskHandle, TaskPoolExtManual},
396 typefind::TypeFindImpl,
397 utils::Displayable,
398 value::GstValueExt,
399 };
400}
401
402#[macro_use]
403pub mod subclass;