mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-22 23:18:26 +00:00
base classes: expose accessors for static pads
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer-rs/-/merge_requests/1023>
This commit is contained in:
parent
08953dfe66
commit
ba25d7ea90
10 changed files with 156 additions and 0 deletions
|
@ -57,6 +57,10 @@ pub trait AudioDecoderExtManual: 'static {
|
||||||
function: &str,
|
function: &str,
|
||||||
line: u32,
|
line: u32,
|
||||||
) -> Result<gst::FlowSuccess, gst::FlowError>;
|
) -> Result<gst::FlowSuccess, gst::FlowError>;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<AudioDecoder>> AudioDecoderExtManual for O {
|
impl<O: IsA<AudioDecoder>> AudioDecoderExtManual for O {
|
||||||
|
@ -173,6 +177,20 @@ impl<O: IsA<AudioDecoder>> AudioDecoderExtManual for O {
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstAudioDecoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstAudioDecoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
|
|
|
@ -23,6 +23,10 @@ pub trait AudioEncoderExtManual: 'static {
|
||||||
#[doc(alias = "get_allocator")]
|
#[doc(alias = "get_allocator")]
|
||||||
#[doc(alias = "gst_audio_encoder_get_allocator")]
|
#[doc(alias = "gst_audio_encoder_get_allocator")]
|
||||||
fn allocator(&self) -> (Option<gst::Allocator>, gst::AllocationParams);
|
fn allocator(&self) -> (Option<gst::Allocator>, gst::AllocationParams);
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<AudioEncoder>> AudioEncoderExtManual for O {
|
impl<O: IsA<AudioEncoder>> AudioEncoderExtManual for O {
|
||||||
|
@ -79,4 +83,18 @@ impl<O: IsA<AudioEncoder>> AudioEncoderExtManual for O {
|
||||||
(from_glib_full(allocator), params.into())
|
(from_glib_full(allocator), params.into())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstAudioEncoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstAudioEncoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -87,6 +87,8 @@ pub trait AggregatorExtManual: 'static {
|
||||||
) -> SignalHandlerId
|
) -> SignalHandlerId
|
||||||
where
|
where
|
||||||
P: IsA<Aggregator>;
|
P: IsA<Aggregator>;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<Aggregator>> AggregatorExtManual for O {
|
impl<O: IsA<Aggregator>> AggregatorExtManual for O {
|
||||||
|
@ -274,6 +276,14 @@ impl<O: IsA<Aggregator>> AggregatorExtManual for O {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let ptr: &ffi::GstAggregator = &*(self.as_ptr() as *const _);
|
||||||
|
|
||||||
|
from_glib_none(ptr.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(any(feature = "v1_16", feature = "dox"))]
|
#[cfg(any(feature = "v1_16", feature = "dox"))]
|
||||||
|
|
|
@ -13,6 +13,8 @@ pub trait BaseSinkExtManual: 'static {
|
||||||
fn query_latency(
|
fn query_latency(
|
||||||
&self,
|
&self,
|
||||||
) -> Result<(bool, bool, Option<gst::ClockTime>, Option<gst::ClockTime>), glib::BoolError>;
|
) -> Result<(bool, bool, Option<gst::ClockTime>, Option<gst::ClockTime>), glib::BoolError>;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<BaseSink>> BaseSinkExtManual for O {
|
impl<O: IsA<BaseSink>> BaseSinkExtManual for O {
|
||||||
|
@ -55,4 +57,12 @@ impl<O: IsA<BaseSink>> BaseSinkExtManual for O {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let ptr: &ffi::GstBaseSink = &*(self.as_ptr() as *const _);
|
||||||
|
|
||||||
|
from_glib_none(ptr.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,8 @@ pub trait BaseSrcExtManual: 'static {
|
||||||
#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))]
|
#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))]
|
||||||
#[doc(alias = "gst_base_src_new_segment")]
|
#[doc(alias = "gst_base_src_new_segment")]
|
||||||
fn new_segment(&self, segment: &gst::Segment) -> Result<(), glib::BoolError>;
|
fn new_segment(&self, segment: &gst::Segment) -> Result<(), glib::BoolError>;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<BaseSrc>> BaseSrcExtManual for O {
|
impl<O: IsA<BaseSrc>> BaseSrcExtManual for O {
|
||||||
|
@ -92,4 +94,12 @@ impl<O: IsA<BaseSrc>> BaseSrcExtManual for O {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let ptr: &ffi::GstBaseSrc = &*(self.as_ptr() as *const _);
|
||||||
|
|
||||||
|
from_glib_none(ptr.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,10 @@ pub trait BaseTransformExtManual: 'static {
|
||||||
|
|
||||||
#[doc(alias = "get_segment")]
|
#[doc(alias = "get_segment")]
|
||||||
fn segment(&self) -> gst::Segment;
|
fn segment(&self) -> gst::Segment;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<BaseTransform>> BaseTransformExtManual for O {
|
impl<O: IsA<BaseTransform>> BaseTransformExtManual for O {
|
||||||
|
@ -36,4 +40,18 @@ impl<O: IsA<BaseTransform>> BaseTransformExtManual for O {
|
||||||
from_glib_none(&trans.segment as *const _)
|
from_glib_none(&trans.segment as *const _)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstBaseTransform = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstBaseTransform = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,10 @@ pub trait RTPBaseDepayloadExtManual: 'static {
|
||||||
|
|
||||||
#[doc(alias = "gst_rtp_base_depayload_push_list")]
|
#[doc(alias = "gst_rtp_base_depayload_push_list")]
|
||||||
fn push_list(&self, list: gst::BufferList) -> Result<gst::FlowSuccess, gst::FlowError>;
|
fn push_list(&self, list: gst::BufferList) -> Result<gst::FlowSuccess, gst::FlowError>;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<RTPBaseDepayload>> RTPBaseDepayloadExtManual for O {
|
impl<O: IsA<RTPBaseDepayload>> RTPBaseDepayloadExtManual for O {
|
||||||
|
@ -28,4 +32,18 @@ impl<O: IsA<RTPBaseDepayload>> RTPBaseDepayloadExtManual for O {
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstRTPBaseDepayload = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstRTPBaseDepayload = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,10 @@ pub trait RTPBasePayloadExtManual: 'static {
|
||||||
|
|
||||||
#[doc(alias = "gst_rtp_base_payload_push_list")]
|
#[doc(alias = "gst_rtp_base_payload_push_list")]
|
||||||
fn push_list(&self, list: gst::BufferList) -> Result<gst::FlowSuccess, gst::FlowError>;
|
fn push_list(&self, list: gst::BufferList) -> Result<gst::FlowSuccess, gst::FlowError>;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<RTPBasePayload>> RTPBasePayloadExtManual for O {
|
impl<O: IsA<RTPBasePayload>> RTPBasePayloadExtManual for O {
|
||||||
|
@ -51,4 +55,18 @@ impl<O: IsA<RTPBasePayload>> RTPBasePayloadExtManual for O {
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstRTPBasePayload = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstRTPBasePayload = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -110,6 +110,10 @@ pub trait VideoDecoderExtManual: 'static {
|
||||||
function: &str,
|
function: &str,
|
||||||
line: u32,
|
line: u32,
|
||||||
) -> Result<gst::FlowSuccess, gst::FlowError>;
|
) -> Result<gst::FlowSuccess, gst::FlowError>;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<VideoDecoder>> VideoDecoderExtManual for O {
|
impl<O: IsA<VideoDecoder>> VideoDecoderExtManual for O {
|
||||||
|
@ -407,6 +411,20 @@ impl<O: IsA<VideoDecoder>> VideoDecoderExtManual for O {
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstVideoDecoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstVideoDecoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl HasStreamLock for VideoDecoder {
|
impl HasStreamLock for VideoDecoder {
|
||||||
|
|
|
@ -69,6 +69,10 @@ pub trait VideoEncoderExtManual: 'static {
|
||||||
&'a self,
|
&'a self,
|
||||||
output_state: VideoCodecState<'a, InNegotiation<'a>>,
|
output_state: VideoCodecState<'a, InNegotiation<'a>>,
|
||||||
) -> Result<(), gst::FlowError>;
|
) -> Result<(), gst::FlowError>;
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad;
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<O: IsA<VideoEncoder>> VideoEncoderExtManual for O {
|
impl<O: IsA<VideoEncoder>> VideoEncoderExtManual for O {
|
||||||
|
@ -252,6 +256,20 @@ impl<O: IsA<VideoEncoder>> VideoEncoderExtManual for O {
|
||||||
Err(gst::FlowError::NotNegotiated)
|
Err(gst::FlowError::NotNegotiated)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn sink_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstVideoEncoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.sinkpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn src_pad(&self) -> gst::Pad {
|
||||||
|
unsafe {
|
||||||
|
let elt: &ffi::GstVideoEncoder = &*(self.as_ptr() as *const _);
|
||||||
|
from_glib_none(elt.srcpad)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl HasStreamLock for VideoEncoder {
|
impl HasStreamLock for VideoEncoder {
|
||||||
|
|
Loading…
Reference in a new issue