job-runner

Crates.iojob-runner
lib.rsjob-runner
version1.0.1
sourcesrc
created_at2023-01-19 07:37:32.313014
updated_at2023-01-19 07:47:24.616662
descriptionSimple background job runner with configurable delays between job runs
homepagehttps://crates.io/crates/job-runner
repositoryhttps://github.com/EkardNT/job-runner
max_upload_size
id762382
size30,279
Drake Tetreault (EkardNT)

documentation

README

Crate

A simple job runner library which gives each job a dedicated thread and allows for configurable delays between each invocation of the job's logic.

Example

A program using the JobRunner utility is expected to have this basic outline:

use job_runner::{Job, JobRunner, fixed_delay};

fn main() {
    // At program startup, create the JobRunner and register your tasks.
    let mut job_runner = JobRunner::new();
    job_runner.start(Job::new(
        "cool_job",
        fixed_delay(std::time::Duration::from_secs(5)),
        my_cool_job));

    // Do other things in your program...

    // Then, when shutting down your program, signal all the job threads
    // to stop running.
    job_runner.stop_all();

    // Maybe signal other parts of your program to gracefully shut down too...

    // Finally (and optionally) wait for the job threads to actually exit.
    job_runner.join_all();
}

fn my_cool_job() {
    // Do cool things..
}
Commit count: 11

cargo fmt