use chrono::{DateTime, Datelike, TimeZone, Timelike, Utc};
use mlua::prelude::*;
pub fn timestamp_to_table(lua: &Lua, ts: DateTime<Utc>) -> LuaResult<LuaTable> {
let table = lua.create_table()?;
table.raw_set("year", ts.year())?;
table.raw_set("month", ts.month())?;
table.raw_set("day", ts.day())?;
table.raw_set("hour", ts.hour())?;
table.raw_set("min", ts.minute())?;
table.raw_set("sec", ts.second())?;
table.raw_set("nanosec", ts.nanosecond())?;
table.raw_set("yday", ts.ordinal())?;
table.raw_set("wday", ts.weekday().number_from_sunday())?;
table.raw_set("isdst", false)?;
Ok(table)
}
pub fn table_is_timestamp(t: &LuaTable) -> LuaResult<bool> {
for &key in &["year", "month", "day", "hour", "min", "sec"] {
if !t.contains_key(key)? {
return Ok(false);
}
}
Ok(true)
}
#[allow(clippy::needless_pass_by_value)] pub fn table_to_timestamp(t: LuaTable) -> LuaResult<DateTime<Utc>> {
let year = t.raw_get("year")?;
let month = t.raw_get("month")?;
let day = t.raw_get("day")?;
let hour = t.raw_get("hour")?;
let min = t.raw_get("min")?;
let sec = t.raw_get("sec")?;
let nano = t.raw_get::<Option<u32>>("nanosec")?.unwrap_or(0);
Ok(Utc
.with_ymd_and_hms(year, month, day, hour, min, sec)
.single()
.and_then(|t| t.with_nanosecond(nano))
.expect("invalid timestamp"))
}