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
// Take a look at the license at the top of the repository in the LICENSE file.

use crate::{ffi, RTSPClient, RTSPSession};
use glib::{prelude::*, source::SourceId, translate::*};
use gst_rtsp::rtsp_message::RTSPMessage;

mod sealed {
    pub trait Sealed {}
    impl<T: super::IsA<super::RTSPClient>> Sealed for T {}
}

pub trait RTSPClientExtManual: sealed::Sealed + IsA<RTSPClient> + 'static {
    /// Attaches `self` to `context`. When the mainloop for `context` is run, the
    /// client will be dispatched. When `context` is [`None`], the default context will be
    /// used).
    ///
    /// This function should be called when the client properties and urls are fully
    /// configured and the client is ready to start.
    /// ## `context`
    /// a [`glib::MainContext`][crate::glib::MainContext]
    ///
    /// # Returns
    ///
    /// the ID (greater than 0) for the source within the GMainContext.
    #[doc(alias = "gst_rtsp_client_attach")]
    fn attach(&self, context: Option<&glib::MainContext>) -> SourceId {
        unsafe {
            from_glib(ffi::gst_rtsp_client_attach(
                self.as_ref().to_glib_none().0,
                context.to_glib_none().0,
            ))
        }
    }

    #[doc(alias = "gst_rtsp_client_send_message")]
    fn send_message(
        &self,
        message: &RTSPMessage,
        session: Option<&RTSPSession>,
    ) -> gst_rtsp::RTSPResult {
        unsafe {
            from_glib(ffi::gst_rtsp_client_send_message(
                self.as_ref().to_glib_none().0,
                session.to_glib_none().0,
                message.to_glib_none().0,
            ))
        }
    }
}

impl<O: IsA<RTSPClient>> RTSPClientExtManual for O {}