#[non_exhaustive]pub enum Schedule {
Once(SystemTime),
Periodic(Duration),
Cron(SmolStr),
Manual,
}Expand description
When a background job runs.
Implements Serialize/Deserialize so durable persistence backends
(e.g. SystemLabelSchedulerPersistence) can round-trip the schedule
across restart. SystemTime, Duration, and SmolStr are all
serde-compatible out of the box.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Once(SystemTime)
Fire once at the absolute instant given.
Periodic(Duration)
Repeat every period (uniform spacing).
Cron(SmolStr)
Cron-style schedule ("0 */15 * * * *").
Manual
Only via explicit uni.plugin.runJob('id').
Implementations§
Source§impl Schedule
impl Schedule
Sourcepub fn next_after(&self, from: SystemTime) -> Option<SystemTime>
pub fn next_after(&self, from: SystemTime) -> Option<SystemTime>
Compute the next instant at or after from that this schedule
fires, or None if the schedule is exhausted (a Once whose
instant has already passed) or the cron expression cannot be
parsed.
Used by the host scheduler driver
(crate::scheduler::Scheduler::tick_at) to time-gate
dispatch.
§Examples
use std::time::{Duration, SystemTime};
use uni_plugin::traits::background::Schedule;
let now = SystemTime::now();
let s = Schedule::Periodic(Duration::from_secs(10));
let next = s.next_after(now).unwrap();
assert!(next >= now + Duration::from_secs(10));
// A Once whose instant has passed is exhausted.
let past = now - Duration::from_secs(60);
assert!(Schedule::Once(past).next_after(now).is_none());Trait Implementations§
Source§impl<'de> Deserialize<'de> for Schedule
impl<'de> Deserialize<'de> for Schedule
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
impl Eq for Schedule
impl StructuralPartialEq for Schedule
Auto Trait Implementations§
impl Freeze for Schedule
impl RefUnwindSafe for Schedule
impl Send for Schedule
impl Sync for Schedule
impl Unpin for Schedule
impl UnsafeUnpin for Schedule
impl UnwindSafe for Schedule
Blanket Implementations§
impl<T> Allocation for T
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more