Struct sbp::messages::system::msg_status_report::MsgStatusReport

source ·
pub struct MsgStatusReport {
    pub sender_id: Option<u16>,
    pub reporting_system: u16,
    pub sbp_version: u16,
    pub sequence: u32,
    pub uptime: u32,
    pub status: Vec<SubSystemReport>,
}
Expand description

Status report message

The status report is sent periodically to inform the host or other attached devices that the system is running. It is used to monitor system malfunctions. It contains status reports that indicate to the host the status of each subsystem and whether it is operating correctly.

Interpretation of the subsystem specific status code is product dependent, but if the generic status code is initializing, it should be ignored. Refer to product documentation for details.

Fields§

§sender_id: Option<u16>

The message sender_id

§reporting_system: u16

Identity of reporting system

§sbp_version: u16

SBP protocol version

§sequence: u32

Increments on each status report sent

§uptime: u32

Number of seconds since system start-up

§status: Vec<SubSystemReport>

Reported status of individual subsystems

Implementations§

source§

impl MsgStatusReport

source

pub fn system(&self) -> Result<System, u16>

Gets the System stored in the reporting_system bitfield.

Returns Ok if the bitrange contains a known System variant. Otherwise the value of the bitrange is returned as an Err(u16). This may be because of a malformed message, or because new variants of System were added.

source

pub fn set_system(&mut self, system: System)

Set the bitrange corresponding to the System of the reporting_system bitfield.

source

pub fn sbp_major_protocol_version_number(&self) -> u8

Gets the sbp_major_protocol_version_number stored in sbp_version.

source

pub fn set_sbp_major_protocol_version_number( &mut self, sbp_major_protocol_version_number: u8 )

Sets the sbp_major_protocol_version_number bitrange of sbp_version.

source

pub fn sbp_minor_protocol_version_number(&self) -> u8

Gets the sbp_minor_protocol_version_number stored in sbp_version.

source

pub fn set_sbp_minor_protocol_version_number( &mut self, sbp_minor_protocol_version_number: u8 )

Sets the sbp_minor_protocol_version_number bitrange of sbp_version.

Trait Implementations§

source§

impl Clone for MsgStatusReport

source§

fn clone(&self) -> MsgStatusReport

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 ConcreteMessage for MsgStatusReport

source§

const MESSAGE_TYPE: u16 = 65_534u16

The message type.
source§

const MESSAGE_NAME: &'static str = "MSG_STATUS_REPORT"

The message name.
source§

impl Debug for MsgStatusReport

source§

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

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

impl<'de> Deserialize<'de> for MsgStatusReport

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 FriendlyName for MsgStatusReport

source§

fn friendly_name() -> &'static str

source§

impl From<MsgStatusReport> for Sbp

source§

fn from(msg: MsgStatusReport) -> Self

Converts to this type from the input type.
source§

impl PartialEq for MsgStatusReport

source§

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

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

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

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

impl SbpMessage for MsgStatusReport

source§

fn message_name(&self) -> &'static str

Get the message name.
source§

fn message_type(&self) -> Option<u16>

Get the message type.
source§

fn sender_id(&self) -> Option<u16>

Get the sender_id if it is set.
source§

fn set_sender_id(&mut self, new_id: u16)

Set the sender id.
source§

fn encoded_len(&self) -> usize

Number of bytes this message will take on the wire.
source§

fn is_valid(&self) -> bool

Tells you if the message is valid or if it is not a valid message and may need to be special cased at certain points.
source§

fn into_valid_msg(self) -> Result<Self, Invalid>

source§

fn gps_time(&self) -> Option<Result<MessageTime, GpsTimeError>>

Get the GPS time associated with the message.
source§

fn friendly_name(&self) -> &'static str

Get friendly name associated with the message.
source§

impl Serialize for MsgStatusReport

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 TryFrom<Sbp> for MsgStatusReport

§

type Error = TryFromSbpError

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

fn try_from(msg: Sbp) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl StructuralPartialEq for MsgStatusReport

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> Event for T
where T: ConcreteMessage,

source§

const MESSAGE_TYPES: &'static [u16] = const MESSAGE_TYPES: &'static [u16] = &[T::MESSAGE_TYPE];

The message types that correspond to this event. An empty slice means all messages.
source§

fn from_sbp(msg: Sbp) -> T

Create an instance of this event from an SBP message. This message will only be called if the message type is in Event::MESSAGE_TYPES.
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>,