Cater for non-Linux environments

Doctests can be run using `cargo test --doc`. The examples still require Linux.
This commit is contained in:
huntc 2021-04-29 14:43:11 +10:00 committed by Marcel
parent e10fa1a35a
commit c97894f84c
2 changed files with 39 additions and 3 deletions

View file

@ -22,6 +22,8 @@ env_logger = "0.7"
futures = { version = "0.3" } futures = { version = "0.3" }
i2cdev = "0.4" i2cdev = "0.4"
influx_db_client = { version = "0.4", default-features= false, features = ["rustls-tls"] } influx_db_client = { version = "0.4", default-features= false, features = ["rustls-tls"] }
linux-embedded-hal = "0.3"
tokio = {version = "0.2", features = ["full"] } tokio = {version = "0.2", features = ["full"] }
url = "2.1" url = "2.1"
[target.'cfg(target_os = "linux")'.dev-dependencies]
linux-embedded-hal = "0.3"

View file

@ -7,7 +7,8 @@
//! extern crate bme680; //! extern crate bme680;
//! extern crate embedded_hal; //! extern crate embedded_hal;
//! extern crate linux_embedded_hal as hal; //! // Note that you'll have to import your board crates types corresponding to
//! // Delay and I2cdev.
//! //!
//! use bme680::*; //! use bme680::*;
//! use embedded_hal::blocking::i2c; //! use embedded_hal::blocking::i2c;
@ -15,10 +16,43 @@
//! use std::result; //! use std::result;
//! use std::time::Duration; //! use std::time::Duration;
//! //!
//! # mod hal {
//! # use super::*;
//! # use embedded_hal::blocking::delay;
//! #
//! # #[derive(Debug)]
//! # pub struct Delay {}
//! #
//! # impl delay::DelayMs<u8> for Delay {
//! # fn delay_ms(&mut self, _ms: u8) {}
//! # }
//! #
//! # #[derive(Debug)]
//! # pub enum I2CError {}
//! #
//! # pub struct I2cdev {}
//! #
//! # impl i2c::Write for I2cdev {
//! # type Error = I2CError;
//! #
//! # fn write<'w>(&mut self, addr: u8, bytes: &'w [u8]) -> result::Result<(), Self::Error> {
//! # Ok(())
//! # }
//! # }
//! #
//! # impl i2c::Read for I2cdev {
//! # type Error = I2CError;
//! #
//! # fn read<'w>(&mut self, addr: u8, bytes: &'w mut [u8]) -> result::Result<(), Self::Error> {
//! # Ok(())
//! # }
//! # }
//! # }
//!
//! fn main() -> result::Result<(), Error<<hal::I2cdev as i2c::Read>::Error, <hal::I2cdev as i2c::Write>::Error>> //! fn main() -> result::Result<(), Error<<hal::I2cdev as i2c::Read>::Error, <hal::I2cdev as i2c::Write>::Error>>
//! { //! {
//! // Initialize device //! // Initialize device
//! let i2c = I2cdev::new("/dev/i2c-1").unwrap(); //! let i2c = I2cdev {}; // Your I2C device construction will look different, perhaps using I2cdev::new(..)
//! let mut dev = Bme680::init(i2c, Delay {}, I2CAddress::Primary)?; //! let mut dev = Bme680::init(i2c, Delay {}, I2CAddress::Primary)?;
//! let settings = SettingsBuilder::new() //! let settings = SettingsBuilder::new()
//! .with_humidity_oversampling(OversamplingSetting::OS2x) //! .with_humidity_oversampling(OversamplingSetting::OS2x)