rfluids 0.3.1

🦀 Rusty CoolProp wrapper
Documentation
use std::collections::HashMap;

use super::{HumidAirOutputError, OutputResult, request::HumidAirUpdateRequest};
use crate::{io::HumidAirParam, native::CoolProp};

pub(crate) fn cached_output(
    cache: &mut HashMap<HumidAirParam, OutputResult<f64>>,
    key: HumidAirParam,
    request: HumidAirUpdateRequest,
) -> OutputResult<f64> {
    match cache
        .entry(key)
        .or_insert_with(|| {
            CoolProp::ha_props_si(
                key,
                request.0.key,
                request.0.value,
                request.1.key,
                request.1.value,
                request.2.key,
                request.2.value,
            )
            .map_err(|e| HumidAirOutputError::CalculationFailed(key, e))
        })
        .as_ref()
    {
        Ok(&x) => Ok(x),
        Err(e) => Err(e.clone()),
    }
}

pub(crate) fn guard(key: HumidAirParam, value: f64, ok: fn(f64) -> bool) -> OutputResult<f64> {
    if ok(value) {
        return Ok(value);
    }
    Err(HumidAirOutputError::UnavailableOutput(key))
}

#[cfg(test)]
pub(crate) mod tests {
    use rstest::*;

    use super::*;

    #[rstest]
    #[case(
        HumidAirParam::W, -1.0, Err(HumidAirOutputError::UnavailableOutput(HumidAirParam::W))
    )]
    #[case(HumidAirParam::W, 0.0, Ok(0.0))]
    #[case(HumidAirParam::W, 1.0, Ok(1.0))]
    fn guard(#[case] key: HumidAirParam, #[case] value: f64, #[case] expected: OutputResult<f64>) {
        // When
        let res = super::guard(key, value, |x| x >= 0.0);

        // Then
        assert_eq!(res, expected);
    }
}