use core::fmt::Debug;
pub struct Reverse<T> {
inner: T,
}
pub trait ReverseCompat<T> {
fn reverse(self) -> Reverse<T>;
}
impl <T> ReverseCompat<T> for T {
fn reverse(self) -> Reverse<T> {
Reverse::new(self)
}
}
impl <T> Reverse<T> {
pub fn new(inner: T) -> Reverse<T> {
Reverse{ inner }
}
pub fn inner(&self) -> &T {
&self.inner
}
pub fn inner_mut(&mut self) -> &mut T {
&mut self.inner
}
pub fn unwrap(self) -> T {
self.inner
}
}
mod digital {
use super::{Reverse, Debug};
impl <T, E> eh0_2::digital::v2::InputPin for Reverse<T>
where
T: eh1_0::digital::InputPin<Error=E>,
E: Debug,
{
type Error = E;
fn is_high(&self) -> Result<bool, Self::Error> {
self.inner.try_is_high()
}
fn is_low(&self) -> Result<bool, Self::Error> {
self.inner.try_is_low()
}
}
impl<T, E> eh0_2::digital::v2::OutputPin for Reverse<T>
where
T: eh1_0::digital::OutputPin<Error = E>,
E: Debug,
{
type Error = E;
fn set_high(&mut self) -> Result<(), Self::Error> {
self.inner.try_set_high()
}
fn set_low(&mut self) -> Result<(), Self::Error> {
self.inner.try_set_low()
}
}
}
mod delay {
use super::{Reverse, Debug};
impl <T, E> eh0_2::blocking::delay::DelayMs<u32> for Reverse<T>
where
T: eh1_0::blocking::delay::DelayMs<u32, Error=E>,
E: Debug,
{
fn delay_ms(&mut self, ms: u32) {
self.inner.try_delay_ms(ms).unwrap();
}
}
impl <T, E> eh0_2::blocking::delay::DelayMs<u16> for Reverse<T>
where
T: eh1_0::blocking::delay::DelayMs<u16, Error=E>,
E: Debug,
{
fn delay_ms(&mut self, ms: u16) {
self.inner.try_delay_ms(ms).unwrap();
}
}
impl <T, E> eh0_2::blocking::delay::DelayUs<u32> for Reverse<T>
where
T: eh1_0::blocking::delay::DelayUs<u32, Error=E>,
E: Debug,
{
fn delay_us(&mut self, us: u32) {
self.inner.try_delay_us(us).unwrap();
}
}
impl <T, E> eh0_2::blocking::delay::DelayUs<u16> for Reverse<T>
where
T: eh1_0::blocking::delay::DelayUs<u16, Error=E>,
E: Debug,
{
fn delay_us(&mut self, us: u16) {
self.inner.try_delay_us(us).unwrap();
}
}
}
mod spi {
use super::{Reverse, Debug};
impl <T, E> eh0_2::blocking::spi::Write<u8> for Reverse<T>
where
T: eh1_0::blocking::spi::Write<u8, Error=E>,
E: Debug
{
type Error = E;
fn write(&mut self, words: &[u8]) -> Result<(), Self::Error> {
self.inner.try_write(words)
}
}
impl <T, E> eh0_2::blocking::spi::Transfer<u8> for Reverse<T>
where
T: eh1_0::blocking::spi::Transfer<u8, Error=E>,
E: Debug
{
type Error = E;
fn transfer<'a>(&mut self, words: &'a mut [u8]) -> Result<&'a [u8], Self::Error> {
self.inner.try_transfer(words)
}
}
impl <T, E> eh0_2::blocking::spi::WriteIter<u8> for Reverse<T>
where
T: eh1_0::blocking::spi::WriteIter<u8, Error=E>,
E: Debug
{
type Error = E;
fn write_iter<WI>(&mut self, words: WI) -> Result<(), Self::Error>
where
WI: IntoIterator<Item = u8>
{
self.inner.try_write_iter(words)
}
}
}
mod i2c {
use eh1_0::blocking::i2c::SevenBitAddress;
use super::{Reverse, Debug};
impl <T, E> eh0_2::blocking::i2c::Read for Reverse<T>
where
T: eh1_0::blocking::i2c::Read<SevenBitAddress, Error=E>,
E: Debug,
{
type Error = E;
fn read(&mut self, address: SevenBitAddress, words: &mut [u8]) -> Result<(), Self::Error> {
self.inner.try_read(address, words)
}
}
impl <T, E> eh0_2::blocking::i2c::Write for Reverse<T>
where
T: eh1_0::blocking::i2c::Write<SevenBitAddress, Error=E>,
E: Debug,
{
type Error = E;
fn write(&mut self, address: SevenBitAddress, words: &[u8]) -> Result<(), Self::Error> {
self.inner.try_write(address, words)
}
}
impl <T, E> eh0_2::blocking::i2c::WriteIter for Reverse<T>
where
T: eh1_0::blocking::i2c::WriteIter<SevenBitAddress, Error=E>,
E: Debug,
{
type Error = E;
fn write<B>(&mut self, address: SevenBitAddress, words: B) -> Result<(), Self::Error>
where
B: IntoIterator<Item = u8>,
{
self.inner.try_write_iter(address, words)
}
}
impl <T, E> eh0_2::blocking::i2c::WriteRead for Reverse<T>
where
T: eh1_0::blocking::i2c::WriteRead<SevenBitAddress, Error=E>,
E: Debug,
{
type Error = E;
fn write_read(&mut self, address: SevenBitAddress, bytes: &[u8], buffer: &mut [u8]) -> Result<(), Self::Error> {
self.inner.try_write_read(address, bytes, buffer)
}
}
impl <T, E> eh0_2::blocking::i2c::WriteIterRead for Reverse<T>
where
T: eh1_0::blocking::i2c::WriteIterRead<SevenBitAddress, Error=E>,
E: Debug,
{
type Error = E;
fn write_iter_read<B>(&mut self, address: SevenBitAddress, bytes: B, buffer: &mut [u8]) -> Result<(), Self::Error>
where
B: IntoIterator<Item = u8>,
{
self.inner.try_write_iter_read(address, bytes, buffer)
}
}
}
mod serial {
use super::{Reverse, Debug};
impl <T, E> eh0_2::blocking::serial::Write<u8> for Reverse<T>
where
T: eh1_0::blocking::serial::Write<u8, Error=E>,
E: Debug,
{
type Error = E;
fn bwrite_all(&mut self, words: &[u8]) -> Result<(), Self::Error> {
self.inner.try_bwrite_all(words)
}
fn bflush(&mut self) -> Result<(), Self::Error> {
self.inner.try_bflush()
}
}
}