#[macro_export]
macro_rules! cached {
($cachename:ident >> fn $name:ident ($($arg:ident : $argtype:ty),*) -> $ret:ty = $body:expr) => {
lazy_static! {
static ref $cachename: ::std::sync::Mutex<cached::UnboundCache<($($argtype),*), $ret>> = {
::std::sync::Mutex::new(cached::UnboundCache::new())
};
}
#[allow(unused_parens)]
pub fn $name($($arg: $argtype),*) -> $ret {
let key = ($($arg.clone()),*);
{
let mut cache = $cachename.lock().unwrap();
let res = $crate::Cached::cache_get(&mut *cache, &key);
if let Some(res) = res { return res.clone(); }
}
let val = (||$body)();
let mut cache = $cachename.lock().unwrap();
$crate::Cached::cache_set(&mut *cache, key, val.clone());
val
}
};
($cachename:ident : $cachetype:ident >> fn $name:ident ($($arg:ident : $argtype:ty),*) -> $ret:ty = $body:expr) => {
lazy_static! {
static ref $cachename: ::std::sync::Mutex<$cachetype<($($argtype),*), $ret>> = {
::std::sync::Mutex::new($cachetype::new())
};
}
#[allow(unused_parens)]
pub fn $name($($arg: $argtype),*) -> $ret {
let key = ($($arg.clone()),*);
{
let mut cache = $cachename.lock().unwrap();
let res = $crate::Cached::cache_get(&mut *cache, &key);
if let Some(res) = res { return res.clone(); }
}
let val = (||$body)();
let mut cache = $cachename.lock().unwrap();
$crate::Cached::cache_set(&mut *cache, key, val.clone());
val
}
};
($cachename:ident : $cachetype:ident = $cacheinstance:expr ; >> fn $name:ident ($($arg:ident : $argtype:ty),*) -> $ret:ty = $body:expr) => {
lazy_static! {
static ref $cachename: ::std::sync::Mutex<$cachetype<($($argtype),*), $ret>> = {
::std::sync::Mutex::new($cacheinstance)
};
}
#[allow(unused_parens)]
pub fn $name($($arg: $argtype),*) -> $ret {
let key = ($($arg.clone()),*);
{
let mut cache = $cachename.lock().unwrap();
let res = $crate::Cached::cache_get(&mut *cache, &key);
if let Some(res) = res { return res.clone(); }
}
let val = (||$body)();
let mut cache = $cachename.lock().unwrap();
$crate::Cached::cache_set(&mut *cache, key, val.clone());
val
}
};
}