rhai/src/packages/logic.rs

109 lines
2.9 KiB
Rust
Raw Normal View History

2021-02-13 16:01:34 +01:00
#![allow(non_snake_case)]
2020-04-21 17:01:10 +02:00
use crate::def_package;
2020-08-14 07:43:26 +02:00
use crate::plugin::*;
2020-04-24 06:39:24 +02:00
2021-02-13 16:01:34 +01:00
#[cfg(feature = "decimal")]
use rust_decimal::Decimal;
2020-11-04 05:34:34 +01:00
#[cfg(any(
not(feature = "no_float"),
all(not(feature = "only_i32"), not(feature = "only_i64"))
))]
2020-08-14 07:43:26 +02:00
macro_rules! gen_cmp_functions {
2020-08-20 16:11:41 +02:00
($root:ident => $($arg_type:ident),+) => {
mod $root { $(pub mod $arg_type {
use super::super::*;
#[export_module]
pub mod functions {
#[rhai_fn(name = "<")]
pub fn lt(x: $arg_type, y: $arg_type) -> bool {
x < y
}
#[rhai_fn(name = "<=")]
pub fn lte(x: $arg_type, y: $arg_type) -> bool {
x <= y
}
#[rhai_fn(name = ">")]
pub fn gt(x: $arg_type, y: $arg_type) -> bool {
x > y
}
#[rhai_fn(name = ">=")]
pub fn gte(x: $arg_type, y: $arg_type) -> bool {
x >= y
}
#[rhai_fn(name = "==")]
pub fn eq(x: $arg_type, y: $arg_type) -> bool {
x == y
}
#[rhai_fn(name = "!=")]
pub fn ne(x: $arg_type, y: $arg_type) -> bool {
x != y
2020-08-14 07:43:26 +02:00
}
}
})* }
2020-08-20 16:11:41 +02:00
};
}
2020-11-04 05:34:34 +01:00
#[cfg(any(
not(feature = "no_float"),
all(not(feature = "only_i32"), not(feature = "only_i64"))
))]
2020-08-14 07:43:26 +02:00
macro_rules! reg_functions {
2020-08-24 16:37:44 +02:00
($mod_name:ident += $root:ident ; $($arg_type:ident),+) => { $(
2020-09-13 16:12:11 +02:00
combine_with_exported_module!($mod_name, "logic", $root::$arg_type::functions);
2020-08-24 16:37:44 +02:00
)* }
}
2020-04-22 08:55:40 +02:00
def_package!(crate:LogicPackage:"Logical operators.", lib, {
2020-08-14 07:43:26 +02:00
#[cfg(not(feature = "only_i32"))]
#[cfg(not(feature = "only_i64"))]
{
2020-08-20 16:11:41 +02:00
reg_functions!(lib += numbers; i8, u8, i16, u16, i32, u32, u64);
2020-06-17 10:50:46 +02:00
2020-08-14 07:43:26 +02:00
#[cfg(not(target_arch = "wasm32"))]
2020-08-20 16:11:41 +02:00
reg_functions!(lib += num_128; i128, u128);
}
2020-04-21 17:01:10 +02:00
#[cfg(not(feature = "no_float"))]
2020-11-04 05:34:34 +01:00
{
#[cfg(not(feature = "f32_float"))]
reg_functions!(lib += float; f32);
#[cfg(feature = "f32_float")]
reg_functions!(lib += float; f64);
}
2021-02-13 16:01:34 +01:00
#[cfg(feature = "decimal")]
reg_functions!(lib += decimal; Decimal);
2020-08-14 07:43:26 +02:00
set_exported_fn!(lib, "!", not);
2020-04-21 17:01:10 +02:00
});
2020-08-14 07:43:26 +02:00
// Logic operators
#[export_fn]
fn not(x: bool) -> bool {
!x
}
#[cfg(not(feature = "only_i32"))]
#[cfg(not(feature = "only_i64"))]
2020-08-20 16:11:41 +02:00
gen_cmp_functions!(numbers => i8, u8, i16, u16, i32, u32, u64);
2020-08-14 07:43:26 +02:00
#[cfg(not(feature = "only_i32"))]
#[cfg(not(feature = "only_i64"))]
#[cfg(not(target_arch = "wasm32"))]
2020-08-20 16:11:41 +02:00
gen_cmp_functions!(num_128 => i128, u128);
2020-08-14 07:43:26 +02:00
#[cfg(not(feature = "no_float"))]
2020-11-04 05:34:34 +01:00
#[cfg(not(feature = "f32_float"))]
2020-08-20 16:11:41 +02:00
gen_cmp_functions!(float => f32);
2020-11-04 05:34:34 +01:00
#[cfg(not(feature = "no_float"))]
#[cfg(feature = "f32_float")]
gen_cmp_functions!(float => f64);
2021-02-13 16:01:34 +01:00
#[cfg(feature = "decimal")]
gen_cmp_functions!(decimal => Decimal);