//! I2C Sensor Reading

use anyhow;
use embedded_hal::blocking::delay::DelayMs;
use esp_idf_hal::{
    delay::FreeRtos,
    i2c::{config::MasterConfig, Master, MasterPins, I2C0},
    peripherals::Peripherals,
    prelude::*,
};
use esp_idf_sys::*;
use imc42670p::{IMC42670P, SlaveAddr};

use shtcx::{self, PowerMode};

use shared_bus;

// goals of this exercise:
// instantiate i2c peripheral
// implement one sensor, print sensor values
// implement second sensor on same bus to solve an ownership problem

fn main() -> anyhow::Result<()>  {
    link_patches();

    let peripherals = Peripherals::take().unwrap();

    let sda = peripherals.pins.gpio10;
    let scl = peripherals.pins.gpio8;
    // If you are using an ESP32-C3-DevKitC-02, change to:
    // let sda = peripherals.pins.gpio4;
    // let scl = peripherals.pins.gpio5;

    let i2c = Master::<I2C0, _, _>::new(
        peripherals.i2c0,
        MasterPins { sda, scl },
        <MasterConfig as Default>::default().baudrate(400.kHz().into()),
    )?;

    let bus = shared_bus::BusManagerSimple::new(i2c);

    let proxy_1 =bus.acquire_i2c();
    let proxy_2 =bus.acquire_i2c();

    let mut imu = IMC42670P::new(proxy_1, SlaveAddr::B110_1000)?;
    // If you are using an ESP32-C3-DevKitC-02, change to:
    // let mut imu = IMC42670P::new(proxy_1, SlaveAddr::B110_1001)?;
    println!("Sensor init");
     let device_id = imu.read_device_id_register()?;
    println!("Device ID: {}", device_id);
  

    imu.gyro_ln()?;


    let mut sht = shtcx::shtc3(proxy_2);
    let device_id = sht.device_identifier().unwrap();
    println!("Device ID: {}", device_id);

    loop {
        let gyro_data =imu.read_gyro()?;
        sht.start_measurement(PowerMode::NormalMode).unwrap();
        FreeRtos.delay_ms(100u32);
        let measurement = sht.get_measurement_result().unwrap(); 
        
        println!(
            " GYRO: X: {:.4}  Y: {:.4}  Z: {:.4}\n
            TEMP: {}\n
            HUM: {:?}\n
            \n 
            ",
            gyro_data.x, gyro_data.y, gyro_data.y, 
            measurement.temperature.as_degrees_celsius(), measurement.humidity.as_percent(),
        );

        FreeRtos.delay_ms(500u32);
    }
}
esp:0
esp:1
esp:2
esp:3
esp:4
esp:5
esp:6
esp:7
esp:9
esp:10
esp:18
esp:19
esp:20
esp:21
esp:RST
esp:3V3
esp:NC1
esp:GND
esp:8.1
esp:8.2
esp:NC2
esp:NC3
esp:NC4
esp:NC5
esp:NC6
esp:5V
esp:EN
esp:BAT+
IMC42670PBreakout
chip1:SCL
chip1:SDA
chip1:GND
chip1:VCC
SHTC3Breakout
chip2:SCL
chip2:SDA
chip2:GND
chip2:VCC