grass/src/builtin/math.rs
2020-02-16 10:14:17 -05:00

52 lines
1.9 KiB
Rust

use std::collections::BTreeMap;
use super::Builtin;
use crate::units::Unit;
use crate::value::{Number, Value};
pub(crate) fn register(f: &mut BTreeMap<String, Builtin>) {
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)))
});
}