Struct timely_communication::networking::MessageHeader

source ·
pub struct MessageHeader {
    pub channel: usize,
    pub source: usize,
    pub target: usize,
    pub length: usize,
    pub seqno: usize,
}
Expand description

Framing data for each Vec<u8> transmission, indicating a typed channel, the source and destination workers, and the length in bytes.

Fields§

§channel: usize

index of channel.

§source: usize

index of worker sending message.

§target: usize

index of worker receiving message.

§length: usize

number of bytes in message.

§seqno: usize

sequence number.

Implementations§

source§

impl MessageHeader

source

pub fn try_read(bytes: &mut [u8]) -> Option<MessageHeader>

Returns a header when there is enough supporting data

source

pub fn write_to<W: Write>(&self, writer: &mut W) -> Result<()>

Writes the header as binary data.

source

pub fn required_bytes(&self) -> usize

The number of bytes required for the header and data.

Trait Implementations§

source§

impl Clone for MessageHeader

source§

fn clone(&self) -> MessageHeader

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Columnar for MessageHeader
where usize: Columnar,

§

type Ref<'a> = MessageHeaderReference<<usize as Columnar>::Ref<'a>, <usize as Columnar>::Ref<'a>, <usize as Columnar>::Ref<'a>, <usize as Columnar>::Ref<'a>, <usize as Columnar>::Ref<'a>> where usize: 'a

For each lifetime, a reference with that lifetime. Read more
source§

fn copy_from<'a>(&mut self, other: Self::Ref<'a>)

Repopulates self from a reference. Read more
source§

fn into_owned<'a>(other: Self::Ref<'a>) -> Self

Produce an instance of Self from Self::Ref<'a>.
§

type Container = MessageHeaderContainer<<usize as Columnar>::Container, <usize as Columnar>::Container, <usize as Columnar>::Container, <usize as Columnar>::Container, <usize as Columnar>::Container>

The type that stores the columnar representation. Read more
source§

fn as_columns<'a, I>(selves: I) -> Self::Container
where I: IntoIterator<Item = &'a Self>, Self: 'a,

Converts a sequence of the references to the type into columnar form.
source§

fn into_columns<I>(selves: I) -> Self::Container
where I: IntoIterator<Item = Self>, Self: Sized,

Converts a sequence of the type into columnar form. Read more
source§

impl Container<MessageHeader> for MessageHeaderContainer<<usize as Columnar>::Container, <usize as Columnar>::Container, <usize as Columnar>::Container, <usize as Columnar>::Container, <usize as Columnar>::Container>
where usize: Columnar,

§

type Borrowed<'a> = MessageHeaderContainer<<<usize as Columnar>::Container as Container<usize>>::Borrowed<'a>, <<usize as Columnar>::Container as Container<usize>>::Borrowed<'a>, <<usize as Columnar>::Container as Container<usize>>::Borrowed<'a>, <<usize as Columnar>::Container as Container<usize>>::Borrowed<'a>, <<usize as Columnar>::Container as Container<usize>>::Borrowed<'a>> where usize: 'a

The type of a borrowed container. Read more
source§

fn borrow<'a>(&'a self) -> Self::Borrowed<'a>

Converts a reference to the type to a borrowed variant.
source§

impl Debug for MessageHeader

source§

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

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for MessageHeader

source§

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 Hash for MessageHeader

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<R0, R1, R2, R3, R4> PartialEq<MessageHeader> for MessageHeaderReference<R0, R1, R2, R3, R4>

source§

fn eq(&self, other: &MessageHeader) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialEq for MessageHeader

source§

fn eq(&self, other: &MessageHeader) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'columnar, C0, C1, C2, C3, C4> Push<&'columnar MessageHeader> for MessageHeaderContainer<C0, C1, C2, C3, C4>
where C0: Push<&'columnar usize>, C1: Push<&'columnar usize>, C2: Push<&'columnar usize>, C3: Push<&'columnar usize>, C4: Push<&'columnar usize>,

source§

fn push(&mut self, item: &'columnar MessageHeader)

Pushes an item onto self.
source§

fn extend(&mut self, iter: impl IntoIterator<Item = T>)

Pushes elements of an iterator onto self.
source§

impl<C0, C1, C2, C3, C4> Push<MessageHeader> for MessageHeaderContainer<C0, C1, C2, C3, C4>
where C0: Push<usize>, C1: Push<usize>, C2: Push<usize>, C3: Push<usize>, C4: Push<usize>,

source§

fn push(&mut self, item: MessageHeader)

Pushes an item onto self.
source§

fn extend(&mut self, iter: impl IntoIterator<Item = T>)

Pushes elements of an iterator onto self.
source§

impl Serialize for MessageHeader

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Copy for MessageHeader

source§

impl Eq for MessageHeader

source§

impl StructuralPartialEq for MessageHeader

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

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CloneToUninit for T
where T: Copy,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CopyAs<T> for T

source§

fn copy_as(self) -> T

source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

§

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>,

§

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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,