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
// 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::Element;
use crate::Object;
use crate::Toc;
use glib::object::IsA;
use glib::translate::*;

glib::wrapper! {
    /// Element interface that allows setting of the TOC.
    ///
    /// Elements that support some kind of chapters or editions (or tracks like in
    /// the FLAC cue sheet) will implement this interface.
    ///
    /// If you just want to retrieve the TOC in your application then all you
    /// need to do is watch for TOC messages on your pipeline's bus (or you can
    /// perform TOC query). This interface is only for setting TOC data, not for
    /// extracting it. To set TOC from the application, find proper tocsetter element
    /// and set TOC using [`Self::set_toc()`].
    ///
    /// Elements implementing the [`crate::TocSetter`] interface can extend existing TOC
    /// by getting extend UID for that (you can use [`crate::Toc::find_entry()`] to retrieve it)
    /// with any TOC entries received from downstream.
    ///
    /// # Implements
    ///
    /// [`trait@crate::prelude::TocSetterExt`], [`trait@crate::prelude::ElementExt`], [`trait@crate::prelude::GstObjectExt`], [`trait@glib::object::ObjectExt`], [`trait@crate::prelude::ElementExtManual`]
    pub struct TocSetter(Interface<ffi::GstTocSetter, ffi::GstTocSetterInterface>) @requires Element, Object;

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

unsafe impl Send for TocSetter {}
unsafe impl Sync for TocSetter {}

pub const NONE_TOC_SETTER: Option<&TocSetter> = None;

/// Trait containing all `TocSetter` methods.
///
/// # Implementors
///
/// [`struct@crate::TocSetter`]
pub trait TocSetterExt: 'static {
    /// Return current TOC the setter uses. The TOC should not be
    /// modified without making it writable first.
    ///
    /// # Returns
    ///
    /// TOC set, or [`None`]. Unref with
    ///  `gst_toc_unref()` when no longer needed
    #[doc(alias = "gst_toc_setter_get_toc")]
    #[doc(alias = "get_toc")]
    fn toc(&self) -> Option<Toc>;

    /// Reset the internal TOC. Elements should call this from within the
    /// state-change handler.
    #[doc(alias = "gst_toc_setter_reset")]
    fn reset(&self);

    /// Set the given TOC on the setter. Previously set TOC will be
    /// unreffed before setting a new one.
    /// ## `toc`
    /// a [`crate::Toc`] to set.
    #[doc(alias = "gst_toc_setter_set_toc")]
    fn set_toc(&self, toc: Option<&Toc>);
}

impl<O: IsA<TocSetter>> TocSetterExt for O {
    fn toc(&self) -> Option<Toc> {
        unsafe { from_glib_full(ffi::gst_toc_setter_get_toc(self.as_ref().to_glib_none().0)) }
    }

    fn reset(&self) {
        unsafe {
            ffi::gst_toc_setter_reset(self.as_ref().to_glib_none().0);
        }
    }

    fn set_toc(&self, toc: Option<&Toc>) {
        unsafe {
            ffi::gst_toc_setter_set_toc(self.as_ref().to_glib_none().0, toc.to_glib_none().0);
        }
    }
}