diff options
author | iximeow <git@iximeow.net> | 2022-12-29 19:08:35 +0000 |
---|---|---|
committer | iximeow <git@iximeow.net> | 2022-12-29 19:08:35 +0000 |
commit | fb64c0fb491b5a4d481e1a32efb57199f6bd89c2 (patch) | |
tree | e0c6d46e0378640ca18dccdd12a583d9e61ba287 | |
parent | 0832c96c116f4c3a28bd22a0cdd287a3b0764c7b (diff) |
allow goodfiles to query current time
-rw-r--r-- | src/lua/mod.rs | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/lua/mod.rs b/src/lua/mod.rs index f186e6b..8f14b9a 100644 --- a/src/lua/mod.rs +++ b/src/lua/mod.rs @@ -4,6 +4,7 @@ use rlua::prelude::*; use std::sync::{Arc, Mutex}; use std::path::PathBuf; +use std::time::{UNIX_EPOCH, SystemTime}; pub const DEFAULT_RUST_GOODFILE: &'static [u8] = include_bytes!("../../config/goodfiles/rust.lua"); @@ -142,6 +143,15 @@ impl BuildEnv { }) .map_err(|e| format!("problem defining metric function: {:?}", e))?; + let now_ms = lua_ctx.create_function(move |_, ()| { + let now = SystemTime::now(); + Ok(now + .duration_since(UNIX_EPOCH) + .expect("now is later than epoch") + .as_millis() as u64) + }) + .map_err(|e| format!("problem defining now_ms function: {:?}", e))?; + let job_ref = Arc::clone(&self.job); let artifact = lua_ctx.create_function(move |_, (path, name): (String, Option<String>)| { let path: PathBuf = path.into(); @@ -214,6 +224,7 @@ impl BuildEnv { ("metric", metric), ("error", error), ("artifact", artifact), + ("now_ms", now_ms), ] ).unwrap(); build_functions.set("environment", build_environment).unwrap(); |