Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/metric-space/tiny-scheduler
no-brainer job scheduler for haskell
https://github.com/metric-space/tiny-scheduler
composable-time-units easy-job-scheduler haskell job-scheduler
Last synced: 26 days ago
JSON representation
no-brainer job scheduler for haskell
- Host: GitHub
- URL: https://github.com/metric-space/tiny-scheduler
- Owner: metric-space
- License: bsd-3-clause
- Created: 2017-04-15T02:25:15.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2019-03-27T19:13:18.000Z (over 5 years ago)
- Last Synced: 2024-09-29T17:41:49.078Z (about 1 month ago)
- Topics: composable-time-units, easy-job-scheduler, haskell, job-scheduler
- Language: Haskell
- Homepage:
- Size: 13.7 KB
- Stars: 8
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# tiny-scheduler
Utility Library to run jobs concurrently at predetermined Intervals
## Basic Example
```haskell
import TinyScheduler.Jobs
import TinyScheduler.SubJobs
import TinyScheduler.Time
import Data.Timeintervalio :: Interval
intervalio = (Minutes 1) + (Secs 20)jobx :: UTCTime -> Job ()
jobx x = makeJob 1234 4 intervalio x (putStrLn "Hello")main :: IO ()
main = getCurrentTime >>= (\x ->
execSubJobs . convertJobIntoSubJobs x $ (jobx x)) >>
return ()```
### A little more advanced Example
In the following, assuming that time starts at 0, jobs are fired at 1 minute 2 seconds, 1 minutes 4 seconds,
and 2 minutes 2 seconds and 2 minutes 4 seconds from current time```haskell
import TinyScheduler.Jobs
import TinyScheduler.SubJobs
import TinyScheduler.Time
import Data.Time
import Data.Monoidatom1 :: TimeAtom
atom1 = makeTimeAtom 2 (Minutes 1)atom2 :: TimeAtom
atom2 = makeTimeAtom 2 (Secs 2)jobx :: UTCTime -> Job ()
jobx x = timeAtomToJob 1234 (putStrLn "Hello") x (atom1 <> atom2)main :: IO ()
main = getCurrentTime >>= (\x ->
execSubJobs . convertJobIntoSubJobs x $ (jobx x)) >>
return ()```
# how to install
`stack install tiny-scheduler`
## pending work
1. Tests
2. More documentation
3. Haddock documentation
4. Complete the example below### for an application based example (still in progress)
go to [https://github.com/functor-soup/tiny-simple-scheduler-example](https://github.com/functor-soup/tiny-simple-scheduler-example)