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
140
use std::borrow::Cow;
use std::cell::RefCell;
use std::rc::Rc;
use deser::de::{DeserializerState, MapSink, SeqSink, Sink, SinkHandle};
use deser::{Atom, Error};
use crate::{Path, PathSegment};
pub struct PathSink<'a> {
sink: SinkHandle<'a>,
set_segment: Option<PathSegment>,
}
impl<'a> PathSink<'a> {
pub fn wrap(sink: &'a mut dyn Sink) -> PathSink<'a> {
PathSink::wrap_ref(SinkHandle::to(sink))
}
pub fn wrap_ref(sink: SinkHandle<'a>) -> PathSink<'a> {
PathSink {
sink,
set_segment: None,
}
}
fn set_segment(&mut self, state: &DeserializerState) {
if let Some(segment) = self.set_segment.take() {
*state.get_mut::<Path>().segments.last_mut().unwrap() = segment;
}
}
}
impl<'a> Sink for PathSink<'a> {
fn atom(&mut self, atom: Atom, state: &DeserializerState) -> Result<(), Error> {
self.set_segment(state);
self.sink.atom(atom, state)
}
fn map(&mut self, state: &DeserializerState) -> Result<Box<dyn MapSink + '_>, Error> {
self.set_segment(state);
state.get_mut::<Path>().segments.push(PathSegment::Index(0));
Ok(Box::new(PathTrackingMapSink {
sink: self.sink.map(state)?,
captured_segment: Rc::default(),
}))
}
fn seq(&mut self, state: &DeserializerState) -> Result<Box<dyn SeqSink + '_>, Error> {
self.set_segment(state);
state.get_mut::<Path>().segments.push(PathSegment::Index(0));
Ok(Box::new(PathTrackingSeqSink {
sink: self.sink.seq(state)?,
index: 0,
}))
}
fn expecting(&self) -> Cow<'_, str> {
self.sink.expecting()
}
}
struct PathTrackingMapSink<'a> {
sink: Box<dyn MapSink + 'a>,
captured_segment: Rc<RefCell<Option<PathSegment>>>,
}
impl<'a> MapSink for PathTrackingMapSink<'a> {
fn key(&mut self) -> Result<SinkHandle, Error> {
Ok(SinkHandle::boxed(KeyCapturingSink {
sink: self.sink.key()?,
captured_segment: self.captured_segment.clone(),
}))
}
fn value(&mut self) -> Result<SinkHandle, Error> {
Ok(SinkHandle::boxed(PathSink {
sink: self.sink.value()?,
set_segment: self.captured_segment.take(),
}))
}
fn finish(&mut self, state: &DeserializerState) -> Result<(), Error> {
state.get_mut::<Path>().segments.pop();
self.sink.finish(state)
}
}
struct PathTrackingSeqSink<'a> {
sink: Box<dyn SeqSink + 'a>,
index: usize,
}
impl<'a> SeqSink for PathTrackingSeqSink<'a> {
fn item(&mut self) -> Result<SinkHandle, Error> {
let sink_wrapper = PathSink {
sink: self.sink.item()?,
set_segment: Some(PathSegment::Index(self.index)),
};
Ok(SinkHandle::boxed(sink_wrapper))
}
fn finish(&mut self, state: &DeserializerState) -> Result<(), Error> {
state.get_mut::<Path>().segments.pop();
self.sink.finish(state)
}
}
struct KeyCapturingSink<'a> {
sink: SinkHandle<'a>,
captured_segment: Rc<RefCell<Option<PathSegment>>>,
}
impl<'a> Sink for KeyCapturingSink<'a> {
fn atom(&mut self, atom: Atom, state: &DeserializerState) -> Result<(), Error> {
*self.captured_segment.borrow_mut() = match atom {
Atom::Str(ref value) => Some(PathSegment::Key(value.to_string())),
Atom::U64(value) => Some(PathSegment::Index(value as usize)),
Atom::I64(value) => Some(PathSegment::Index(value as usize)),
_ => None,
};
self.sink.atom(atom, state)?;
Ok(())
}
fn map(&mut self, state: &DeserializerState) -> Result<Box<dyn MapSink + '_>, Error> {
self.sink.map(state)
}
fn seq(&mut self, state: &DeserializerState) -> Result<Box<dyn SeqSink + '_>, Error> {
self.sink.seq(state)
}
fn expecting(&self) -> Cow<'_, str> {
self.sink.expecting()
}
}