Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oleiade/jackdauer
Use this Rust crate to easily parse various time formats to durations.
https://github.com/oleiade/jackdauer
date-and-time parsing text-processing
Last synced: 2 months ago
JSON representation
Use this Rust crate to easily parse various time formats to durations.
- Host: GitHub
- URL: https://github.com/oleiade/jackdauer
- Owner: oleiade
- License: mit
- Created: 2021-07-25T14:53:48.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-04-24T10:55:52.000Z (almost 2 years ago)
- Last Synced: 2024-10-13T19:19:34.667Z (4 months ago)
- Topics: date-and-time, parsing, text-processing
- Language: Rust
- Homepage: https://docs.rs/jackdauer/0.1.0/jackdauer/
- Size: 23.4 KB
- Stars: 8
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# JackDauer
![CI](https://github.com/oleiade/jackdauer/actions/workflows/main.yml/badge.svg)
Use this Rust crate to easily parse various time formats to durations.
## Demo
```rust
use dauer::duration;
use std::time::Duration;let nanoseconds = duration("1 nanosecond");
let milliseconds = duration("2 milliseconds");
let seconds = duration("3 seconds");
let minutes = duration("4 minutes");
let hours = duration("5 hours");
let day = duration("6 days");
let week = duration("7 weeks");
let month = duration("8 months");
let year = duration("9 months");
let real_big_duration = duration("9 years, 8 months, 7 weeks and 6 days");
let real_small_duration = duration("4 minutes 3 seconds, 2 milliseconds and 1 nanosecond");
```## Features
- The [`duration`](https://docs.rs/jackdauer/0.1.0/jackdauer/fn.duration.html) function provides straightforward functions to parse durations from a human-readable format, into std::time::Duration instances.
- The time unit-specific functions return unsigned integers representing the amount of said time unit parsed from a human-readable format:
- [`years`](fn.years.html) returns the parsed duration as a number of years
- [`months`](fn.months.html) returns the parsed duration as a number of months
- [`weeks`](fn.weeks.html) returns the parsed duration as a number of weeks
- [`days`](fn.days.html) returns the parsed duration as a number of days
- [`hours`](fn.hours.html) returns the parsed duration as a number of hours
- [`minutes`](fn.minutes.html) returns the parsed duration as a number of minutes
- [`seconds`](fn.seconds.html) returns the parsed duration as a number of seconds
- [`milliseconds`](fn.milliseconds.html) returns the parsed duration as a number of years
- [`nanoseconds`](fn.nanoseconds.html) returns the parsed duration as a number of years## Installation
Add it as a dependency to your `Cargo.toml`
```toml
[dependencies]
jackdauer = "0.1.0"
```## Documentation
[Documentation](https://docs.rs/jackdauer/0.1.0/jackdauer/)
## Authors
- [@oleiade](https://www.github.com/oleiade)
## FAQ
#### What's the name about?
"Dauer" is the German word for "*duration*". When thinking about time, it reminded me of this show called "24", and its main character "Jack Bauer" (which, incidentally also happens to mean "builder" in German). The contraction of both gives "Jack Dauer".
#### But why the ridiculous name?
It's 2021, COVID-19 is still raging out there. The last year and a half have been quite gloomy, and I thought I needed (and you probably needed it too; maybe you're not just aware of it) some terrible pun to shed some light on my day-to-day quarantined life.
## Acknowledgements
- [This crate wouldn't have been possible without Nom, the parser combinator library](https://github.com/Geal/nom)
- [Inspiration taken from the awesome ms javascript library](https://github.com/vercel/ms#readme)
- [readme.so, a superb tool that helped me build this README](https://readme.so)## License
[MIT](https://choosealicense.com/licenses/mit/)