1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
|
// Copyright (C) 2021-2022 Soni L.
// SPDX-License-Identifier: MIT OR Apache-2.0
use serde_json::Deserializer as JsonDer;
use serde::Deserialize;
#[test]
fn test_basic() {
let mut der = JsonDer::from_str(r#"{"foo": 1, "bar": {"baz": 2}}"#);
let preds = vec![("dict", datafu::pred(|v| { todo!() }))].into_iter().collect();
let pat = datafu::Pattern::<()>::compile::<&str, &str>("->[x]:?$dict->y[yk]", Some(preds), None).unwrap();
#[derive(Deserialize)]
struct Values {
x: String,
yk: String,
y: usize,
}
// should this error about needing multiple results/Vec requirement?
let matches: Values = pat.deserialize(&mut der).unwrap();
assert_eq!(matches.x, "bar");
assert_eq!(matches.yk, "baz");
assert_eq!(matches.y, 2);
assert!(der.end().is_ok());
}
//#[test]
//fn test_str() {
// //let tree = Value::M(vec![
// // ("foo".into(), Value::U(1)),
// // ("bar".into(), Value::M(vec![
// // ("baz".into(), Value::U(2)),
// // ].into_iter().collect())),
// //].into_iter().collect());
// let der = JsonDer::from_str(r#"{"foo": 1, "bar": {"baz": 2}}"#)
// let preds = vec![("dict", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::M(_)))) as Box<datafu::Predicate<Value>>)].into_iter().collect();
// let pat = datafu::Pattern::<Value>::compile::<&str, &str>("->X'bar'->Y", Some(preds), None).unwrap();
// let mut matcher = pat.attempt_match(&tree);
// let m = matcher.next().unwrap().unwrap();
// assert_eq!(m["X"].0, RefOwn::Ref(&Value::from("bar")));
// assert_eq!(m["Y"].0, RefOwn::Ref(&Value::from("baz")));
// assert_eq!(m["Y"].1, RefOwn::Ref(&Value::U(2)));
// assert!(matcher.next().is_none());
//}
//
//#[test]
//fn test_basic_2() {
// let tree = Value::M(vec![
// ("projects".into(), Value::M(vec![
// ("385e734a52e13949a7a5c71827f6de920dbfea43".into(), Value::M(vec![
// ("https://soniex2.autistic.space/git-repos/ganarchy.git".into(), Value::M(vec![
// ("HEAD".into(), Value::M(vec![
// ("active".into(), Value::B(true)),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect());
// let preds = vec![("d", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::M(_)))) as Box<datafu::Predicate<Value>>)].into_iter().collect();
// let pat = datafu::Pattern::<Value>::compile::<&str, &str>("->'projects':?$d->P/[0-9a-fA-F]{40}|[0-9a-fA-F]{64}/?:?$d->U:?$d->B", Some(preds), None).unwrap();
// let mut matcher = pat.attempt_match(&tree);
// let m = matcher.next().unwrap().unwrap();
// assert_eq!(m["P"].0, RefOwn::Ref(&Value::from("385e734a52e13949a7a5c71827f6de920dbfea43")));
// assert_eq!(m["U"].0, RefOwn::Ref(&Value::from("https://soniex2.autistic.space/git-repos/ganarchy.git")));
// assert_eq!(m["B"].0, RefOwn::Ref(&Value::from("HEAD")));
// assert_eq!(m["B"].1, RefOwn::Ref(&Value::M(vec![(Value::from("active"), Value::B(true))].into_iter().collect())));
// assert!(matcher.next().is_none());
//}
//
//#[test]
//fn test_spaces() {
// let tree = Value::M(vec![
// ("projects".into(), Value::M(vec![
// ("385e734a52e13949a7a5c71827f6de920dbfea43".into(), Value::M(vec![
// ("https://soniex2.autistic.space/git-repos/ganarchy.git".into(), Value::M(vec![
// ("HEAD".into(), Value::M(vec![
// ("active".into(), Value::B(true)),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect());
// let preds = vec![("dict", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::M(_)))) as Box<datafu::Predicate<Value>>)].into_iter().collect();
// let pat = datafu::Pattern::<Value>::compile::<_, &str>("
// -> 'projects'?
// -> commit /[0-9a-fA-F]{40}|[0-9a-fA-F]{64}/? :?$dict
// -> url :?$dict
// -> branch :?$dict",
// Some(preds),
// None,
// ).unwrap();
// let mut matcher = pat.attempt_match(&tree);
// let m = matcher.next().unwrap().unwrap();
// assert_eq!(m["commit"].0, RefOwn::Ref(&Value::from("385e734a52e13949a7a5c71827f6de920dbfea43")));
// assert_eq!(m["url"].0, RefOwn::Ref(&Value::from("https://soniex2.autistic.space/git-repos/ganarchy.git")));
// assert_eq!(m["branch"].0, RefOwn::Ref(&Value::from("HEAD")));
// assert_eq!(m["branch"].1, RefOwn::Ref(&Value::M(vec![(Value::from("active"), Value::B(true))].into_iter().collect())));
// assert!(matcher.next().is_none());
//}
//
//#[test]
//fn test_harder() {
// let tree = Value::M(vec![
// ("projects".into(), Value::M(vec![
// ("385e734a52e13949a7a5c71827f6de920dbfea43".into(), Value::M(vec![
// ("https://soniex2.autistic.space/git-repos/ganarchy.git".into(), Value::M(vec![
// ("HEAD".into(), Value::M(vec![
// ("active".into(), Value::B(true)),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect())),
// ].into_iter().collect());
// let preds = vec![
// ("dict", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::M(_)))) as Box<datafu::Predicate<Value>>),
// ("str", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::S(_)))) as Box<datafu::Predicate<Value>>),
// ("bool", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::B(_)))) as Box<datafu::Predicate<Value>>),
// // stubs, we don't particularly need to test these
// ("commit", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::S(_)))) as Box<datafu::Predicate<Value>>),
// ("uri", Box::new(|v: RefOwn<'_, _, _>| matches!(v, RefOwn::Ref(&Value::S(_)))) as Box<datafu::Predicate<Value>>),
// ].into_iter().collect();
// let pat = datafu::Pattern::<Value>::compile::<_, &str>("
// ->'projects':$dict
// ->commit[:?$str:?$commit]:?$dict
// ->url[:?$str:?$uri]:?$dict
// ->branch:?$dict
// (->active'active'?:?$bool)
// (->federate'federate'?:?$bool)?",
// Some(preds),
// None,
// ).unwrap();
// let mut matcher = pat.attempt_match(&tree);
// let m = matcher.next().unwrap().unwrap();
// assert_eq!(m["commit"].0, RefOwn::Ref(&Value::from("385e734a52e13949a7a5c71827f6de920dbfea43")));
// assert_eq!(m["url"].0, RefOwn::Ref(&Value::from("https://soniex2.autistic.space/git-repos/ganarchy.git")));
// assert_eq!(m["branch"].0, RefOwn::Ref(&Value::from("HEAD")));
// assert_eq!(m["active"].1, RefOwn::Ref(&Value::B(true)));
// assert_eq!(m.get("federate"), None);
// assert!(matcher.next().is_none());
//}
|