#timezone #date-time #time #tz #iana #name #chrono

time-tz

Implementation of tz database (IANA) for the time Rust crate

17 releases (5 stable)

3.0.0-rc.5.0.0 Mar 2, 2024
2.0.0 Jul 22, 2023
1.0.3 Jun 10, 2023
1.0.2 May 22, 2022
0.5.2 Mar 11, 2022

#25 in Date and time

Download history 4972/week @ 2024-04-03 7498/week @ 2024-04-10 7182/week @ 2024-04-17 7178/week @ 2024-04-24 5179/week @ 2024-05-01 5352/week @ 2024-05-08 6946/week @ 2024-05-15 7379/week @ 2024-05-22 6449/week @ 2024-05-29 6440/week @ 2024-06-05 5781/week @ 2024-06-12 5715/week @ 2024-06-19 4277/week @ 2024-06-26 4678/week @ 2024-07-03 6973/week @ 2024-07-10 5359/week @ 2024-07-17

22,550 downloads per month
Used in 22 crates (16 directly)

BSD-3-Clause

635KB
10K SLoC

C 7K SLoC // 0.2% comments Rust 1.5K SLoC // 0.2% comments AWK 1K SLoC // 0.2% comments Korn shell 690 SLoC // 0.1% comments Shell 36 SLoC // 0.1% comments

time-tz

An implementation of the tz database for the time-rs Rust crate.

chat

This implementation is based off of chrono-tz (https://github.com/chronotope/chrono-tz) but uses time-rs instead of chrono. This is designed to replace use of chono dependency which is impacted by CVE-2020-26235 (localtime_r thread safety issue linked to std::env::set_var).

Features

  • Injects an assume_timezone member function to any PrimitiveDateTime.
  • Injects a to_timezone member function to any OffsetDateTime.
  • Provides a timezones::get_by_name function to get a timezone by name.
  • Supports finding the closest IANA match from a windows timezone name.
  • Supports obtaining system's current timezone (through the system feature).

Usage

use time::macros::datetime;
use time_tz::{PrimitiveDateTimeExt, OffsetDateTimeExt, timezones};

fn main()
{
    // ===========================================
    //  Create a new datetime in a given timezone
    // ===========================================
    
    // First we have to get the source timezone:
    let london = timezones::db::europe::LONDON;

    // Now we can create a primitive date time and call the extension function:
    let dt = datetime!(2016-10-8 17:0:0).assume_timezone_utc(london);


    // ===========================
    //  Convert to a new timezone
    // ===========================

    // First we get the target timezone:
    let berlin = timezones::db::europe::BERLIN;

    // Now we can convert (again by calling an extension function):
    let converted = dt.to_timezone(berlin);

    // ... do something with converted
}

Dependencies

~1–14MB
~149K SLoC