2021-03-29 15:43:37 +00:00
|
|
|
use crate::err::Error;
|
|
|
|
use crate::sql::value::Value;
|
2022-01-13 17:37:46 +00:00
|
|
|
use std::ops::Add;
|
|
|
|
use std::ops::Div;
|
|
|
|
use std::ops::Mul;
|
|
|
|
use std::ops::Sub;
|
2021-03-29 15:43:37 +00:00
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn or(a: Value, b: Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(match a.is_truthy() {
|
|
|
|
true => a,
|
|
|
|
false => b,
|
|
|
|
})
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn and(a: Value, b: Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(match a.is_truthy() {
|
|
|
|
true => b,
|
|
|
|
false => a,
|
|
|
|
})
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-12-02 21:48:10 +00:00
|
|
|
pub fn tco(a: Value, b: Value) -> Result<Value, Error> {
|
|
|
|
Ok(match a.is_truthy() {
|
|
|
|
true => a,
|
|
|
|
false => b,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn nco(a: Value, b: Value) -> Result<Value, Error> {
|
|
|
|
Ok(match a.is_some() {
|
|
|
|
true => a,
|
|
|
|
false => b,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn add(a: Value, b: Value) -> Result<Value, Error> {
|
|
|
|
Ok(a.add(b))
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn sub(a: Value, b: Value) -> Result<Value, Error> {
|
|
|
|
Ok(a.sub(b))
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn mul(a: Value, b: Value) -> Result<Value, Error> {
|
|
|
|
Ok(a.mul(b))
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn div(a: Value, b: Value) -> Result<Value, Error> {
|
|
|
|
Ok(a.div(b))
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn exact(a: &Value, b: &Value) -> Result<Value, Error> {
|
|
|
|
Ok(Value::from(a == b))
|
2021-05-17 17:00:17 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn equal(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.equal(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn not_equal(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!a.equal(b)).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn all_equal(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.all_equal(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn any_equal(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.any_equal(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn like(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.fuzzy(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn not_like(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!a.fuzzy(b)).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn all_like(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.all_fuzzy(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn any_like(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.any_fuzzy(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn less_than(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.lt(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn less_than_or_equal(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.le(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn more_than(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.gt(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn more_than_or_equal(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.ge(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn contain(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.contains(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn not_contain(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!a.contains(b)).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn contain_all(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.contains_all(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn contain_any(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.contains_any(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn contain_none(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!a.contains_any(b)).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn inside(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(b.contains(a).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn not_inside(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!b.contains(a)).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn inside_all(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(b.contains_all(a).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn inside_any(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(b.contains_any(a).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn inside_none(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!b.contains_any(a)).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-04-29 20:41:57 +00:00
|
|
|
pub fn outside(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok((!a.intersects(b)).into())
|
2022-04-29 20:41:57 +00:00
|
|
|
}
|
|
|
|
|
2022-01-13 17:37:46 +00:00
|
|
|
pub fn intersects(a: &Value, b: &Value) -> Result<Value, Error> {
|
2022-09-01 00:27:52 +00:00
|
|
|
Ok(a.intersects(b).into())
|
2021-03-29 15:43:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn or_true() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(2);
|
2021-03-29 15:43:37 +00:00
|
|
|
let res = or(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn or_false_one() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(0);
|
|
|
|
let two = Value::from(1);
|
2021-03-29 15:43:37 +00:00
|
|
|
let res = or(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn or_false_two() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(0);
|
2021-03-29 15:43:37 +00:00
|
|
|
let res = or(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn and_true() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(2);
|
2021-03-29 15:43:37 +00:00
|
|
|
let res = and(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("2", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn and_false_one() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(0);
|
|
|
|
let two = Value::from(1);
|
2021-03-29 15:43:37 +00:00
|
|
|
let res = and(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("0", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn and_false_two() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(0);
|
2021-03-29 15:43:37 +00:00
|
|
|
let res = and(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("0", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
2022-12-02 21:48:10 +00:00
|
|
|
#[test]
|
|
|
|
fn tco_true() {
|
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(2);
|
|
|
|
let res = tco(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn tco_false_one() {
|
|
|
|
let one = Value::from(0);
|
|
|
|
let two = Value::from(1);
|
|
|
|
let res = tco(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn tco_false_two() {
|
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(0);
|
|
|
|
let res = tco(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn nco_true() {
|
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::from(2);
|
|
|
|
let res = nco(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn nco_false_one() {
|
|
|
|
let one = Value::None;
|
|
|
|
let two = Value::from(1);
|
|
|
|
let res = nco(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn nco_false_two() {
|
|
|
|
let one = Value::from(1);
|
|
|
|
let two = Value::None;
|
|
|
|
let res = nco(one, two);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
2021-03-29 15:43:37 +00:00
|
|
|
#[test]
|
|
|
|
fn add_basic() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(5);
|
|
|
|
let two = Value::from(4);
|
|
|
|
let res = add(one, two);
|
2021-03-29 15:43:37 +00:00
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("9", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn sub_basic() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(5);
|
|
|
|
let two = Value::from(4);
|
|
|
|
let res = sub(one, two);
|
2021-03-29 15:43:37 +00:00
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn mul_basic() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(5);
|
|
|
|
let two = Value::from(4);
|
|
|
|
let res = mul(one, two);
|
2021-03-29 15:43:37 +00:00
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("20", format!("{}", out));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn div_basic() {
|
2022-01-13 17:37:46 +00:00
|
|
|
let one = Value::from(5);
|
|
|
|
let two = Value::from(4);
|
|
|
|
let res = div(one, two);
|
2021-03-29 15:43:37 +00:00
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap();
|
|
|
|
assert_eq!("1.25", format!("{}", out));
|
|
|
|
}
|
|
|
|
}
|