gstreamer_rtp::prelude

Trait RTPBaseDepayloadExt

Source
pub trait RTPBaseDepayloadExt: IsA<RTPBaseDepayload> + 'static {
Show 25 methods // Provided methods fn delayed(&self) { ... } fn dropped(&self) { ... } fn flush(&self, keep_current: bool) { ... } fn is_aggregate_hdrext_enabled(&self) -> bool { ... } fn is_source_info_enabled(&self) -> bool { ... } fn push(&self, out_buf: Buffer) -> Result<FlowSuccess, FlowError> { ... } fn push_list(&self, out_list: BufferList) -> Result<FlowSuccess, FlowError> { ... } fn set_aggregate_hdrext_enabled(&self, enable: bool) { ... } fn set_source_info_enabled(&self, enable: bool) { ... } fn is_auto_header_extension(&self) -> bool { ... } fn set_auto_header_extension(&self, auto_header_extension: bool) { ... } fn max_reorder(&self) -> i32 { ... } fn set_max_reorder(&self, max_reorder: i32) { ... } fn is_source_info(&self) -> bool { ... } fn set_source_info(&self, source_info: bool) { ... } fn stats(&self) -> Option<Structure> { ... } fn connect_add_extension<F: Fn(&Self, &RTPHeaderExtension) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn emit_add_extension(&self, ext: &RTPHeaderExtension) { ... } fn connect_clear_extensions<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn emit_clear_extensions(&self) { ... } fn connect_request_extension<F: Fn(&Self, u32, Option<&str>) -> Option<RTPHeaderExtension> + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_auto_header_extension_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_max_reorder_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_source_info_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_stats_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... }
}
Expand description

Trait containing all RTPBaseDepayload methods.

§Implementors

RTPBaseDepayload

Provided Methods§

Source

fn delayed(&self)

Called from RTPBaseDepayload or RTPBaseDepayload when the depayloader needs to keep the current input RTP header for use with the next output buffer.

The delayed buffer will remain until the end of processing the current output buffer and then enqueued for processing with the next output buffer.

A typical use-case is when the depayloader implementation will start a new output buffer for the current input RTP buffer but push the current output buffer first.

Must be called with the stream lock held.

Source

fn dropped(&self)

Called from RTPBaseDepayload or RTPBaseDepayload if the depayloader does not use the current buffer for the output buffer. This will either drop the delayed buffer or the last buffer from the header extension cache.

A typical use-case is when the depayloader implementation is dropping an input RTP buffer while waiting for the first keyframe.

Must be called with the stream lock held.

Source

fn flush(&self, keep_current: bool)

If RTPBaseDepayload or RTPBaseDepayload drop an output buffer this function tells the base class to flush header extension cache as well.

This will not drop an input RTP header marked as delayed from delayed().

If keep_current is true the current input RTP header will be kept and enqueued after flushing the previous input RTP headers.

A typical use-case for keep_current is when the depayloader implementation invalidates the current output buffer and starts a new one with the current RTP input buffer.

Must be called with the stream lock held.

§keep_current

if the current RTP buffer shall be kept

Source

fn is_aggregate_hdrext_enabled(&self) -> bool

Queries whether header extensions will be aggregated per depayloaded buffers.

§Returns

true if aggregate-header-extension is enabled.

Source

fn is_source_info_enabled(&self) -> bool

Queries whether GstRTPSourceMeta will be added to depayloaded buffers.

§Returns

true if source-info is enabled.

Source

fn push(&self, out_buf: Buffer) -> Result<FlowSuccess, FlowError>

Push out_buf to the peer of self. This function takes ownership of out_buf.

This function will by default apply the last incoming timestamp on the outgoing buffer when it didn’t have a timestamp already.

§out_buf

a gst::Buffer

§Returns

a gst::FlowReturn.

Source

fn push_list(&self, out_list: BufferList) -> Result<FlowSuccess, FlowError>

Push out_list to the peer of self. This function takes ownership of out_list.

§out_list

a gst::BufferList

§Returns

a gst::FlowReturn.

Source

fn set_aggregate_hdrext_enabled(&self, enable: bool)

Enable or disable aggregating header extensions.

§enable

whether to aggregate header extensions per output buffer

Source

fn set_source_info_enabled(&self, enable: bool)

Enable or disable adding GstRTPSourceMeta to depayloaded buffers.

§enable

whether to add meta about RTP sources to buffer

Source

fn is_auto_header_extension(&self) -> bool

If enabled, the depayloader will automatically try to enable all the RTP header extensions provided in the sink caps, saving the application the need to handle these extensions manually using the GstRTPBaseDepayload::request-extension: signal.

Source

fn set_auto_header_extension(&self, auto_header_extension: bool)

If enabled, the depayloader will automatically try to enable all the RTP header extensions provided in the sink caps, saving the application the need to handle these extensions manually using the GstRTPBaseDepayload::request-extension: signal.

Source

fn max_reorder(&self) -> i32

Max seqnum reorder before the sender is assumed to have restarted.

When max-reorder is set to 0 all reordered/duplicate packets are considered coming from a restarted sender.

Source

fn set_max_reorder(&self, max_reorder: i32)

Max seqnum reorder before the sender is assumed to have restarted.

When max-reorder is set to 0 all reordered/duplicate packets are considered coming from a restarted sender.

Source

fn is_source_info(&self) -> bool

Add RTP source information found in RTP header as meta to output buffer.

Source

fn set_source_info(&self, source_info: bool)

Add RTP source information found in RTP header as meta to output buffer.

Source

fn stats(&self) -> Option<Structure>

Various depayloader statistics retrieved atomically (and are therefore synchroized with each other). This property return a GstStructure named application/x-rtp-depayload-stats containing the following fields relating to the last processed buffer and current state of the stream being depayloaded:

  • clock-rate: G_TYPE_UINT, clock-rate of the stream
  • npt-start: G_TYPE_UINT64, time of playback start
  • npt-stop: G_TYPE_UINT64, time of playback stop
  • play-speed: G_TYPE_DOUBLE, the playback speed
  • play-scale: G_TYPE_DOUBLE, the playback scale
  • running-time-dts: G_TYPE_UINT64, the last running-time of the last DTS
  • running-time-pts: G_TYPE_UINT64, the last running-time of the last PTS
  • seqnum: G_TYPE_UINT, the last seen seqnum
  • timestamp: G_TYPE_UINT, the last seen RTP timestamp
Source

fn connect_add_extension<F: Fn(&Self, &RTPHeaderExtension) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Add ext as an extension for reading part of an RTP header extension from incoming RTP packets.

§ext

the RTPHeaderExtension

Source

fn emit_add_extension(&self, ext: &RTPHeaderExtension)

Source

fn connect_clear_extensions<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Clear all RTP header extensions used by this depayloader.

Source

fn emit_clear_extensions(&self)

Source

fn connect_request_extension<F: Fn(&Self, u32, Option<&str>) -> Option<RTPHeaderExtension> + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

The returned ext must be configured with the correct ext_id and with the necessary attributes as required by the extension implementation.

§ext_id

the extension id being requested

§ext_uri

the extension URI being requested

§Returns

the RTPHeaderExtension for ext_id, or None

Source

fn connect_auto_header_extension_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_max_reorder_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_source_info_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_stats_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§