gstreamer_rtsp_server/
rtsp_server.rs

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

use glib::{prelude::*, source::SourceId, translate::*};

use crate::{ffi, RTSPServer};

pub trait RTSPServerExtManual: IsA<RTSPServer> + 'static {
    /// Attaches `self` to `context`. When the mainloop for `context` is run, the
    /// server will be dispatched. When `context` is [`None`], the default context will be
    /// used).
    ///
    /// This function should be called when the server properties and urls are fully
    /// configured and the server is ready to start.
    ///
    /// This takes a reference on `self` until the source is destroyed. Note that
    /// if `context` is not the default main context as returned by
    /// [`glib::MainContext::default()`][crate::glib::MainContext::default()] (or [`None`]), [`glib::Source::remove()`][crate::glib::Source::remove()] cannot be used to
    /// destroy the source. In that case it is recommended to use
    /// [`RTSPServerExt::create_source()`][crate::prelude::RTSPServerExt::create_source()] and attach it to `context` manually.
    /// ## `context`
    /// a [`glib::MainContext`][crate::glib::MainContext]
    ///
    /// # Returns
    ///
    /// the ID (greater than 0) for the source within the GMainContext.
    #[doc(alias = "gst_rtsp_server_attach")]
    fn attach(
        &self,
        context: Option<&glib::MainContext>,
    ) -> Result<SourceId, glib::error::BoolError> {
        unsafe {
            match ffi::gst_rtsp_server_attach(
                self.as_ref().to_glib_none().0,
                context.to_glib_none().0,
            ) {
                0 => Err(glib::bool_error!(
                    "Failed to attach main context to RTSP server"
                )),
                id => Ok(from_glib(id)),
            }
        }
    }
}

impl<O: IsA<RTSPServer>> RTSPServerExtManual for O {}