Struct ReadConnection

Source
pub struct ReadConnection<Read: ReadHalf> { /* private fields */ }
Expand description

A connection that can only be used for reading.

§Cancel safety

All async methods of this type are cancel safe unless explicitly stated otherwise in its documentation.

Implementations§

Source§

impl<Read: ReadHalf> ReadConnection<Read>

Source

pub fn id(&self) -> usize

The unique identifier of the connection.

Source

pub async fn receive_reply<'r, Params, ReplyError>( &'r mut self, ) -> Result<Result<Reply<Params>, ReplyError>>
where Params: Deserialize<'r> + Debug, ReplyError: Deserialize<'r> + Debug,

Receives a method call reply.

The generic parameters needs some explanation:

  • Params is the type of the successful reply. This should be a type that can deserialize itself from the parameters field of the reply.
  • ReplyError is the type of the error reply. This should be a type that can deserialize itself from the whole reply object itself and must fail when there is no error field in the object. This can be easily achieved using the serde::Deserialize derive:
use serde::{Deserialize, Serialize};

#[derive(Debug, Deserialize, Serialize)]
#[serde(tag = "error", content = "parameters")]
enum MyError {
   // The name needs to be the fully-qualified name of the error.
   #[serde(rename = "org.example.ftl.Alpha")]
   Alpha { param1: u32, param2: String },
   #[serde(rename = "org.example.ftl.Bravo")]
   Bravo,
   #[serde(rename = "org.example.ftl.Charlie")]
   Charlie { param1: String },
}
Source

pub async fn receive_call<'m, Method>(&'m mut self) -> Result<Call<Method>>
where Method: Deserialize<'m> + Debug,

Receive a method call over the socket.

The generic Method is the type of the method name and its input parameters. This should be a type that can deserialize itself from a complete method call message, i-e an object containing method and parameter fields. This can be easily achieved using the serde::Deserialize derive (See the code snippet in super::WriteConnection::send_call documentation for an example).

Trait Implementations§

Source§

impl<Read: Debug + ReadHalf> Debug for ReadConnection<Read>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<Read> Freeze for ReadConnection<Read>
where Read: Freeze,

§

impl<Read> RefUnwindSafe for ReadConnection<Read>
where Read: RefUnwindSafe,

§

impl<Read> Send for ReadConnection<Read>
where Read: Send,

§

impl<Read> Sync for ReadConnection<Read>
where Read: Sync,

§

impl<Read> Unpin for ReadConnection<Read>
where Read: Unpin,

§

impl<Read> UnwindSafe for ReadConnection<Read>
where Read: UnwindSafe,

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
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.

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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more