Reimplement FieldIsType filter with FieldPredicate filter
This commit is contained in:
parent
f86a8968a4
commit
564d8d84fe
1 changed files with 17 additions and 8 deletions
|
@ -1,6 +1,8 @@
|
||||||
use libimagstore::store::Entry;
|
use libimagstore::store::Entry;
|
||||||
|
|
||||||
use builtin::header::field_path::FieldPath;
|
use builtin::header::field_path::FieldPath;
|
||||||
|
use builtin::header::field_predicate::FieldPredicate;
|
||||||
|
use builtin::header::field_predicate::Predicate;
|
||||||
use filter::Filter;
|
use filter::Filter;
|
||||||
|
|
||||||
use toml::Value;
|
use toml::Value;
|
||||||
|
@ -31,17 +33,27 @@ impl Type {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct IsTypePred {
|
||||||
|
ty: Type
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Predicate for IsTypePred {
|
||||||
|
|
||||||
|
fn evaluate(&self, v: Value) -> bool {
|
||||||
|
self.ty.matches(&v)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
pub struct FieldIsType {
|
pub struct FieldIsType {
|
||||||
header_field_path: FieldPath,
|
filter: FieldPredicate<IsTypePred>,
|
||||||
expected_type: Type,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FieldIsType {
|
impl FieldIsType {
|
||||||
|
|
||||||
pub fn new(path: FieldPath, expected_type: Type) -> FieldIsType {
|
pub fn new(path: FieldPath, expected_type: Type) -> FieldIsType {
|
||||||
FieldIsType {
|
FieldIsType {
|
||||||
header_field_path: path,
|
filter: FieldPredicate::new(path, Box::new(IsTypePred { ty: expected_type })),
|
||||||
expected_type: expected_type,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,10 +62,7 @@ impl FieldIsType {
|
||||||
impl Filter for FieldIsType {
|
impl Filter for FieldIsType {
|
||||||
|
|
||||||
fn filter(&self, e: &Entry) -> bool {
|
fn filter(&self, e: &Entry) -> bool {
|
||||||
e.get_header()
|
self.filter.filter(e)
|
||||||
.read(&self.header_field_path[..])
|
|
||||||
.map(|val| val.map(|v| self.expected_type.matches(&v)).unwrap_or(false))
|
|
||||||
.unwrap_or(false)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue