pub struct UAVCAN_NODE_INFO_DATA {
pub time_usec: u64,
pub uptime_sec: u32,
pub sw_vcs_commit: u32,
pub name: CharArray<80>,
pub hw_version_major: u8,
pub hw_version_minor: u8,
pub hw_unique_id: [u8; 16],
pub sw_version_major: u8,
pub sw_version_minor: u8,
}dialect-ualberta only.Expand description
General information describing a particular UAVCAN node. Please refer to the definition of the UAVCAN service “uavcan.protocol.GetNodeInfo” for the background information. This message should be emitted by the system whenever a new node appears online, or an existing node reboots. Additionally, it can be emitted upon request from the other end of the MAVLink channel (see MAV_CMD_UAVCAN_GET_NODE_INFO). It is also not prohibited to emit this message unconditionally at a low frequency. The UAVCAN specification is available at http://uavcan.org.
ID: 311
Fields§
§time_usec: u64Timestamp (UNIX Epoch time or time since system boot). The receiving end can infer timestamp format (since 1.1.1970 or since system boot) by checking for the magnitude of the number.
uptime_sec: u32Time since the start-up of the node.
sw_vcs_commit: u32Version control system (VCS) revision identifier (e.g. git short commit hash). 0 if unknown.
name: CharArray<80>Node name string. For example, “sapog.px4.io”.
hw_version_major: u8Hardware major version number.
hw_version_minor: u8Hardware minor version number.
hw_unique_id: [u8; 16]Hardware unique 128-bit ID.
sw_version_major: u8Software major version number.
sw_version_minor: u8Software minor version number.
Implementations§
Trait Implementations§
Source§impl<'arbitrary> Arbitrary<'arbitrary> for UAVCAN_NODE_INFO_DATA
impl<'arbitrary> Arbitrary<'arbitrary> for UAVCAN_NODE_INFO_DATA
Source§fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>
fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>
Self from the given unstructured data. Read moreSource§fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>
fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>
Self from the entirety of the given
unstructured data. Read moreSource§impl Clone for UAVCAN_NODE_INFO_DATA
impl Clone for UAVCAN_NODE_INFO_DATA
Source§fn clone(&self) -> UAVCAN_NODE_INFO_DATA
fn clone(&self) -> UAVCAN_NODE_INFO_DATA
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for UAVCAN_NODE_INFO_DATA
impl Debug for UAVCAN_NODE_INFO_DATA
Source§impl Default for UAVCAN_NODE_INFO_DATA
impl Default for UAVCAN_NODE_INFO_DATA
Source§impl<'de> Deserialize<'de> for UAVCAN_NODE_INFO_DATA
impl<'de> Deserialize<'de> for UAVCAN_NODE_INFO_DATA
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>,
Source§impl MessageData for UAVCAN_NODE_INFO_DATA
impl MessageData for UAVCAN_NODE_INFO_DATA
Source§impl PartialEq for UAVCAN_NODE_INFO_DATA
impl PartialEq for UAVCAN_NODE_INFO_DATA
Source§impl Serialize for UAVCAN_NODE_INFO_DATA
impl Serialize for UAVCAN_NODE_INFO_DATA
Source§impl TS for UAVCAN_NODE_INFO_DATA
impl TS for UAVCAN_NODE_INFO_DATA
Source§type WithoutGenerics = UAVCAN_NODE_INFO_DATA
type WithoutGenerics = UAVCAN_NODE_INFO_DATA
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = UAVCAN_NODE_INFO_DATA
type OptionInnerType = UAVCAN_NODE_INFO_DATA
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete() -> String
fn decl_concrete() -> String
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
TS::export_all]. Read more§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
To export only this type, without its dependencies, use [
TS::export]. Read more§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
To export only this type, without its dependencies, use [
TS::export]. Read more§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
§fn default_output_path() -> Option<PathBuf>
fn default_output_path() -> Option<PathBuf>
T should be exported. Read more