view examples/full_featured.rs @ 73:b493c1f99877

Disable full-featured example if feature full not enabled for automated testing
author Lewin Bormann <lbo@spheniscida.de>
date Sat, 02 Apr 2022 13:49:42 -0700
parents 3ed9875b9139
children 868eb5c58450
line wrap: on
line source

use memoize::memoize;
use std::thread;
use std::time::{Duration, Instant};

#[derive(Debug, Clone)]
struct ComplexStruct {
    s: String,
    b: bool,
    i: Instant,
}

#[cfg(feature = "full")]
#[memoize(TimeToLive: Duration::from_secs(2), Capacity: 123)]
fn hello(key: String) -> ComplexStruct {
    println!("hello: {}", key);
    ComplexStruct {
        s: key,
        b: false,
        i: Instant::now(),
    }
}

fn main() {
    #[cfg(feature = "full")]
    {
        println!("result: {:?}", hello("ABC".to_string()));
        println!("result: {:?}", hello("DEF".to_string()));
        println!("result: {:?}", hello("ABC".to_string())); //Same as first
        thread::sleep(core::time::Duration::from_millis(2100));
        println!("result: {:?}", hello("EFG".to_string()));
        println!("result: {:?}", hello("ABC".to_string())); //Refreshed
        println!("result: {:?}", hello("EFG".to_string())); //Same as first
        println!("result: {:?}", hello("ABC".to_string())); //Same as refreshed
        println!("result: {:?}", memoized_original_hello("ABC".to_string()));
    }
}