use std::collections::BTreeMap; use super::Builtin; use crate::units::Unit; use crate::value::{Number, Value}; pub(crate) fn register(f: &mut BTreeMap) { decl!(f "percentage", |args, _| { let num = match arg!(args, 0, "number").eval() { Value::Dimension(n, Unit::None) => n * Number::from(100), _ => todo!("expected unitless number in builtin function `percentage()`") }; Ok(Value::Dimension(num, Unit::Percent)) }); decl!(f "round", |args, _| { match arg!(args, 0, "number").eval() { Value::Dimension(n, u) => Ok(Value::Dimension(n.round(), u)), _ => todo!("expected number in builtin function `round()`") } }); decl!(f "ceil", |args, _| { match arg!(args, 0, "number").eval() { Value::Dimension(n, u) => Ok(Value::Dimension(n.ceil(), u)), _ => todo!("expected number in builtin function `ceil()`") } }); decl!(f "floor", |args, _| { match arg!(args, 0, "number").eval() { Value::Dimension(n, u) => Ok(Value::Dimension(n.floor(), u)), _ => todo!("expected number in builtin function `floor()`") } }); decl!(f "abs", |args, _| { match arg!(args, 0, "number").eval() { Value::Dimension(n, u) => Ok(Value::Dimension(n.abs(), u)), _ => todo!("expected number in builtin function `abs()`") } }); decl!(f "comparable", |args, _| { let unit1 = match arg!(args, 0, "number1").eval() { Value::Dimension(_, u) => u, _ => todo!("$number1: ___ is not a number.") }; let unit2 = match arg!(args, 1, "number2").eval() { Value::Dimension(_, u) => u, _ => todo!("$number2: ____ is not a number.") }; Ok(Value::bool(unit1.comparable(&unit2))) }); }