#hash-map #hash-set #collection #delay-queue #delay

delay_map

HashMap collections whose entries expire after a given time

6 releases (3 breaking)

0.4.0 Jul 11, 2024
0.3.0 Mar 7, 2023
0.2.0 Feb 6, 2023
0.1.2 Oct 27, 2022
0.1.0 Jan 31, 2022

#249 in Data structures

Download history 12250/week @ 2024-09-17 10081/week @ 2024-09-24 8686/week @ 2024-10-01 11601/week @ 2024-10-08 14326/week @ 2024-10-15 14247/week @ 2024-10-22 12639/week @ 2024-10-29 9810/week @ 2024-11-05 9137/week @ 2024-11-12 11723/week @ 2024-11-19 12949/week @ 2024-11-26 11548/week @ 2024-12-03 11796/week @ 2024-12-10 9630/week @ 2024-12-17 7492/week @ 2024-12-24 5947/week @ 2024-12-31

36,825 downloads per month
Used in 5 crates (2 directly)

Apache-2.0

21KB
331 lines

delay_map

Build Status Doc Status Crates Status

Documentation at docs.rs

Overview

This crate contains two data structures, HashSetDelay and HashMapDelay. These behave like the standard library HashSet and HashMaps with the added feature that entries inserted into the mappings expire after a fixed period of time.

Usage

Creating a map

    use delay_map::HashMapDelay;
    use futures::prelude::*;

    // Set a default timeout for entries
    let mut delay_map = HashMapDelay::new(std::time::Duration::from_secs(1));


    tokio_test::block_on(async {

    delay_map.insert(1, "entry_1");
    delay_map.insert(2, "entry_2");
    
    if let Some(Ok((key, value))) = delay_map.next().await {
        println!("Entry 1: {}, {}", key, value);  
    }

    if let Some(Ok((key, value))) = delay_map.next().await {
        println!("Entry 2: {}, {}", key,value);  
    }
    });

Dependencies

~3–8.5MB
~70K SLoC