can find due after ts and Task w schedule

master
Bel LaPointe 2025-11-12 14:08:32 -07:00
parent 89185f5016
commit 4ca5ed4d7c
1 changed files with 25 additions and 11 deletions

View File

@ -503,20 +503,20 @@ impl Delta {
struct Task(serde_yaml::Value);
impl Task {
pub fn next_due(&self) -> Option<u64> {
pub fn next_due(&self, after: u64) -> Option<u64> {
match self.schedule() {
Some(schedule) => self.parse_schedule_next(schedule),
Some(schedule) => self.parse_schedule_next(schedule, after),
None => Some(1),
}
}
fn parse_schedule_next(&self, schedule: String) -> Option<u64> {
fn parse_schedule_next(&self, schedule: String, after: u64) -> Option<u64> {
let mut schedule = schedule;
if regex::Regex::new(r"^[0-9]+h$").unwrap().is_match(&schedule) {
let hours = &schedule[..schedule.len() - 1];
match hours.parse::<u64>() {
Ok(hours) => return Some(Delta::now_time() + hours * 60 * 60),
Ok(hours) => return Some(after + hours * 60 * 60),
_ => {}
};
}
@ -528,7 +528,7 @@ impl Task {
schedule += "T00";
}
if regex::Regex::new(r"[0-9]{4}-[0-9]{2}-[0-9]{2}T[0-9]{2}$")
if regex::Regex::new(r"^[0-9]{4}-[0-9]{2}-[0-9]{2}T[0-9]{2}$")
.unwrap()
.is_match(&schedule)
{
@ -545,6 +545,20 @@ impl Task {
};
}
if regex::Regex::new(r"^([^ ]+ ){4}[^ ]+$")
.unwrap()
.is_match(&schedule)
{
let after = chrono::DateTime::from_timestamp(after as i64, 0).unwrap();
if let Ok(next) = cron_parser::parse(&schedule, &after) {
let seconds = next.format("%s").to_string();
match seconds.parse::<u64>() {
Ok(n) => return Some(n),
_ => {}
};
}
}
None
}
@ -570,7 +584,7 @@ mod test_task {
fn test_unscheduled() {
let task = Task(serde_yaml::Value::String("hello world".to_string()));
assert_eq!(None, task.schedule());
assert_eq!(Some(1 as u64), task.next_due());
assert_eq!(Some(1 as u64), task.next_due(100));
}
#[test]
@ -579,7 +593,7 @@ mod test_task {
m.insert("schedule".into(), "2006-01-02".into());
let task = Task(serde_yaml::Value::Mapping(m));
assert_eq!(Some("2006-01-02".to_string()), task.schedule());
assert_eq!(Some(1136160000 as u64), task.next_due());
assert_eq!(Some(1136160000 as u64), task.next_due(100));
}
#[test]
@ -588,7 +602,7 @@ mod test_task {
m.insert("schedule".into(), "2036-01-02".into());
let task = Task(serde_yaml::Value::Mapping(m));
assert_eq!(Some("2036-01-02".to_string()), task.schedule());
assert_eq!(Some(2082844800 as u64), task.next_due());
assert_eq!(Some(2082844800 as u64), task.next_due(100));
}
#[test]
@ -597,7 +611,7 @@ mod test_task {
m.insert("schedule".into(), "2036-01-02T16".into());
let task = Task(serde_yaml::Value::Mapping(m));
assert_eq!(Some("2036-01-02T16".to_string()), task.schedule());
assert_eq!(Some(2082902400 as u64), task.next_due());
assert_eq!(Some(2082902400 as u64), task.next_due(100));
}
#[test]
@ -606,7 +620,7 @@ mod test_task {
m.insert("schedule".into(), "1h".into());
let task = Task(serde_yaml::Value::Mapping(m));
assert_eq!(Some("1h".to_string()), task.schedule());
assert_eq!(Some(Delta::now_time() + 60 * 60 as u64), task.next_due());
assert_eq!(Some(3700), task.next_due(100));
}
#[test]
@ -615,7 +629,7 @@ mod test_task {
m.insert("schedule".into(), "* * * * *".into());
let task = Task(serde_yaml::Value::Mapping(m));
assert_eq!(Some("* * * * *".to_string()), task.schedule());
assert_eq!(Some((Delta::now_time()) + 60 % 60 as u64), task.next_due());
assert_eq!(Some(120 as u64), task.next_due(100));
}
}