Going to a more generic equality comparison for json.
This commit is contained in:
parent
6297fa0189
commit
46bb5558ac
16
src/bin.rs
16
src/bin.rs
@ -143,26 +143,16 @@ impl Loopable for serde_json::Value {
|
||||
|
||||
impl CompareContextElement for serde_json::Value {
|
||||
fn equals(&self, other: &dyn ContextElement) -> bool {
|
||||
match self {
|
||||
serde_json::Value::Null => false,
|
||||
serde_json::Value::Bool(boolean) => false,
|
||||
serde_json::Value::Number(_num) => false,
|
||||
serde_json::Value::String(string_value) => {
|
||||
// Handle json string
|
||||
// Handle other serde_json::Value
|
||||
match other.to_any().downcast_ref::<Self>() {
|
||||
None => (),
|
||||
Some(other_json_value) => return self == other_json_value,
|
||||
}
|
||||
// Handle rust string (for string literals)
|
||||
// Handle string literals
|
||||
match other.to_any().downcast_ref::<String>() {
|
||||
None => (),
|
||||
Some(other_string) => return string_value == other_string,
|
||||
Some(other_string) => return self.as_str().map_or(false, |s| s == other_string),
|
||||
}
|
||||
// Otherwise we know of no other string types
|
||||
false
|
||||
}
|
||||
serde_json::Value::Array(array_value) => false,
|
||||
serde_json::Value::Object(_obj) => false,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user