#duration #instant #const #time-duration #time

no-std fugit

Time library for embedded targets with ease-of-use and performance first

11 releases

0.3.7 Jun 6, 2023
0.3.6 Jun 23, 2022
0.3.5 Feb 14, 2022
0.3.3 Dec 25, 2021
0.1.4 Oct 31, 2021

#22 in Date and time

Download history 13548/week @ 2024-12-05 16866/week @ 2024-12-12 13090/week @ 2024-12-19 10006/week @ 2024-12-26 14233/week @ 2025-01-02 18565/week @ 2025-01-09 17268/week @ 2025-01-16 14791/week @ 2025-01-23 15915/week @ 2025-01-30 18744/week @ 2025-02-06 15736/week @ 2025-02-13 14111/week @ 2025-02-20 14103/week @ 2025-02-27 15104/week @ 2025-03-06 15450/week @ 2025-03-13 12739/week @ 2025-03-20

59,234 downloads per month
Used in 255 crates (115 directly)

MIT/Apache

150KB
2.5K SLoC

fugit

fugit provides a comprehensive library of Duration and Instant for the handling of time in embedded systems, doing all it can at compile time.

This library is a heavily inspired of std::chrono's Duration from C++ which does all it can at compile time.

Aims

  • no_std library with goals of user-friendliness and performance first
    • All methods are const fn that can be (i.e. non-trait methods)
    • Use no traits, concrete types all the way for maximum const-ification
    • Operations are supported between different bases and backing storages instead of implementing custom traits
    • All constants needed for comparing or changing timebase are guaranteed compile time generated
  • Support for both u32 and u64 backing storage with efficient instruction lowering on MCUs
    • On Cortex-M3 and up: no soft-impls pulled in for both u32 and u64 except when changing base on u64
    • Comparisons on u32 and u64 do not use division, only changing base with all constants calculated at compile time
  • Selection of base happens at compile time
    • A common problem is that run time changing of base robs us of a lot of optimization opportunities, but since there are no traits and short-hands select the correct base at compile time.

Dependencies

~170KB