Added logic for ringer and scheduler. still wip
This commit is contained in:
70
src/ringer.rs
Normal file
70
src/ringer.rs
Normal file
@@ -0,0 +1,70 @@
|
||||
use std::{sync::{Arc, Mutex}, thread};
|
||||
|
||||
use gpio_cdev::{Chip, LineRequestFlags};
|
||||
|
||||
pub trait Ringer: Send + Sync {
|
||||
fn ring(&self) -> Result<(), String>;
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct BeepRinger {
|
||||
chip: Arc<Mutex<Chip>>,
|
||||
}
|
||||
|
||||
impl BeepRinger {
|
||||
|
||||
fn beep(times: u32, chip: &mut Chip) -> Result<(), String> {
|
||||
let beeper = chip.get_line(17);
|
||||
|
||||
let beeper = match beeper {
|
||||
Ok(beeper) => beeper,
|
||||
Err(e) => {
|
||||
println!("Error opening line: {}", e);
|
||||
return Err("Could not open Line to Beeper".to_string());
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
let beeper = beeper
|
||||
.request(LineRequestFlags::OUTPUT, 0, "my-gpio");
|
||||
|
||||
let beeper = match beeper {
|
||||
Ok(beeper) => beeper,
|
||||
Err(e) => {
|
||||
println!("Error requesting line: {}", e);
|
||||
return Err("Could not request Line to Beeper".to_string());
|
||||
}
|
||||
};
|
||||
|
||||
for _ in 0..times {
|
||||
beeper.set_value(1).map_err(|e| e.to_string())?;
|
||||
thread::sleep(std::time::Duration::from_secs(1));
|
||||
beeper.set_value(0).map_err(|e| e.to_string())?;
|
||||
thread::sleep(std::time::Duration::from_secs(1));
|
||||
}
|
||||
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
pub fn new(chip: Arc<Mutex<Chip>>) -> Self {
|
||||
Self { chip }
|
||||
}
|
||||
}
|
||||
|
||||
impl Ringer for BeepRinger {
|
||||
fn ring(&self) -> Result<(), String> {
|
||||
let chip = self.chip.lock();
|
||||
|
||||
let mut chip = match chip {
|
||||
Ok(chip) => chip,
|
||||
Err(e) => {
|
||||
println!("Error opening chip: {}", e);
|
||||
return Err("Could not access Chip".to_string());
|
||||
}
|
||||
};
|
||||
|
||||
BeepRinger::beep(5, &mut *chip)?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user