From 28b16cc364cc4f4112aca2195df389ea6f007048 Mon Sep 17 00:00:00 2001 From: Diego Barrios Romero Date: Wed, 7 Nov 2018 20:19:06 +0100 Subject: Convert between modes through transformation of the struct --- src/devices/construction/i2c.rs | 41 +++++++++++++++++++++++++++++++++++++++++ src/devices/construction/mod.rs | 3 +++ 2 files changed, 44 insertions(+) create mode 100644 src/devices/construction/i2c.rs create mode 100644 src/devices/construction/mod.rs (limited to 'src/devices/construction') diff --git a/src/devices/construction/i2c.rs b/src/devices/construction/i2c.rs new file mode 100644 index 0000000..900a5fe --- /dev/null +++ b/src/devices/construction/i2c.rs @@ -0,0 +1,41 @@ +//! Functions exclusive of ADS1013 + +extern crate embedded_hal as hal; +use hal::blocking; +use core::marker::PhantomData; +use { Ads1x1x, DEVICE_BASE_ADDRESS, SlaveAddr, ic, Config, mode }; +use interface::I2cInterface; + + +macro_rules! impl_new_destroy { + ( $IC:ident, $create:ident, $destroy:ident ) => { + impl Ads1x1x, ic::$IC, mode::OneShot> + where + 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) + }, + config: Config::default(), + a_conversion_was_started: false, + _ic: PhantomData, + _mode: PhantomData + } + } + } + impl Ads1x1x, ic::$IC, 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); +impl_new_destroy!(Ads1113, new_ads1113, destroy_ads1113); \ No newline at end of file diff --git a/src/devices/construction/mod.rs b/src/devices/construction/mod.rs new file mode 100644 index 0000000..0873d88 --- /dev/null +++ b/src/devices/construction/mod.rs @@ -0,0 +1,3 @@ +//! Construction / destruction functions + +mod i2c; -- cgit v1.2.3-54-g00ecf