pub struct QueryMessage<I, A> {
pub ltime: LamportTime,
pub id: u32,
pub from: Node<I, A>,
pub filters: TinyVec<Bytes>,
pub flags: QueryFlag,
pub relay_factor: u8,
pub timeout: Duration,
pub name: SmolStr,
pub payload: Bytes,
}
Expand description
Query message
Fields§
§ltime: LamportTime
Event lamport time
id: u32
query id, randomly generated
from: Node<I, A>
source node
filters: TinyVec<Bytes>
Potential query filters
flags: QueryFlag
Used to provide various flags
relay_factor: u8
Used to set the number of duplicate relayed responses
timeout: Duration
Maximum time between delivery and response
name: SmolStr
Query nqme
payload: Bytes
Query payload
Implementations§
Source§impl<I, A> QueryMessage<I, A>
impl<I, A> QueryMessage<I, A>
Sourcepub const fn ltime(&self) -> LamportTime
pub const fn ltime(&self) -> LamportTime
Returns the event lamport time
Sourcepub const fn relay_factor(&self) -> u8
pub const fn relay_factor(&self) -> u8
Returns the number of duplicate relayed responses
Sourcepub const fn with_ltime(self, val: LamportTime) -> Self
pub const fn with_ltime(self, val: LamportTime) -> Self
Sets the event lamport time (Builder pattern)
Sourcepub fn with_filters(self, val: TinyVec<Bytes>) -> Self
pub fn with_filters(self, val: TinyVec<Bytes>) -> Self
Sets the potential query filters (Builder pattern)
Sourcepub fn with_flags(self, val: QueryFlag) -> Self
pub fn with_flags(self, val: QueryFlag) -> Self
Sets the flags (Builder pattern)
Sourcepub fn with_relay_factor(self, val: u8) -> Self
pub fn with_relay_factor(self, val: u8) -> Self
Sets the number of duplicate relayed responses (Builder pattern)
Sourcepub fn with_timeout(self, val: Duration) -> Self
pub fn with_timeout(self, val: Duration) -> Self
Sets the maximum time between delivery and response (Builder pattern)
Sourcepub fn with_payload(self, val: Bytes) -> Self
pub fn with_payload(self, val: Bytes) -> Self
Sets the payload (Builder pattern)
Source§impl<I, A> QueryMessage<I, A>
impl<I, A> QueryMessage<I, A>
Trait Implementations§
Source§impl<I, A> AsMessageRef<I, A> for &QueryMessage<I, A>
impl<I, A> AsMessageRef<I, A> for &QueryMessage<I, A>
Source§fn as_message_ref(&self) -> SerfMessageRef<'_, I, A>
fn as_message_ref(&self) -> SerfMessageRef<'_, I, A>
Converts this type into a shared reference of the (usually inferred) input type.
Source§impl<I, A> AsMessageRef<I, A> for QueryMessage<I, A>
impl<I, A> AsMessageRef<I, A> for QueryMessage<I, A>
Source§fn as_message_ref(&self) -> SerfMessageRef<'_, I, A>
fn as_message_ref(&self) -> SerfMessageRef<'_, I, A>
Converts this type into a shared reference of the (usually inferred) input type.
Source§impl<I: Clone, A: Clone> Clone for QueryMessage<I, A>
impl<I: Clone, A: Clone> Clone for QueryMessage<I, A>
Source§fn clone(&self) -> QueryMessage<I, A>
fn clone(&self) -> QueryMessage<I, A>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<'de, I, A> Deserialize<'de> for QueryMessage<I, A>where
I: Deserialize<'de>,
A: Deserialize<'de>,
impl<'de, I, A> Deserialize<'de> for QueryMessage<I, A>where
I: Deserialize<'de>,
A: Deserialize<'de>,
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<I, A> Serialize for QueryMessage<I, A>
impl<I, A> Serialize for QueryMessage<I, A>
Source§impl<I, A> Transformable for QueryMessage<I, A>where
I: Transformable,
A: Transformable,
impl<I, A> Transformable for QueryMessage<I, A>where
I: Transformable,
A: Transformable,
Source§type Error = QueryMessageTransformError<I, A>
type Error = QueryMessageTransformError<I, A>
The error type returned when encoding or decoding fails.
Source§fn encode(&self, dst: &mut [u8]) -> Result<usize, Self::Error>
fn encode(&self, dst: &mut [u8]) -> Result<usize, Self::Error>
Encodes the value into the given buffer for transmission. Read more
Source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
Returns the encoded length of the value.
This is used to pre-allocate a buffer for encoding.
Source§fn decode(src: &[u8]) -> Result<(usize, Self), Self::Error>where
Self: Sized,
fn decode(src: &[u8]) -> Result<(usize, Self), Self::Error>where
Self: Sized,
Decodes the value from the given buffer received over the wire. Read more
Source§fn encode_to_vec(&self) -> Result<Vec<u8>, Self::Error>
fn encode_to_vec(&self) -> Result<Vec<u8>, Self::Error>
Encodes the value into a vec for transmission.
Source§fn encode_to_writer<W>(&self, writer: &mut W) -> Result<usize, Error>where
W: Write,
fn encode_to_writer<W>(&self, writer: &mut W) -> Result<usize, Error>where
W: Write,
Encodes the value into the given writer for transmission.
Source§fn encode_to_async_writer<W>(
&self,
writer: &mut W,
) -> impl Future<Output = Result<usize, Error>> + Send
fn encode_to_async_writer<W>( &self, writer: &mut W, ) -> impl Future<Output = Result<usize, Error>> + Send
Encodes the value into the given async writer for transmission.
impl<I: Eq, A: Eq> Eq for QueryMessage<I, A>
impl<I, A> StructuralPartialEq for QueryMessage<I, A>
Auto Trait Implementations§
impl<I, A> !Freeze for QueryMessage<I, A>
impl<I, A> RefUnwindSafe for QueryMessage<I, A>where
I: RefUnwindSafe,
A: RefUnwindSafe,
impl<I, A> Send for QueryMessage<I, A>
impl<I, A> Sync for QueryMessage<I, A>
impl<I, A> Unpin for QueryMessage<I, A>
impl<I, A> UnwindSafe for QueryMessage<I, A>where
I: UnwindSafe,
A: UnwindSafe,
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<K, Q> Comparable<Q> for K
impl<K, Q> Comparable<Q> for K
Source§impl<T> Decodable for Twhere
T: Transformable,
impl<T> Decodable for Twhere
T: Transformable,
Source§type Error = <T as Transformable>::Error
type Error = <T as Transformable>::Error
The error type returned when encoding or decoding fails.
Source§fn decode(src: &[u8]) -> Result<(usize, T), <T as Decodable>::Error>
fn decode(src: &[u8]) -> Result<(usize, T), <T as Decodable>::Error>
Decodes the value from the given buffer received over the wire. Read more
Source§impl<T> Encodable for Twhere
T: Transformable,
impl<T> Encodable for Twhere
T: Transformable,
Source§type Error = <T as Transformable>::Error
type Error = <T as Transformable>::Error
The error type returned when encoding or decoding fails.
Source§fn encode(&self, dst: &mut [u8]) -> Result<usize, <T as Encodable>::Error>
fn encode(&self, dst: &mut [u8]) -> Result<usize, <T as Encodable>::Error>
Encodes the value into the given buffer for transmission. Read more
Source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
Returns the encoded length of the value.
This is used to pre-allocate a buffer for encoding.
Source§fn encode_to_vec(&self) -> Result<Vec<u8>, <T as Encodable>::Error>
fn encode_to_vec(&self) -> Result<Vec<u8>, <T as Encodable>::Error>
Encodes the value into a vec for transmission.
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<K, Q> Equivalent<Q> for K
impl<K, Q> Equivalent<Q> for K
Source§fn equivalent(&self, key: &Q) -> bool
fn equivalent(&self, key: &Q) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out
indicating that a T
is niched.