gstreamer-rs/gstreamer-rtsp-server/src/auto/rtsp_stream_transport.rs

151 lines
5.6 KiB
Rust
Raw Normal View History

2018-04-23 17:34:22 +00:00
// 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 RTSPStream;
use glib;
use glib::GString;
use glib::object::IsA;
use glib::translate::*;
use gst;
use gst_rtsp;
2019-03-19 07:40:05 +00:00
use gst_rtsp_server_sys;
2019-01-29 13:53:44 +00:00
use std::boxed::Box as Box_;
glib_wrapper! {
2019-03-19 07:40:05 +00:00
pub struct RTSPStreamTransport(Object<gst_rtsp_server_sys::GstRTSPStreamTransport, gst_rtsp_server_sys::GstRTSPStreamTransportClass, RTSPStreamTransportClass>);
match fn {
2019-03-19 07:40:05 +00:00
get_type => || gst_rtsp_server_sys::gst_rtsp_stream_transport_get_type(),
}
}
impl RTSPStreamTransport {
2019-01-16 11:32:39 +00:00
//pub fn new<P: IsA<RTSPStream>>(stream: &P, tr: /*Ignored*/&mut gst_rtsp::RTSPTransport) -> RTSPStreamTransport {
2019-03-19 07:40:05 +00:00
// unsafe { TODO: call gst_rtsp_server_sys:gst_rtsp_stream_transport_new() }
//}
}
2019-01-16 11:32:39 +00:00
pub const NONE_RTSP_STREAM_TRANSPORT: Option<&RTSPStreamTransport> = None;
pub trait RTSPStreamTransportExt: 'static {
fn get_rtpinfo(&self, start_time: gst::ClockTime) -> Option<GString>;
fn get_stream(&self) -> Option<RTSPStream>;
//fn get_transport(&self) -> /*Ignored*/Option<gst_rtsp::RTSPTransport>;
fn get_url(&self) -> Option<gst_rtsp::RTSPUrl>;
fn is_timed_out(&self) -> bool;
fn keep_alive(&self);
fn send_rtcp(&self, buffer: &gst::Buffer) -> Result<(), glib::error::BoolError>;
fn send_rtp(&self, buffer: &gst::Buffer) -> Result<(), glib::error::BoolError>;
fn set_active(&self, active: bool) -> Result<(), glib::error::BoolError>;
2019-01-29 13:53:44 +00:00
//fn set_callbacks<P: Fn(&gst::Buffer, u8) -> bool + 'static, Q: Fn(&gst::Buffer, u8) -> bool + 'static>(&self, send_rtp: P, send_rtcp: Q);
2019-01-29 13:53:44 +00:00
fn set_keepalive<P: Fn() + 'static>(&self, keep_alive: P);
fn set_timed_out(&self, timedout: bool);
//fn set_transport(&self, tr: /*Ignored*/&mut gst_rtsp::RTSPTransport);
2019-03-19 07:40:05 +00:00
fn set_url(&self, url: Option<&gst_rtsp::RTSPUrl>);
}
impl<O: IsA<RTSPStreamTransport>> RTSPStreamTransportExt for O {
fn get_rtpinfo(&self, start_time: gst::ClockTime) -> Option<GString> {
unsafe {
2019-03-19 07:40:05 +00:00
from_glib_full(gst_rtsp_server_sys::gst_rtsp_stream_transport_get_rtpinfo(self.as_ref().to_glib_none().0, start_time.to_glib()))
}
}
fn get_stream(&self) -> Option<RTSPStream> {
unsafe {
2019-03-19 07:40:05 +00:00
from_glib_none(gst_rtsp_server_sys::gst_rtsp_stream_transport_get_stream(self.as_ref().to_glib_none().0))
}
}
//fn get_transport(&self) -> /*Ignored*/Option<gst_rtsp::RTSPTransport> {
2019-03-19 07:40:05 +00:00
// unsafe { TODO: call gst_rtsp_server_sys:gst_rtsp_stream_transport_get_transport() }
//}
fn get_url(&self) -> Option<gst_rtsp::RTSPUrl> {
unsafe {
2019-03-19 07:40:05 +00:00
from_glib_none(gst_rtsp_server_sys::gst_rtsp_stream_transport_get_url(self.as_ref().to_glib_none().0))
}
}
fn is_timed_out(&self) -> bool {
unsafe {
2019-03-19 07:40:05 +00:00
from_glib(gst_rtsp_server_sys::gst_rtsp_stream_transport_is_timed_out(self.as_ref().to_glib_none().0))
}
}
fn keep_alive(&self) {
unsafe {
2019-03-19 07:40:05 +00:00
gst_rtsp_server_sys::gst_rtsp_stream_transport_keep_alive(self.as_ref().to_glib_none().0);
}
}
fn send_rtcp(&self, buffer: &gst::Buffer) -> Result<(), glib::error::BoolError> {
unsafe {
2019-03-19 07:40:05 +00:00
glib_result_from_gboolean!(gst_rtsp_server_sys::gst_rtsp_stream_transport_send_rtcp(self.as_ref().to_glib_none().0, buffer.to_glib_none().0), "Failed to send rtcp")
}
}
fn send_rtp(&self, buffer: &gst::Buffer) -> Result<(), glib::error::BoolError> {
unsafe {
2019-03-19 07:40:05 +00:00
glib_result_from_gboolean!(gst_rtsp_server_sys::gst_rtsp_stream_transport_send_rtp(self.as_ref().to_glib_none().0, buffer.to_glib_none().0), "Failed to send rtp")
}
}
fn set_active(&self, active: bool) -> Result<(), glib::error::BoolError> {
unsafe {
2019-03-19 07:40:05 +00:00
glib_result_from_gboolean!(gst_rtsp_server_sys::gst_rtsp_stream_transport_set_active(self.as_ref().to_glib_none().0, active.to_glib()), "Failed to set active")
}
}
2019-01-29 13:53:44 +00:00
//fn set_callbacks<P: Fn(&gst::Buffer, u8) -> bool + 'static, Q: Fn(&gst::Buffer, u8) -> bool + 'static>(&self, send_rtp: P, send_rtcp: Q) {
2019-03-19 07:40:05 +00:00
// unsafe { TODO: call gst_rtsp_server_sys:gst_rtsp_stream_transport_set_callbacks() }
//}
2019-01-29 13:53:44 +00:00
fn set_keepalive<P: Fn() + 'static>(&self, keep_alive: P) {
let keep_alive_data: Box_<P> = Box::new(keep_alive);
2019-03-19 07:40:05 +00:00
unsafe extern "C" fn keep_alive_func<P: Fn() + 'static>(user_data: glib_sys::gpointer) {
2019-01-29 13:53:44 +00:00
let callback: &P = &*(user_data as *mut _);
(*callback)();
}
let keep_alive = Some(keep_alive_func::<P> as _);
2019-03-19 07:40:05 +00:00
unsafe extern "C" fn notify_func<P: Fn() + 'static>(data: glib_sys::gpointer) {
2019-01-29 13:53:44 +00:00
let _callback: Box_<P> = Box_::from_raw(data as *mut _);
}
let destroy_call3 = Some(notify_func::<P> as _);
let super_callback0: Box_<P> = keep_alive_data;
unsafe {
2019-03-19 07:40:05 +00:00
gst_rtsp_server_sys::gst_rtsp_stream_transport_set_keepalive(self.as_ref().to_glib_none().0, keep_alive, Box::into_raw(super_callback0) as *mut _, destroy_call3);
2019-01-29 13:53:44 +00:00
}
}
fn set_timed_out(&self, timedout: bool) {
unsafe {
2019-03-19 07:40:05 +00:00
gst_rtsp_server_sys::gst_rtsp_stream_transport_set_timed_out(self.as_ref().to_glib_none().0, timedout.to_glib());
}
}
//fn set_transport(&self, tr: /*Ignored*/&mut gst_rtsp::RTSPTransport) {
2019-03-19 07:40:05 +00:00
// unsafe { TODO: call gst_rtsp_server_sys:gst_rtsp_stream_transport_set_transport() }
//}
2019-03-19 07:40:05 +00:00
fn set_url(&self, url: Option<&gst_rtsp::RTSPUrl>) {
unsafe {
2019-03-19 07:40:05 +00:00
gst_rtsp_server_sys::gst_rtsp_stream_transport_set_url(self.as_ref().to_glib_none().0, url.to_glib_none().0);
}
}
}