Fast and precise gnu relative time parser of rust strings to a Duration

fundu-gnu Docs | Changelog


GitHub branch checks state Crates.io docs.rs MSRV

Table of Contents

Overview

This crate provides a simple to use and fast parser based on fundu aiming for full compatibility with gnu relative items in date strings format as specified in their [documentation].

fundu-gnu can parse rust strings with RelativeTimeParser::parse and others or the global parse method:

&str | Duration | -- | -- | "1hour"| Duration::positive(60 * 60, 0) | "minute"| Duration::positive(60, 0) | "2 hours"| Duration::positive(2 * 60 * 60, 0) | "-3minutes"| Duration::negative(3 * 60, 0) | "3 mins ago"| Duration::negative(3 * 60, 0) | "999sec +1day"| Duration::positive(86_400 + 999, 0) | "55secs500week"| Duration::positive(55 + 500 * 604_800, 0) | "123456789"| Duration::positive(123_456_789, 0) | "42fortnight"| Duration::positive(42 * 2 * 604_800, 0) | "yesterday"| Duration::negative(24 * 60 * 60, 0) | "now"| Duration::positive(0, 0) | "today -10seconds"| Duration::negative(10, 0) |

fundu parses into its own [Duration] which is a superset of other Durations like [std::time::Duration], [chrono::Duration] and [time::Duration]. See the documentation how to easily handle the conversion between these durations. For examples and further documentation see the docs!

Audience

This crate is for you if you

This crate might not be for you if you want to customize the parser to a format which would not be compatible with gnu. See the main fundu project, if you want to use a parser tailored to your needs.

Installation

Add this to Cargo.toml

toml [dependencies] fundu-gnu = "0.3.0"

or install with cargo add fundu-gnu.

Activating the chrono or time feature provides a TryFrom and SaturatingInto implementation of fundu's Duration for [chrono::Duration] or [time::Duration]. These features also enable a From implementation of [chrono::DateTime] or [time::OffsetDateTime], [time::PrimitiveDateTime] for fundu-gnu's DateTime. Converting from/to [std::time::Duration] does not require an additional feature. Activating the serde feature allows some structs and enums to be serialized or deserialized with serde

Description of the Format

Supported time units:

Fuzzy time units are not all of equal duration and depend on a given date. If no date is given when parsing, the system time of now in UTC +0 is assumed.

Supported numerals:

The special keywords yesterday worth -1 day, tomorrow worth +1 day, today and now each worth a zero duration are allowed, too. These keywords count as a full duration and don't accept a number, time unit or the ago time unit suffix.

Summary of the rest of the format:

Please see also the gnu documentation for a description of their format.

Benchmarks

To run the benchmarks on your machine, clone the repository

shell git clone https://github.com/fundu-rs/fundu.git cd fundu

and then run the fundu-gnu benchmarks with

shell cargo bench --package fundu-gnu

The above won't run the flamegraph and iai-callgrind benchmarks.

The iai-callgrind (feature = with-iai) and flamegraph (feature = with-flamegraph) benchmarks can only be run on unix. Use the --features option of cargo to run the benchmarks with these features.

To get a rough idea about the parsing times, here the average parsing speed of some inputs (Quad core 3000Mhz, 8GB DDR3, Linux):

Input | avg parsing time --- | ---:| 1 | 49.399 ns 123456789 | 57.108 ns "1".repeat(1022) | 253.89 ns sec / 1sec / seconds / 1seconds | 63.521 / 81.871 / 74.962 / 97.785 ns min / 1min / minutes / 1minutes | 64.102 / 82.876 / 77.893 / 98.374 ns 1year | 164.30 ns 10000000year | 182.85 ns 1sec 1min | 167.74 ns 1sec 1min 1sec 1min | 325.70 ns 1sec 1min 1hour 1day | 353.18 ns "1sec 1min".repeat(100) | 15.258 µs

Parsing of fuzzy time units like in 1year or 10000000year adds a considerable amount of additional computations but is still comparably fast.

License

MIT license (LICENSE or http://opensource.org/licenses/MIT)