ModbusValue

Enum ModbusValue 

Source
pub enum ModbusValue {
    Bool(bool),
    U16(u16),
    I16(i16),
    U32(u32),
    I32(i32),
    F32(f32),
    U64(u64),
    I64(i64),
    F64(f64),
}
Expand description

Industrial data type enumeration for Modbus register values.

This enum represents all numeric types commonly used in industrial automation and SCADA systems. It is designed to be self-contained (no external dependencies) for use with ModbusCodec.

§Register Mapping

TypeRegistersDescription
Bool1 (coil)Single bit value
U16/I161Single 16-bit register
U32/I32/F322Two consecutive registers
U64/I64/F644Four consecutive registers

§Example

use voltage_modbus::ModbusValue;

let temp = ModbusValue::F32(25.5);
assert_eq!(temp.register_count(), 2);
assert!((temp.as_f64() - 25.5).abs() < 0.001);

Variants§

§

Bool(bool)

Boolean value (typically from coils)

§

U16(u16)

Unsigned 16-bit integer (1 register)

§

I16(i16)

Signed 16-bit integer (1 register)

§

U32(u32)

Unsigned 32-bit integer (2 registers)

§

I32(i32)

Signed 32-bit integer (2 registers)

§

F32(f32)

32-bit floating point (2 registers)

§

U64(u64)

Unsigned 64-bit integer (4 registers)

§

I64(i64)

Signed 64-bit integer (4 registers)

§

F64(f64)

64-bit floating point (4 registers)

Implementations§

Source§

impl ModbusValue

Source

pub fn as_f64(&self) -> f64

Convert the value to f64 for uniform numeric handling.

This is useful for calculations, comparisons, and storing values in a normalized format.

Source

pub fn as_i64(&self) -> i64

Convert the value to i64 for integer operations.

Float values are rounded to the nearest integer.

Source

pub fn register_count(&self) -> usize

Returns the number of 16-bit Modbus registers required for this value.

§Returns
  • 0 for Bool (coils use separate addressing)
  • 1 for U16/I16
  • 2 for U32/I32/F32
  • 4 for U64/I64/F64
Source

pub fn is_zero(&self) -> bool

Check if the value is zero or false.

Source

pub fn type_name(&self) -> &'static str

Returns the type name as a string for logging/debugging.

Trait Implementations§

Source§

impl Clone for ModbusValue

Source§

fn clone(&self) -> ModbusValue

Returns a duplicate 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 Debug for ModbusValue

Source§

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

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

impl Default for ModbusValue

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Display for ModbusValue

Source§

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

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

impl From<bool> for ModbusValue

Source§

fn from(v: bool) -> Self

Converts to this type from the input type.
Source§

impl From<f32> for ModbusValue

Source§

fn from(v: f32) -> Self

Converts to this type from the input type.
Source§

impl From<f64> for ModbusValue

Source§

fn from(v: f64) -> Self

Converts to this type from the input type.
Source§

impl From<i16> for ModbusValue

Source§

fn from(v: i16) -> Self

Converts to this type from the input type.
Source§

impl From<i32> for ModbusValue

Source§

fn from(v: i32) -> Self

Converts to this type from the input type.
Source§

impl From<i64> for ModbusValue

Source§

fn from(v: i64) -> Self

Converts to this type from the input type.
Source§

impl From<u16> for ModbusValue

Source§

fn from(v: u16) -> Self

Converts to this type from the input type.
Source§

impl From<u32> for ModbusValue

Source§

fn from(v: u32) -> Self

Converts to this type from the input type.
Source§

impl From<u64> for ModbusValue

Source§

fn from(v: u64) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for ModbusValue

Source§

fn eq(&self, other: &ModbusValue) -> 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 StructuralPartialEq for ModbusValue

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§

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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,

Source§

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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

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

Source§

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

Source§

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> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more