From db77d27eadb7fe015fbf8e9c91e149a6525aa674 Mon Sep 17 00:00:00 2001 From: Maxim Baz Date: Thu, 19 Dec 2024 20:09:59 +0100 Subject: [PATCH] iio als: support more drivers --- src/als/iio.rs | 55 ++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 44 insertions(+), 11 deletions(-) diff --git a/src/als/iio.rs b/src/als/iio.rs index 64b9aa4..3a2b418 100644 --- a/src/als/iio.rs +++ b/src/als/iio.rs @@ -40,8 +40,11 @@ impl Als { ) }) .and_then(|e| { - parse_illuminance(e.path()) - .or_else(|_| parse_intensity(e.path())) + // TODO should probably start from the `parse_illuminance_input` in the next major version + parse_illuminance_raw(e.path()) + .or_else(|_| parse_illuminance_input(e.path())) + .or_else(|_| parse_intensity_raw(e.path())) + .or_else(|_| parse_intensity_rgb(e.path())) .ok() }) }) @@ -80,24 +83,54 @@ impl super::Als for Als { } } -fn parse_illuminance(path: PathBuf) -> Result> { - let open_file = |name: &str| File::open(path.join(name)).map_err(Box::::from); +fn parse_illuminance_raw(path: PathBuf) -> Result> { + Ok(Illuminance { + value: Mutex::new( + open_file(&path, "in_illuminance_raw") + .or_else(|_| open_file(&path, "in_illuminance0_raw"))?, + ), + scale: open_file(&path, "in_illuminance_scale") + .or_else(|_| open_file(&path, "in_illuminance0_scale")) + .and_then(|mut f| read(&mut f)) + .unwrap_or(1_f64), + offset: open_file(&path, "in_illuminance_offset") + .or_else(|_| open_file(&path, "in_illuminance0_offset")) + .and_then(|mut f| read(&mut f)) + .unwrap_or(0_f64), + }) +} +fn parse_intensity_raw(path: PathBuf) -> Result> { Ok(Illuminance { - value: Mutex::new(open_file("in_illuminance_raw")?), - scale: open_file("in_illuminance_scale") + value: Mutex::new(open_file(&path, "in_intensity_both_raw")?), + scale: open_file(&path, "in_intensity_scale") .and_then(|mut f| read(&mut f)) .unwrap_or(1_f64), - offset: open_file("in_illuminance_offset") + offset: open_file(&path, "in_intensity_offset") .and_then(|mut f| read(&mut f)) .unwrap_or(0_f64), }) } -fn parse_intensity(path: PathBuf) -> Result> { +fn parse_illuminance_input(path: PathBuf) -> Result> { + Ok(Illuminance { + value: Mutex::new( + open_file(&path, "in_illuminance_input") + .or_else(|_| open_file(&path, "in_illuminance0_input"))?, + ), + scale: 1_f64, + offset: 0_f64, + }) +} + +fn parse_intensity_rgb(path: PathBuf) -> Result> { Ok(Intensity { - r: Mutex::new(File::open(path.join("in_intensity_red_raw"))?), - g: Mutex::new(File::open(path.join("in_intensity_green_raw"))?), - b: Mutex::new(File::open(path.join("in_intensity_blue_raw"))?), + r: Mutex::new(open_file(&path, "in_intensity_red_raw")?), + g: Mutex::new(open_file(&path, "in_intensity_green_raw")?), + b: Mutex::new(open_file(&path, "in_intensity_blue_raw")?), }) } + +fn open_file(path: &Path, name: &str) -> Result> { + File::open(path.join(name)).map_err(Box::::from) +}