bt_avdtp

Struct StreamEndpoint

Source
pub struct StreamEndpoint { /* private fields */ }
Expand description

An AVDTP StreamEndpoint. StreamEndpoints represent a particular capability of the application to be a source of sink of media. Included here to aid negotiating the stream connection. See Section 5.3 of the AVDTP 1.3 Specification for more information about the Stream Endpoint Architecture.

Implementations§

Source§

impl StreamEndpoint

Source

pub fn new( id: u8, media_type: MediaType, endpoint_type: EndpointType, capabilities: Vec<ServiceCapability>, ) -> AvdtpResult<StreamEndpoint>

Make a new StreamEndpoint. |id| must be in the valid range for a StreamEndpointId (0x01 - 0x3E). StreamEndpoints start in the Idle state.

Source

pub fn as_new(&self) -> Self

Source

pub fn set_update_callback( &mut self, callback: Option<StreamEndpointUpdateCallback>, )

Pass update callback to StreamEndpoint that will be called anytime StreamEndpoint is modified.

Source

pub fn from_info( info: &StreamInformation, capabilities: Vec<ServiceCapability>, ) -> StreamEndpoint

Build a new StreamEndpoint from a StreamInformation and associated Capabilities. This makes it easy to build from AVDTP Discover and GetCapabilities procedures. StreamEndpooints start in the Idle state.

Source

pub fn configure( &mut self, remote_id: &StreamEndpointId, capabilities: Vec<ServiceCapability>, ) -> Result<(), (ServiceCategory, ErrorCode)>

Attempt to Configure this stream using the capabilities given. If the stream is not in an Idle state, fails with Err(InvalidState). Used for the Stream Configuration procedure, see Section 6.9

Source

pub fn reconfigure( &mut self, capabilities: Vec<ServiceCapability>, ) -> Result<(), (ServiceCategory, ErrorCode)>

Attempt to reconfigure this stream with the capabilities given. If any capability is not valid to set, fails with the first such category and InvalidCapabilities If the stream is not in the Open state, fails with Err((None, BadState)) Used for the Stream Reconfiguration procedure, see Section 6.15.

Source

pub fn get_configuration(&self) -> Option<&Vec<ServiceCapability>>

Get the current configuration of this stream. If the stream is not configured, returns None. Used for the Steam Get Configuration Procedure, see Section 6.10

Source

pub fn receive_channel(&mut self, c: Channel) -> AvdtpResult<bool>

When a L2CAP channel is received after an Open command is accepted, it should be delivered via receive_channel. Returns true if this Endpoint expects more channels to be established before streaming is started. Returns Err(InvalidState) if this Endpoint is not expecting a channel to be established, closing |c|.

Source

pub fn establish(&mut self) -> Result<(), ErrorCode>

Begin opening this stream. The stream must be in a Configured state. See Stream Establishment, Section 6.11

Source

pub fn try_priority(&self, active: bool)

Attempts to set audio direction priority of the MediaTransport channel based on whether the stream is a source or sink endpoint if active is true. If active is false, set the priority to Normal instead. Does nothing on failure.

Source

pub fn try_flush_timeout(&self, timeout: MonotonicDuration)

Attempts to set the flush timeout for the MediaTransport channel, for source endpoints.

Source

pub fn release( &mut self, responder: SimpleResponder, peer: &Peer, ) -> AvdtpResult<()>

Close this stream. This procedure will wait until media channels are closed before transitioning to Idle. If the channels are not closed in 3 seconds, we initiate an abort procedure with the remote |peer| to force a transition to Idle.

Source

pub fn state(&self) -> StreamState

Returns the current state of this endpoint.

Source

pub fn start(&mut self) -> Result<(), ErrorCode>

Start this stream. This can be done only from the Open State. Used for the Stream Start procedure, See Section 6.12

Source

pub fn suspend(&mut self) -> Result<(), ErrorCode>

Suspend this stream. This can be done only from the Streaming state. Used for the Stream Suspend procedure, See Section 6.14

Source

pub async fn initiate_abort<'a>(&'a mut self, peer: &'a Peer)

Abort this stream. This can be done from any state, and will always return the state to Idle. We are initiating this procedure so will wait for a response and all our channels will be closed.

Source

pub fn abort(&mut self)

Abort this stream. This can be done from any state, and will always return the state to Idle. We are receiving this abort from the peer, and all our channels will close.

Source

pub fn capabilities(&self) -> &Vec<ServiceCapability>

Capabilities of this StreamEndpoint. Provides support for the Get Capabilities and Get All Capabilities signaling procedures. See Sections 6.7 and 6.8

Source

pub fn codec_type(&self) -> Option<&MediaCodecType>

Returns the CodecType of this StreamEndpoint. Returns None if there is no MediaCodec capability in the endpoint. Note: a MediaCodec capability is required by all endpoints by the spec.

Source

pub fn local_id(&self) -> &StreamEndpointId

Returns the local StreamEndpointId for this endpoint.

Source

pub fn remote_id(&self) -> Option<&StreamEndpointId>

Returns the remote StreamEndpointId for this endpoint, if it’s configured.

Source

pub fn endpoint_type(&self) -> &EndpointType

Returns the EndpointType of this endpoint

Source

pub fn information(&self) -> StreamInformation

Make a StreamInformation which represents the current state of this stream.

Source

pub fn take_transport(&mut self) -> Option<MediaStream>

Take the media transport channel, which transmits (or receives) any media for this StreamEndpoint. Returns None if the channel is held already, or if the channel has not been opened.

Trait Implementations§

Source§

impl Debug for StreamEndpoint

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> DebugExt for T
where T: Debug,

§

fn debug(&self) -> String

§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V