| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 | use crate::{cmd, db::Db, dispatcher, error::Error, value::Value};use bytes::Bytes;use std::convert::TryInto;use std::time::SystemTime;use std::time::UNIX_EPOCH;fn do_time(_db: &Db, _args: &[Bytes]) -> Result<Value, Error> {    let now = SystemTime::now();    let since_the_epoch = now.duration_since(UNIX_EPOCH).expect("Time went backwards");    let seconds = format!("{}", since_the_epoch.as_secs());    let millis = format!("{}", since_the_epoch.subsec_millis());    Ok(vec![seconds.as_str(), millis.as_str()].into())}fn do_command(_db: &Db, _args: &[Bytes]) -> Result<Value, Error> {    let now = SystemTime::now();    let since_the_epoch = now.duration_since(UNIX_EPOCH).expect("Time went backwards");    let in_ms: i128 =        since_the_epoch.as_secs() as i128 * 1000 + since_the_epoch.subsec_millis() as i128;    Ok(format!("{}", in_ms).as_str().into())}dispatcher! {    command  {        do_command,        ["random" "loading" "stale"],        1,    },    incr {        cmd::string::incr,        ["write" "denyoom" "fast"],        2,    },    decr {        cmd::string::decr,        ["write" "denyoom" "fast"],        2,    },    get {        cmd::string::get,        ["random" "loading" "stale"],        2,    },    set {        cmd::string::set,        ["random" "loading" "stale"],        -3,    },    getset {        cmd::string::getset,        ["random" "loading" "stale"],        -3,    },    time {        do_time,        ["random" "loading" "stale"],        1,    },}
 |