Merge pull request #40 from jonathandturner/master

Some fixes for the new evaluator
This commit is contained in:
Jonathan Turner 2019-05-28 19:20:24 +12:00 committed by GitHub
commit 2afa785e0e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 454 additions and 398 deletions

View File

@ -426,6 +426,7 @@ crate fn find(obj: &Value, field: &str, op: &Operator, rhs: &Value) -> bool {
enum CompareValues { enum CompareValues {
Ints(i64, i64), Ints(i64, i64),
Floats(OF64, OF64),
Bytes(i128, i128), Bytes(i128, i128),
String(String, String), String(String, String),
} }
@ -434,6 +435,7 @@ impl CompareValues {
fn compare(&self) -> std::cmp::Ordering { fn compare(&self) -> std::cmp::Ordering {
match self { match self {
CompareValues::Ints(left, right) => left.cmp(right), CompareValues::Ints(left, right) => left.cmp(right),
CompareValues::Floats(left, right) => left.cmp(right),
CompareValues::Bytes(left, right) => left.cmp(right), CompareValues::Bytes(left, right) => left.cmp(right),
CompareValues::String(left, right) => left.cmp(right), CompareValues::String(left, right) => left.cmp(right),
} }
@ -453,6 +455,8 @@ fn coerce_compare_primitive(left: &Primitive, right: &Primitive) -> Option<Compa
match (left, right) { match (left, right) {
(Int(left), Int(right)) => Some(CompareValues::Ints(*left, *right)), (Int(left), Int(right)) => Some(CompareValues::Ints(*left, *right)),
(Float(left), Int(right)) => Some(CompareValues::Floats(*left, (*right as f64).into())),
(Int(left), Float(right)) => Some(CompareValues::Floats((*left as f64).into(), *right)),
(Int(left), Bytes(right)) => Some(CompareValues::Bytes(*left as i128, *right as i128)), (Int(left), Bytes(right)) => Some(CompareValues::Bytes(*left as i128, *right as i128)),
(Bytes(left), Int(right)) => Some(CompareValues::Bytes(*left as i128, *right as i128)), (Bytes(left), Int(right)) => Some(CompareValues::Bytes(*left as i128, *right as i128)),
(String(left), String(right)) => Some(CompareValues::String(left.clone(), right.clone())), (String(left), String(right)) => Some(CompareValues::String(left.clone(), right.clone())),

View File

@ -17,6 +17,7 @@ Command: ParsedCommand = {
Leaf: Expression = { Leaf: Expression = {
<String> => Expression::Leaf(Leaf::String(<>)), <String> => Expression::Leaf(Leaf::String(<>)),
<Num> => Expression::Leaf(Leaf::Int(<>)), <Num> => Expression::Leaf(Leaf::Int(<>)),
<Size> => Expression::Leaf(Leaf::Int(<>)),
<Variable> => Expression::VariableReference(<>), <Variable> => Expression::VariableReference(<>),
} }

File diff suppressed because it is too large Load Diff