Receivers

Enum Receivers 

Source
pub enum Receivers {
    Broadcast,
    Nodes(Vec<String<{ MAX_NAME_SIZE }>, { _ }>),
    None,
}
Expand description

Represents the receiver nodes for a signal in a DBC file.

A signal can have three types of receivers:

  • Broadcast (*): The signal is broadcast to all nodes on the bus
  • Specific nodes: A list of specific node names that receive this signal
  • None: No explicit receivers specified (signal may be unused or receiver is implicit)

§Examples

use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM TCM BCM

BO_ 256 Engine : 8 ECM
 SG_ RPM : 0|16@1+ (0.25,0) [0|8000] "rpm" *
 SG_ Temp : 16|8@0- (1,-40) [-40|215] "°C" TCM BCM
"#)?;

let message = dbc.messages().at(0).unwrap();

// Broadcast receiver
let rpm_signal = message.signals().find("RPM").unwrap();
assert_eq!(rpm_signal.receivers().len(), 0); // Broadcast has no specific nodes

// Specific nodes
let temp_signal = message.signals().find("Temp").unwrap();
assert_eq!(temp_signal.receivers().len(), 2);
assert!(temp_signal.receivers().contains("TCM"));

§DBC Format

In DBC files, receivers are specified after the signal definition:

  • * indicates broadcast
  • Space-separated node names indicate specific receivers
  • No receivers means None

Variants§

§

Broadcast

Broadcast receiver - signal is sent to all nodes on the bus.

§

Nodes(Vec<String<{ MAX_NAME_SIZE }>, { _ }>)

Specific receiver nodes - vector of node names.

§

None

No explicit receivers specified.

Implementations§

Source§

impl Receivers

Source

pub fn iter(&self) -> impl Iterator<Item = &str>

Returns an iterator over the receiver node names.

For Receivers::Broadcast and Receivers::None, the iterator will be empty. For Receivers::Nodes, it iterates over the specific node names.

§Examples
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM TCM BCM

BO_ 256 Engine : 8 ECM
 SG_ Temp : 0|8@1+ (1,0) [0|255] "°C" TCM BCM
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();

// Iterate over receiver nodes
let mut iter = signal.receivers().iter();
assert_eq!(iter.next().map(|s| s.to_string()), Some("TCM".to_string()));
assert_eq!(iter.next().map(|s| s.to_string()), Some("BCM".to_string()));
assert_eq!(iter.next(), None);
§Broadcast and None
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM

BO_ 256 Engine : 8 ECM
 SG_ RPM : 0|16@1+ (0.25,0) [0|8000] "rpm" *
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();

// Broadcast receivers return empty iterator
assert_eq!(signal.receivers().iter().count(), 0);

Returns an iterator over the receiver node names as borrowed references.

For Receivers::Broadcast and Receivers::None, the iterator will be empty. For Receivers::Nodes, it iterates over the specific node names.

§Examples
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM TCM BCM

BO_ 256 Engine : 8 ECM
 SG_ Temp : 0|8@1+ (1,0) [0|255] "°C" TCM BCM
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();

// Iterate over receiver nodes
let mut iter = signal.receivers().iter();
assert_eq!(iter.next(), Some("TCM"));
assert_eq!(iter.next(), Some("BCM"));
assert_eq!(iter.next(), None);
§Broadcast and None
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM

BO_ 256 Engine : 8 ECM
 SG_ RPM : 0|16@1+ (0.25,0) [0|8000] "rpm" *
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();

// Broadcast receivers return empty iterator
assert_eq!(signal.receivers().iter().count(), 0);
Source

pub fn len(&self) -> usize

Returns the number of receiver nodes.

  • For Receivers::Nodes: Returns the count of specific receiver nodes
  • For Receivers::Broadcast and Receivers::None: Returns 0
§Examples
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM TCM BCM

BO_ 256 Engine : 8 ECM
 SG_ Temp : 0|8@1+ (1,0) [0|255] "°C" TCM BCM
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();
assert_eq!(signal.receivers().len(), 2);
Source

pub fn is_empty(&self) -> bool

Returns true if there are no specific receiver nodes.

This returns true for both Receivers::Broadcast and Receivers::None, as neither has specific node names.

§Examples
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM

BO_ 256 Engine : 8 ECM
 SG_ RPM : 0|16@1+ (0.25,0) [0|8000] "rpm"
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();
assert!(signal.receivers().is_empty());
Source

pub fn contains(&self, node: &str) -> bool

Checks if a node name is in the receivers list.

For Receivers::Broadcast and Receivers::None, this always returns false. For Receivers::Nodes, it checks if the node name is in the list.

§Arguments
  • node - The node name to check
§Examples
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM TCM BCM

BO_ 256 Engine : 8 ECM
 SG_ Temp : 0|8@1+ (1,0) [0|255] "°C" TCM BCM
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();

assert!(signal.receivers().contains("TCM"));
assert!(signal.receivers().contains("BCM"));
assert!(!signal.receivers().contains("ECM"));
Source

pub fn at(&self, index: usize) -> Option<&str>

Gets a receiver node by index.

Returns None if:

  • The index is out of bounds
  • The receiver is Broadcast or None
§Arguments
  • index - The zero-based index of the receiver node
§Examples
use dbc_rs::Dbc;

let dbc = Dbc::parse(r#"VERSION "1.0"

BU_: ECM TCM BCM

BO_ 256 Engine : 8 ECM
 SG_ Temp : 0|8@1+ (1,0) [0|255] "°C" TCM BCM
"#)?;

let message = dbc.messages().at(0).unwrap();
let signal = message.signals().at(0).unwrap();

assert_eq!(signal.receivers().at(0), Some("TCM"));
assert_eq!(signal.receivers().at(1), Some("BCM"));
assert_eq!(signal.receivers().at(2), None);

Trait Implementations§

Source§

impl Clone for Receivers

Source§

fn clone(&self) -> Receivers

Returns a duplicate of the value. Read more
1.0.0§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Receivers

Source§

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

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

impl Hash for Receivers

Source§

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

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

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 PartialEq for Receivers

Source§

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

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

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 Eq for Receivers

Source§

impl StructuralPartialEq for Receivers

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

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

§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

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

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

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

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

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

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

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

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

§

type Error = Infallible

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

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

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

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.