1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
use Receivers;
use String;
/// Builder for creating `Receivers` programmatically.
///
/// This builder allows you to construct receiver configurations for signals
/// when building DBC files programmatically.
///
/// Per DBC specification Section 9.5, valid receivers are:
/// - Specific node names (comma-separated in DBC output)
/// - `Vector__XXX` for no specific receiver (represented as `Receivers::None`)
///
/// # Examples
///
/// ```rust,no_run
/// use dbc_rs::{ReceiversBuilder, SignalBuilder, ByteOrder};
///
/// // Specific nodes
/// let specific = ReceiversBuilder::new()
/// .add_node("TCM")
/// .add_node("BCM")
/// .build()?;
///
/// // No receivers (serializes as Vector__XXX)
/// let none = ReceiversBuilder::new().none().build()?;
///
/// // Use with signal builder
/// let signal = SignalBuilder::new()
/// .name("RPM")
/// .start_bit(0)
/// .length(16)
/// .byte_order(ByteOrder::BigEndian)
/// .unsigned(true)
/// .factor(0.25)
/// .offset(0.0)
/// .min(0.0)
/// .max(8000.0)
/// .receivers(ReceiversBuilder::new().add_node("TCM").add_node("BCM"))
/// .build()?;
/// # Ok::<(), dbc_rs::Error>(())
/// ```
///
/// # Feature Requirements
///
/// This builder requires the `std` feature to be enabled.