use super::maintenance::MaintenanceRatio;
use derive_more::Into;
use nil_util::{ConstDeref, F64Math};
use serde::{Deserialize, Serialize};
use std::ops::Mul;
#[derive(Copy, Debug, Into, Deserialize, Serialize, ConstDeref, F64Math)]
#[derive_const(Clone, PartialEq, Eq, PartialOrd, Ord)]
#[cfg_attr(feature = "typescript", derive(ts_rs::TS))]
pub struct Cost(u32);
impl Cost {
#[inline]
pub const fn new(value: u32) -> Self {
Self(value)
}
}
impl const From<f64> for Cost {
fn from(value: f64) -> Self {
debug_assert!(value.is_finite());
debug_assert!(value >= 0.0);
Self::new(value as u32)
}
}
impl const From<Cost> for f64 {
fn from(value: Cost) -> Self {
f64::from(value.0)
}
}
impl const Mul<ResourceRatio> for Cost {
type Output = f64;
fn mul(self, rhs: ResourceRatio) -> Self::Output {
self * rhs.0
}
}
impl const Mul<MaintenanceRatio> for Cost {
type Output = f64;
fn mul(self, rhs: MaintenanceRatio) -> Self::Output {
self * f64::from(rhs)
}
}
#[derive(Copy, Debug, Deserialize, Serialize, ConstDeref, F64Math)]
#[derive_const(Clone, PartialEq, PartialOrd)]
#[cfg_attr(feature = "typescript", derive(ts_rs::TS))]
pub struct ResourceRatio(f64);
impl ResourceRatio {
#[inline]
pub const fn new(value: f64) -> Self {
debug_assert!(value.is_finite());
Self(value.clamp(0.0, 1.0))
}
}
impl const From<ResourceRatio> for f64 {
fn from(value: ResourceRatio) -> Self {
value.0
}
}
#[doc(hidden)]
#[macro_export]
macro_rules! check_total_resource_ratio {
($first:expr, $($other:expr),+ $(,)?) => {
const _: () = {
let mut first = f64::from($first);
$(first += f64::from($other);)+
assert!((first - 1.0).abs() < 0.001);
};
};
}