Skip to content

Commit

Permalink
fix: issue #37
Browse files Browse the repository at this point in the history
  • Loading branch information
BinChengZhao committed May 9, 2022
1 parent 85f8313 commit 739048b
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 7 deletions.
4 changes: 2 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "delay_timer"
version = "0.11.1"
version = "0.11.2"
authors = ["binchengZhao <binchengZhao@outlook.com>"]
edition = "2018"
repository = "https://github.com/BinChengZhao/delay-timer"
Expand Down Expand Up @@ -29,7 +29,7 @@ status-report = []
[dependencies]
cron_clock = "0.8.0"
anyhow = "^1.0.31"
rs-snowflake = "0.5.0"
rs-snowflake = "0.6.0"
dashmap = "^4.0.2"
lru = "^0.6.5"
once_cell = "1.9.0"
Expand Down
9 changes: 6 additions & 3 deletions src/timer/task.rs
Original file line number Diff line number Diff line change
Expand Up @@ -228,15 +228,17 @@ impl<'a> TryFrom<(FrequencyUnify<'a>, ScheduleIteratorTimeZone)> for FrequencyIn
return Err(FrequencyAnalyzeError::DisInitTime);
}

let seconds_state: SecondsState = (timestamp()..).step_by(seconds as usize);
let seconds_state: SecondsState =
((timestamp() + seconds)..).step_by(seconds as usize);
FrequencyInner::SecondsCountDown(1, seconds_state)
}
FrequencyUnify::FrequencySeconds(FrequencySeconds::Repeated(seconds)) => {
if seconds == 0 {
return Err(FrequencyAnalyzeError::DisInitTime);
}

let seconds_state: SecondsState = (timestamp()..).step_by(seconds as usize);
let seconds_state: SecondsState =
((timestamp() + seconds)..).step_by(seconds as usize);

FrequencyInner::SecondsRepeated(seconds_state)
}
Expand All @@ -245,7 +247,8 @@ impl<'a> TryFrom<(FrequencyUnify<'a>, ScheduleIteratorTimeZone)> for FrequencyIn
return Err(FrequencyAnalyzeError::DisInitTime);
}

let seconds_state: SecondsState = (timestamp()..).step_by(seconds as usize);
let seconds_state: SecondsState =
((timestamp() + seconds)..).step_by(seconds as usize);
FrequencyInner::SecondsCountDown(count_down, seconds_state)
}
};
Expand Down
4 changes: 2 additions & 2 deletions src/timer/timer_core.rs
Original file line number Diff line number Diff line change
Expand Up @@ -373,10 +373,10 @@ impl Timer {
// when-on-slot61-exec: (task_excute_timestamp - timestamp + next_second_hand) % slot_seed == 61

// Time difference + next second hand % DEFAULT_TIMER_SLOT_COUNT
let step = task_excute_timestamp.checked_sub(timestamp).unwrap_or(1) + next_second_hand;
let step = task_excute_timestamp.checked_sub(timestamp).unwrap_or(1);
let cylinder_line = step / DEFAULT_TIMER_SLOT_COUNT;
task.set_cylinder_line(cylinder_line);
let slot_seed = step % DEFAULT_TIMER_SLOT_COUNT;
let slot_seed = (step + next_second_hand) % DEFAULT_TIMER_SLOT_COUNT;

{
let mut slot_mut = self
Expand Down

0 comments on commit 739048b

Please sign in to comment.