From 5485d9655e2ab3a6d04e5f69b246f5db4d2c5936 Mon Sep 17 00:00:00 2001 From: Diego Barrios Romero Date: Wed, 21 Nov 2018 09:35:37 +0100 Subject: Code formatting --- src/channels.rs | 4 ++-- src/construction.rs | 16 +++++++--------- src/conversion.rs | 11 +++++------ src/devices/common.rs | 4 ++-- src/devices/features/tier1.rs | 34 ++++++++++++++++++---------------- src/devices/features/tier2.rs | 42 ++++++++++++++++++++++++------------------ src/devices/mod.rs | 2 +- src/devices/mode/continuous.rs | 11 ++++++----- src/devices/mode/oneshot.rs | 15 ++++++++------- src/ic.rs | 9 ++++----- src/interface.rs | 17 +++++++---------- src/lib.rs | 33 ++++++++++++++++++--------------- 12 files changed, 102 insertions(+), 96 deletions(-) (limited to 'src') diff --git a/src/channels.rs b/src/channels.rs index f88e10e..d5ae7bc 100644 --- a/src/channels.rs +++ b/src/channels.rs @@ -1,5 +1,5 @@ //! ADC input channels -use { Ads1x1x, ic, hal, Config, BitFlags as BF }; +use {hal, ic, Ads1x1x, BitFlags as BF, Config}; /// ADC input channel selection #[allow(dead_code)] @@ -43,7 +43,7 @@ macro_rules! impl_channel { ChannelSelection::$CH } } - } + }; } impl_channel!(Ads1013, DifferentialA0A1); diff --git a/src/construction.rs b/src/construction.rs index ab100fd..61abb06 100644 --- a/src/construction.rs +++ b/src/construction.rs @@ -1,42 +1,40 @@ //! Constructor/destructor functions. extern crate embedded_hal as hal; -use hal::blocking; use core::marker::PhantomData; -use { Ads1x1x, DEVICE_BASE_ADDRESS, SlaveAddr, ic, Config, mode, FullScaleRange }; +use hal::blocking; use interface::I2cInterface; - +use {ic, mode, Ads1x1x, Config, FullScaleRange, SlaveAddr, DEVICE_BASE_ADDRESS}; macro_rules! impl_new_destroy { ( $IC:ident, $create:ident, $destroy:ident, $conv:ty ) => { impl Ads1x1x, ic::$IC, $conv, mode::OneShot> where - I2C: blocking::i2c::Write + blocking::i2c::WriteRead + I2C: blocking::i2c::Write + blocking::i2c::WriteRead, { /// Create a new instance of the device in OneShot mode. pub fn $create(i2c: I2C, address: SlaveAddr) -> Self { Ads1x1x { iface: I2cInterface { i2c, - address: address.addr(DEVICE_BASE_ADDRESS) + address: address.addr(DEVICE_BASE_ADDRESS), }, config: Config::default(), fsr: FullScaleRange::default(), a_conversion_was_started: false, _conv: PhantomData, _ic: PhantomData, - _mode: PhantomData + _mode: PhantomData, } } } - impl Ads1x1x, ic::$IC, CONV, MODE> - { + impl Ads1x1x, ic::$IC, CONV, MODE> { /// Destroy driver instance, return I²C bus instance. pub fn $destroy(self) -> I2C { self.iface.i2c } } - } + }; } impl_new_destroy!(Ads1013, new_ads1013, destroy_ads1013, ic::Resolution12Bit); diff --git a/src/conversion.rs b/src/conversion.rs index 5e7751c..644ed4a 100644 --- a/src/conversion.rs +++ b/src/conversion.rs @@ -1,7 +1,7 @@ -use { ic, private, Error }; +use {ic, private, Error}; #[doc(hidden)] -pub trait ConvertThreshold : private::Sealed { +pub trait ConvertThreshold: private::Sealed { fn convert_threshold(value: i16) -> Result>; } @@ -21,7 +21,7 @@ impl ConvertThreshold for ic::Resolution16Bit { } #[doc(hidden)] -pub trait ConvertMeasurement : private::Sealed { +pub trait ConvertMeasurement: private::Sealed { fn convert_measurement(register_data: u16) -> i16; } @@ -32,8 +32,7 @@ impl ConvertMeasurement for ic::Resolution12Bit { if is_negative { let value = 0b1111_0000_0000_0000 | (value >> 4); value as i16 - } - else { + } else { (value >> 4) as i16 } } @@ -69,7 +68,7 @@ mod tests { fn assert_invalid_input_data(result: Result>) { match result { Err(Error::InvalidInputData) => (), - _ => panic!("InvalidInputData error was not returned.") + _ => panic!("InvalidInputData error was not returned."), } } diff --git a/src/devices/common.rs b/src/devices/common.rs index 92b4f9e..57d67b9 100644 --- a/src/devices/common.rs +++ b/src/devices/common.rs @@ -1,7 +1,7 @@ //! Common functions -use { Ads1x1x, Error, Register, BitFlags, interface, Config }; use super::OperatingMode; +use {interface, Ads1x1x, BitFlags, Config, Error, Register}; impl Ads1x1x where @@ -21,7 +21,7 @@ where /// Read whether a measurement is currently in progress. pub fn is_measurement_in_progress(&mut self) -> Result> { let config = Config { - bits: self.iface.read_register(Register::CONFIG)? + bits: self.iface.read_register(Register::CONFIG)?, }; Ok(!config.is_high(BitFlags::OS)) } diff --git a/src/devices/features/tier1.rs b/src/devices/features/tier1.rs index 16ed96c..6bd1a99 100644 --- a/src/devices/features/tier1.rs +++ b/src/devices/features/tier1.rs @@ -1,6 +1,6 @@ //! Common functions -use { Ads1x1x, DataRate12Bit, DataRate16Bit, Error, Register, BitFlags, interface, ic }; +use {ic, interface, Ads1x1x, BitFlags as BF, DataRate12Bit, DataRate16Bit, Error, Register}; impl Ads1x1x where @@ -8,15 +8,16 @@ where { /// Set data rate pub fn set_data_rate(&mut self, rate: DataRate12Bit) -> Result<(), Error> { + use DataRate12Bit as DR; let config; match rate { - DataRate12Bit::Sps128 => config = self.config.with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0), - DataRate12Bit::Sps250 => config = self.config.with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0), - DataRate12Bit::Sps490 => config = self.config.with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0), - DataRate12Bit::Sps920 => config = self.config.with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_high(BitFlags::DR0), - DataRate12Bit::Sps1600 => config = self.config.with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0), - DataRate12Bit::Sps2400 => config = self.config.with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0), - DataRate12Bit::Sps3300 => config = self.config.with_high(BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0), + DR::Sps128 => config = self.config.with_low( BF::DR2).with_low( BF::DR1).with_low( BF::DR0), + DR::Sps250 => config = self.config.with_low( BF::DR2).with_low( BF::DR1).with_high(BF::DR0), + DR::Sps490 => config = self.config.with_low( BF::DR2).with_high(BF::DR1).with_low( BF::DR0), + DR::Sps920 => config = self.config.with_low( BF::DR2).with_high(BF::DR1).with_high(BF::DR0), + DR::Sps1600 => config = self.config.with_high(BF::DR2).with_low( BF::DR1).with_low( BF::DR0), + DR::Sps2400 => config = self.config.with_high(BF::DR2).with_low( BF::DR1).with_high(BF::DR0), + DR::Sps3300 => config = self.config.with_high(BF::DR2).with_high(BF::DR1).with_low( BF::DR0), } self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; @@ -30,16 +31,17 @@ where { /// Set data rate pub fn set_data_rate(&mut self, rate: DataRate16Bit) -> Result<(), Error> { + use DataRate16Bit as DR; let config; match rate { - DataRate16Bit::Sps8 => config = self.config.with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0), - DataRate16Bit::Sps16 => config = self.config.with_low( BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0), - DataRate16Bit::Sps32 => config = self.config.with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0), - DataRate16Bit::Sps64 => config = self.config.with_low( BitFlags::DR2).with_high(BitFlags::DR1).with_high(BitFlags::DR0), - DataRate16Bit::Sps128 => config = self.config.with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_low( BitFlags::DR0), - DataRate16Bit::Sps250 => config = self.config.with_high(BitFlags::DR2).with_low( BitFlags::DR1).with_high(BitFlags::DR0), - DataRate16Bit::Sps475 => config = self.config.with_high(BitFlags::DR2).with_high(BitFlags::DR1).with_low( BitFlags::DR0), - DataRate16Bit::Sps860 => config = self.config.with_high(BitFlags::DR2).with_high(BitFlags::DR1).with_high(BitFlags::DR0), + DR::Sps8 => config = self.config.with_low( BF::DR2).with_low( BF::DR1).with_low( BF::DR0), + DR::Sps16 => config = self.config.with_low( BF::DR2).with_low( BF::DR1).with_high(BF::DR0), + DR::Sps32 => config = self.config.with_low( BF::DR2).with_high(BF::DR1).with_low( BF::DR0), + DR::Sps64 => config = self.config.with_low( BF::DR2).with_high(BF::DR1).with_high(BF::DR0), + DR::Sps128 => config = self.config.with_high(BF::DR2).with_low( BF::DR1).with_low( BF::DR0), + DR::Sps250 => config = self.config.with_high(BF::DR2).with_low( BF::DR1).with_high(BF::DR0), + DR::Sps475 => config = self.config.with_high(BF::DR2).with_high(BF::DR1).with_low( BF::DR0), + DR::Sps860 => config = self.config.with_high(BF::DR2).with_high(BF::DR1).with_high(BF::DR0), } self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; diff --git a/src/devices/features/tier2.rs b/src/devices/features/tier2.rs index 6047572..3f8d7b4 100644 --- a/src/devices/features/tier2.rs +++ b/src/devices/features/tier2.rs @@ -2,21 +2,21 @@ //! //! These are the features included only in ADS1x14, ADS1x15 -use { Ads1x1x, Error, interface, ic, FullScaleRange, ComparatorMode, - ComparatorPolarity, ComparatorLatching, ComparatorQueue, Register, - BitFlags, conversion }; +use { + conversion, ic, interface, Ads1x1x, BitFlags as BF, ComparatorLatching, ComparatorMode, + ComparatorPolarity, ComparatorQueue, Error, FullScaleRange, Register, +}; impl Ads1x1x where DI: interface::WriteData, IC: ic::Tier2Features, - CONV: conversion::ConvertThreshold + CONV: conversion::ConvertThreshold, { /// Set the input voltage measurable range /// /// This configures the programmable gain amplifier and determines the measurable input voltage range. pub fn set_full_scale_range(&mut self, range: FullScaleRange) -> Result<(), Error> { - use BitFlags as BF; let config; match range { FullScaleRange::Within6_144V => config = self.config.with_low( BF::PGA2).with_low( BF::PGA1).with_low( BF::PGA0), @@ -57,8 +57,8 @@ where pub fn set_comparator_mode(&mut self, mode: ComparatorMode) -> Result<(), Error> { let config; match mode { - ComparatorMode::Traditional => config = self.config.with_low(BitFlags::COMP_MODE), - ComparatorMode::Window => config = self.config.with_high(BitFlags::COMP_MODE) + ComparatorMode::Traditional => config = self.config.with_low( BF::COMP_MODE), + ComparatorMode::Window => config = self.config.with_high(BF::COMP_MODE), } self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; @@ -66,11 +66,14 @@ where } /// Set comparator polarity - pub fn set_comparator_polarity(&mut self, polarity: ComparatorPolarity) -> Result<(), Error> { + pub fn set_comparator_polarity( + &mut self, + polarity: ComparatorPolarity, + ) -> Result<(), Error> { let config; match polarity { - ComparatorPolarity::ActiveLow => config = self.config.with_low( BitFlags::COMP_POL), - ComparatorPolarity::ActiveHigh => config = self.config.with_high(BitFlags::COMP_POL) + ComparatorPolarity::ActiveLow => config = self.config.with_low( BF::COMP_POL), + ComparatorPolarity::ActiveHigh => config = self.config.with_high(BF::COMP_POL), } self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; @@ -78,11 +81,14 @@ where } /// Set comparator latching - pub fn set_comparator_latching(&mut self, latching: ComparatorLatching) -> Result<(), Error> { + pub fn set_comparator_latching( + &mut self, + latching: ComparatorLatching, + ) -> Result<(), Error> { let config; match latching { - ComparatorLatching::Nonlatching => config = self.config.with_low( BitFlags::COMP_LAT), - ComparatorLatching::Latching => config = self.config.with_high(BitFlags::COMP_LAT) + ComparatorLatching::Nonlatching => config = self.config.with_low( BF::COMP_LAT), + ComparatorLatching::Latching => config = self.config.with_high(BF::COMP_LAT), } self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; @@ -95,9 +101,9 @@ where pub fn set_comparator_queue(&mut self, queue: ComparatorQueue) -> Result<(), Error> { let config; match queue { - ComparatorQueue::One => config = self.config.with_low( BitFlags::COMP_QUE1).with_low( BitFlags::COMP_QUE0), - ComparatorQueue::Two => config = self.config.with_low( BitFlags::COMP_QUE1).with_high(BitFlags::COMP_QUE0), - ComparatorQueue::Four => config = self.config.with_high(BitFlags::COMP_QUE1).with_low( BitFlags::COMP_QUE0) + ComparatorQueue::One => config = self.config.with_low( BF::COMP_QUE1).with_low( BF::COMP_QUE0), + ComparatorQueue::Two => config = self.config.with_low( BF::COMP_QUE1).with_high(BF::COMP_QUE0), + ComparatorQueue::Four => config = self.config.with_high(BF::COMP_QUE1).with_low( BF::COMP_QUE0), } self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; @@ -110,7 +116,7 @@ where /// The comparator can be enabled by setting the comparator queue. /// See [`set_comparator_queue()`](struct.Ads1x1x.html#method.set_comparator_queue) pub fn disable_comparator(&mut self) -> Result<(), Error> { - let config = self.config.with_high(BitFlags::COMP_QUE1).with_high(BitFlags::COMP_QUE0); + let config = self.config.with_high(BF::COMP_QUE1).with_high(BF::COMP_QUE0); self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; Ok(()) @@ -124,7 +130,7 @@ where /// /// When calling this the comparator will be disabled and the thresholds will be cleared. pub fn use_alert_rdy_pin_as_ready(&mut self) -> Result<(), Error> { - if self.config != self.config.with_high(BitFlags::COMP_QUE1).with_high(BitFlags::COMP_QUE0) { + if self.config != self.config.with_high(BF::COMP_QUE1).with_high(BF::COMP_QUE0) { self.disable_comparator()?; } self.iface.write_register(Register::HIGH_TH, 0x8000)?; diff --git a/src/devices/mod.rs b/src/devices/mod.rs index e5124e1..5b87738 100644 --- a/src/devices/mod.rs +++ b/src/devices/mod.rs @@ -1,7 +1,7 @@ #[derive(Debug, Clone, Copy)] enum OperatingMode { OneShot, - Continuous + Continuous, } mod mode; diff --git a/src/devices/mode/continuous.rs b/src/devices/mode/continuous.rs index 35cfd7b..cb4757c 100644 --- a/src/devices/mode/continuous.rs +++ b/src/devices/mode/continuous.rs @@ -1,9 +1,9 @@ //! Continuous measurement mode -use core::marker::PhantomData; -use { Ads1x1x, conversion, Error, hal, interface, mode, Register }; -use channels::ChannelSelection; use super::super::OperatingMode; +use channels::ChannelSelection; +use core::marker::PhantomData; +use {conversion, hal, interface, mode, Ads1x1x, Error, Register}; impl Ads1x1x where @@ -20,7 +20,7 @@ where a_conversion_was_started: false, _conv: PhantomData, _ic: PhantomData, - _mode: PhantomData + _mode: PhantomData, }) } @@ -58,7 +58,8 @@ where /// Select the channel for measurements. pub fn select_channel(&mut self, _channel: &mut CH) -> Result<(), Error> where - CH: hal::adc::Channel, ID = ChannelSelection> { + CH: hal::adc::Channel, ID = ChannelSelection>, + { let config = self.config.with_mux_bits(CH::channel()); self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; diff --git a/src/devices/mode/oneshot.rs b/src/devices/mode/oneshot.rs index a03d8d2..3595c26 100644 --- a/src/devices/mode/oneshot.rs +++ b/src/devices/mode/oneshot.rs @@ -1,14 +1,14 @@ //! Common functions -use core::marker::PhantomData; -use { Ads1x1x, mode, Error, Register, BitFlags, Config }; -use { interface, conversion, hal, nb }; use channels::ChannelSelection; +use core::marker::PhantomData; +use {conversion, hal, interface, nb}; +use {mode, Ads1x1x, BitFlags, Config, Error, Register}; impl Ads1x1x where DI: interface::WriteData + interface::ReadData, - CONV: conversion::ConvertMeasurement + CONV: conversion::ConvertMeasurement, { /// Change operating mode to Continuous pub fn into_continuous(self) -> Result, Error> { @@ -19,7 +19,7 @@ where a_conversion_was_started: self.a_conversion_was_started, _conv: PhantomData, _ic: PhantomData, - _mode: PhantomData + _mode: PhantomData, }) } @@ -34,7 +34,7 @@ impl hal::adc::OneShot where DI: interface::ReadData + interface::WriteData, CONV: conversion::ConvertMeasurement, - CH: hal::adc::Channel, ID = ChannelSelection> + CH: hal::adc::Channel, ID = ChannelSelection>, { type Error = Error; @@ -63,7 +63,8 @@ where return Ok(CONV::convert_measurement(value)); } let config = self.config.with_mux_bits(CH::channel()); - self.trigger_measurement(&config).map_err(nb::Error::Other)?; + self.trigger_measurement(&config) + .map_err(nb::Error::Other)?; self.config = config; self.a_conversion_was_started = true; Err(nb::Error::WouldBlock) diff --git a/src/ic.rs b/src/ic.rs index a09cb72..4ed42d9 100644 --- a/src/ic.rs +++ b/src/ic.rs @@ -1,9 +1,8 @@ /// ICs use private; -pub struct Resolution12Bit(pub(crate)()); -pub struct Resolution16Bit(pub(crate)()); - +pub struct Resolution12Bit(pub(crate) ()); +pub struct Resolution16Bit(pub(crate) ()); macro_rules! ic_marker { ($name:ident) => { @@ -19,12 +18,12 @@ ic_marker!(Ads1114); ic_marker!(Ads1015); ic_marker!(Ads1115); -pub trait Tier2Features : private::Sealed { } +pub trait Tier2Features: private::Sealed {} macro_rules! tier2_features { ($name:ident) => { impl Tier2Features for $name {} - } + }; } tier2_features!(Ads1014); diff --git a/src/interface.rs b/src/interface.rs index 2ef42fc..36458b4 100644 --- a/src/interface.rs +++ b/src/interface.rs @@ -2,18 +2,17 @@ extern crate embedded_hal as hal; use hal::blocking; -use { private, Error }; - +use {private, Error}; /// I2C interface #[derive(Debug, Default)] pub struct I2cInterface { pub(crate) i2c: I2C, - pub(crate) address : u8, + pub(crate) address: u8, } /// Write data -pub trait WriteData : private::Sealed { +pub trait WriteData: private::Sealed { /// Error type type Error; /// Write to an u16 register @@ -22,19 +21,17 @@ pub trait WriteData : private::Sealed { impl WriteData for I2cInterface where - I2C: blocking::i2c::Write + I2C: blocking::i2c::Write, { type Error = E; fn write_register(&mut self, register: u8, data: u16) -> Result<(), Error> { let payload: [u8; 3] = [register, (data >> 8) as u8, data as u8]; - self.i2c - .write(self.address, &payload) - .map_err(Error::I2C) + self.i2c.write(self.address, &payload).map_err(Error::I2C) } } /// Read data -pub trait ReadData : private::Sealed { +pub trait ReadData: private::Sealed { /// Error type type Error; /// Read an u16 register @@ -43,7 +40,7 @@ pub trait ReadData : private::Sealed { impl ReadData for I2cInterface where - I2C: blocking::i2c::WriteRead + I2C: blocking::i2c::WriteRead, { type Error = E; fn read_register(&mut self, register: u8) -> Result> { diff --git a/src/lib.rs b/src/lib.rs index 7e829be..0faa50b 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -204,8 +204,8 @@ #![deny(warnings)] #![no_std] -extern crate nb; extern crate embedded_hal as hal; +extern crate nb; use core::marker::PhantomData; /// All possible errors in this crate @@ -219,7 +219,7 @@ pub enum Error { NotStarted, } -const DEVICE_BASE_ADDRESS : u8 = 0b100_1000; +const DEVICE_BASE_ADDRESS: u8 = 0b100_1000; /// Mode marker types pub mod mode { @@ -246,10 +246,9 @@ pub enum DataRate12Bit { /// 2400 SPS Sps2400, /// 3300 SPS - Sps3300 + Sps3300, } - /// Data rate for ADS1113, ADS1114, ADS1115 #[derive(Debug, Clone, Copy, PartialEq)] pub enum DataRate16Bit { @@ -268,7 +267,7 @@ pub enum DataRate16Bit { /// 475 SPS Sps475, /// 860 SPS - Sps860 + Sps860, } /// Comparator mode (only for ADS1x14, ADS1x15) #[derive(Debug, Clone, Copy, PartialEq)] @@ -285,7 +284,7 @@ pub enum ComparatorMode { /// In this mode the ALERT/RDY pin asserts (according to selected active /// polarity) when the conversion data exceeds the value set as *high* /// threshold or goes below the value set as *low* temperature threshold. - Window + Window, } /// Comparator polarity (only for ADS1x14, ADS1x15) @@ -294,7 +293,7 @@ pub enum ComparatorPolarity { /// Active low (default) ActiveLow, /// Active high - ActiveHigh + ActiveHigh, } /// Comparator polarity (only for ADS1x14, ADS1x15) @@ -314,7 +313,7 @@ pub enum ComparatorLatching { /// read by the master or an appropriate SMBus alert response is sent by /// the master. The device responds with its address, and it is the lowest /// address currently asserting the ALERT/RDY bus line. - Latching + Latching, } /// Comparator alert queue (only for ADS1x14, ADS1x15) @@ -358,7 +357,7 @@ pub enum SlaveAddr { /// Default slave address Default, /// Alternative slave address providing bit values for A1 and A0 - Alternative(bool, bool) + Alternative(bool, bool), } impl Default for SlaveAddr { @@ -411,19 +410,23 @@ impl BitFlags { #[derive(Debug, Clone, PartialEq)] struct Config { - bits: u16 + bits: u16, } impl Config { - fn is_high(&self, mask : u16) -> bool { + fn is_high(&self, mask: u16) -> bool { (self.bits & mask) != 0 } fn with_high(&self, mask: u16) -> Self { - Config { bits: self.bits | mask } + Config { + bits: self.bits | mask, + } } fn with_low(&self, mask: u16) -> Self { - Config { bits: self.bits & !mask } + Config { + bits: self.bits & !mask, + } } } @@ -448,7 +451,7 @@ pub struct Ads1x1x { a_conversion_was_started: bool, _conv: PhantomData, _ic: PhantomData, - _mode: PhantomData + _mode: PhantomData, } #[doc(hidden)] @@ -464,7 +467,7 @@ pub use conversion::ConvertThreshold; pub use conversion::ConvertMeasurement; mod private { - use super::{ ic, interface }; + use super::{ic, interface}; pub trait Sealed {} impl Sealed for interface::I2cInterface {} -- cgit v1.2.3-54-g00ecf