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 {}