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
// 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 ffi;
use glib::translate::*;
use glib_ffi;
use gobject_ffi;
#[cfg(any(feature = "v1_14", feature = "dox"))]
use gst;
use std::mem;
use std::ptr;

glib_wrapper! {
    /// `AudioStreamAlign` provides a helper object that helps tracking audio
    /// stream alignment and discontinuities, and detects discontinuities if
    /// possible.
    ///
    /// See `AudioStreamAlign::new` for a description of its parameters and
    /// `AudioStreamAlign::process` for the details of the processing.
    ///
    /// Feature: `v1_14`
    #[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Hash)]
    pub struct AudioStreamAlign(Boxed<ffi::GstAudioStreamAlign>);

    match fn {
        copy => |ptr| ffi::gst_audio_stream_align_copy(mut_override(ptr)),
        free => |ptr| ffi::gst_audio_stream_align_free(ptr),
        get_type => || ffi::gst_audio_stream_align_get_type(),
    }
}

impl AudioStreamAlign {
    /// Allocate a new `AudioStreamAlign` with the given configuration. All
    /// processing happens according to sample rate `rate`, until
    /// `gst_audio_discont_wait_set_rate` is called with a new `rate`.
    /// A negative rate can be used for reverse playback.
    ///
    /// `alignment_threshold` gives the tolerance in nanoseconds after which a
    /// timestamp difference is considered a discontinuity. Once detected,
    /// `discont_wait` nanoseconds have to pass without going below the threshold
    /// again until the output buffer is marked as a discontinuity. These can later
    /// be re-configured with `AudioStreamAlign::set_alignment_threshold` and
    /// `AudioStreamAlign::set_discont_wait`.
    ///
    /// Feature: `v1_14`
    ///
    /// ## `rate`
    /// a sample rate
    /// ## `alignment_threshold`
    /// a alignment threshold in nanoseconds
    /// ## `discont_wait`
    /// discont wait in nanoseconds
    ///
    /// # Returns
    ///
    /// a new `AudioStreamAlign`. free with `AudioStreamAlign::free`.
    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn new(rate: i32, alignment_threshold: gst::ClockTime, discont_wait: gst::ClockTime) -> AudioStreamAlign {
        assert_initialized_main_thread!();
        unsafe {
            from_glib_full(ffi::gst_audio_stream_align_new(rate, alignment_threshold.to_glib(), discont_wait.to_glib()))
        }
    }

    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn get_alignment_threshold(&mut self) -> gst::ClockTime {
        unsafe {
            from_glib(ffi::gst_audio_stream_align_get_alignment_threshold(self.to_glib_none_mut().0))
        }
    }

    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn get_discont_wait(&mut self) -> gst::ClockTime {
        unsafe {
            from_glib(ffi::gst_audio_stream_align_get_discont_wait(self.to_glib_none_mut().0))
        }
    }

    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn get_rate(&mut self) -> i32 {
        unsafe {
            ffi::gst_audio_stream_align_get_rate(self.to_glib_none_mut().0)
        }
    }

    /// Returns the number of samples that were processed since the last
    /// discontinuity was detected.
    ///
    /// Feature: `v1_14`
    ///
    ///
    /// # Returns
    ///
    /// The number of samples processed since the last discontinuity.
    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn get_samples_since_discont(&mut self) -> u64 {
        unsafe {
            ffi::gst_audio_stream_align_get_samples_since_discont(self.to_glib_none_mut().0)
        }
    }

    /// Timestamp that was passed when a discontinuity was detected, i.e. the first
    /// timestamp after the discontinuity.
    ///
    /// Feature: `v1_14`
    ///
    ///
    /// # Returns
    ///
    /// The last timestamp at when a discontinuity was detected
    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn get_timestamp_at_discont(&mut self) -> gst::ClockTime {
        unsafe {
            from_glib(ffi::gst_audio_stream_align_get_timestamp_at_discont(self.to_glib_none_mut().0))
        }
    }

    /// Marks the next buffer as discontinuous and resets timestamp tracking.
    ///
    /// Feature: `v1_14`
    ///
    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn mark_discont(&mut self) {
        unsafe {
            ffi::gst_audio_stream_align_mark_discont(self.to_glib_none_mut().0);
        }
    }

    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn set_alignment_threshold(&mut self, alignment_threshold: gst::ClockTime) {
        unsafe {
            ffi::gst_audio_stream_align_set_alignment_threshold(self.to_glib_none_mut().0, alignment_threshold.to_glib());
        }
    }

    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn set_discont_wait(&mut self, discont_wait: gst::ClockTime) {
        unsafe {
            ffi::gst_audio_stream_align_set_discont_wait(self.to_glib_none_mut().0, discont_wait.to_glib());
        }
    }

    #[cfg(any(feature = "v1_14", feature = "dox"))]
    pub fn set_rate(&mut self, rate: i32) {
        unsafe {
            ffi::gst_audio_stream_align_set_rate(self.to_glib_none_mut().0, rate);
        }
    }
}

unsafe impl Send for AudioStreamAlign {}
unsafe impl Sync for AudioStreamAlign {}