From 6f417d833e2a4041f32a6578332b050d79028910 Mon Sep 17 00:00:00 2001 From: Diego Barrios Romero Date: Thu, 18 Jan 2024 22:18:37 +0100 Subject: Derive common traits for types + default for ComparatorQueue --- CHANGELOG.md | 6 +++++- src/types.rs | 39 +++++++++++++++++---------------------- 2 files changed, 22 insertions(+), 23 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9ab0670..49cd011 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,9 +7,13 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. ## [Unreleased] +### Added +- Derived common traits for types. +- Add default for `ComparatorQueue`. + ### Changed - Updated `embedded-hal` to version `1`, `read` in one-shot mode is therefore only an inherent method. -- Raised MSRV to 1.62.0 +- Raised MSRV to 1.62.0. ## [0.2.2] - 2021-07-29 diff --git a/src/types.rs b/src/types.rs index e4402fe..6937dfe 100644 --- a/src/types.rs +++ b/src/types.rs @@ -34,7 +34,7 @@ pub mod mode { } /// Data rate for ADS1013, ADS1014, ADS1015 -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum DataRate12Bit { /// 128 SPS Sps128, @@ -44,6 +44,7 @@ pub enum DataRate12Bit { Sps490, /// 920 SPS Sps920, + #[default] /// 1600 SPS (default) Sps1600, /// 2400 SPS @@ -53,7 +54,7 @@ pub enum DataRate12Bit { } /// Data rate for ADS1113, ADS1114, ADS1115 -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum DataRate16Bit { /// 8 SPS Sps8, @@ -63,6 +64,7 @@ pub enum DataRate16Bit { Sps32, /// 64 SPS Sps64, + #[default] /// 128 SPS (default) Sps128, /// 250 SPS @@ -74,8 +76,9 @@ pub enum DataRate16Bit { } /// Comparator mode (only for ADS1x14, ADS1x15) -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum ComparatorMode { + #[default] /// Traditional comparator (default) /// /// In this mode the ALERT/RDY pin asserts (according to selected active @@ -92,8 +95,9 @@ pub enum ComparatorMode { } /// Comparator polarity (only for ADS1x14, ADS1x15) -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum ComparatorPolarity { + #[default] /// Active low (default) ActiveLow, /// Active high @@ -105,8 +109,9 @@ pub enum ComparatorPolarity { /// Select whether the ALERT/RDY pin latches after being asserted or clears /// after conversions are within the margin of the upper and lower /// threshold values. -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum ComparatorLatching { + #[default] /// Nonlatching (default) /// /// The ALERT/RDY pin does not latch when asserted. @@ -124,13 +129,14 @@ pub enum ComparatorLatching { /// /// The default state of the comparator is deactivated. It can be activated by setting /// the comparator queue. -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum ComparatorQueue { /// Activate comparator and assert after one conversion exceeding thresholds One, /// Activate comparator and assert after two consecutive conversions exceeding thresholds Two, - /// Activate comparator and assert after four consecutive conversions exceeding thresholds + #[default] + /// Activate comparator and assert after four consecutive conversions exceeding thresholds (default) Four, } @@ -138,13 +144,14 @@ pub enum ComparatorQueue { /// /// This sets the input voltage measurable range. /// The FSR is fixed at ±2.048 V in the ADS1x13. -#[derive(Clone, Copy, Debug, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] #[allow(non_camel_case_types)] pub enum FullScaleRange { /// The measurable range is ±6.144V. Within6_144V, /// The measurable range is ±4.096V. Within4_096V, + #[default] /// The measurable range is ±2.048V. (default) Within2_048V, /// The measurable range is ±1.024V. @@ -156,8 +163,9 @@ pub enum FullScaleRange { } /// Possible slave addresses -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Default, Clone, Copy, PartialEq, Eq, Ord, PartialOrd, Hash)] pub enum SlaveAddr { + #[default] /// Default slave address Default, /// Alternative slave address using the provided values @@ -165,13 +173,6 @@ pub enum SlaveAddr { Alternative(bool, bool), } -impl Default for SlaveAddr { - /// Default slave address - fn default() -> Self { - SlaveAddr::Default - } -} - impl SlaveAddr { pub(crate) fn addr(self, default: u8) -> u8 { match self { @@ -242,12 +243,6 @@ impl Default for Config { } } -impl Default for FullScaleRange { - fn default() -> Self { - FullScaleRange::Within2_048V - } -} - /// ADS1x1x ADC driver #[derive(Debug, Default)] pub struct Ads1x1x { -- cgit v1.2.3-54-g00ecf