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
// This file was generated by gir (d50d839) from gir-files (???)
// DO NOT EDIT

use NetClientClock;
use ffi;
use glib::object::Downcast;
use glib::translate::*;
use glib_ffi;
use gobject_ffi;
use gst;
use gst_ffi;
use std::mem;
use std::ptr;

glib_wrapper! {
    ///
    ///
    /// # Implements
    ///
    /// [`NetClientClockExt`](trait.NetClientClockExt.html), [`gst::ClockExt`](../gst/trait.ClockExt.html), [`gst::ObjectExt`](../gst/trait.ObjectExt.html), [`glib::object::ObjectExt`](../glib/object/trait.ObjectExt.html)
    pub struct NtpClock(Object<ffi::GstNtpClock, ffi::GstNtpClockClass>): [
        NetClientClock,
        gst::Clock => gst_ffi::GstClock,
        gst::Object => gst_ffi::GstObject,
    ];

    match fn {
        get_type => || ffi::gst_ntp_clock_get_type(),
    }
}

impl NtpClock {
    /// Create a new `NtpClock` that will report the time provided by
    /// the NTPv4 server on `remote_address` and `remote_port`.
    /// ## `name`
    /// a name for the clock
    /// ## `remote_address`
    /// the address or hostname of the remote clock provider
    /// ## `remote_port`
    /// the port of the remote clock provider
    /// ## `base_time`
    /// initial time of the clock
    ///
    /// # Returns
    ///
    /// a new `gst::Clock` that receives a time from the remote
    /// clock.
    pub fn new<'a, P: Into<Option<&'a str>>>(name: P, remote_address: &str, remote_port: i32, base_time: gst::ClockTime) -> NtpClock {
        assert_initialized_main_thread!();
        let name = name.into();
        let name = name.to_glib_none();
        unsafe {
            gst::Clock::from_glib_none(ffi::gst_ntp_clock_new(name.0, remote_address.to_glib_none().0, remote_port, base_time.to_glib())).downcast_unchecked()
        }
    }
}

unsafe impl Send for NtpClock {}
unsafe impl Sync for NtpClock {}