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
pub use self::emitter::Result;
pub use self::emitter::EmitterError as Error;
pub use self::config::EmitterConfig;
pub use self::events::XmlEvent;
use self::emitter::Emitter;
use std::io::prelude::*;
mod emitter;
mod config;
pub mod events;
pub struct EventWriter<W> {
sink: W,
emitter: Emitter
}
impl<W: Write> EventWriter<W> {
#[inline]
pub fn new(sink: W) -> EventWriter<W> {
EventWriter::new_with_config(sink, EmitterConfig::new())
}
#[inline]
pub fn new_with_config(sink: W, config: EmitterConfig) -> EventWriter<W> {
EventWriter {
sink: sink,
emitter: Emitter::new(config)
}
}
pub fn write<'a, E>(&mut self, event: E) -> Result<()> where E: Into<XmlEvent<'a>> {
match event.into() {
XmlEvent::StartDocument { version, encoding, standalone } =>
self.emitter.emit_start_document(&mut self.sink, version, encoding.unwrap_or("UTF-8"), standalone),
XmlEvent::ProcessingInstruction { name, data } =>
self.emitter.emit_processing_instruction(&mut self.sink, name, data),
XmlEvent::StartElement { name, attributes, namespace } => {
self.emitter.namespace_stack_mut().push_empty().checked_target().extend(namespace.as_ref());
self.emitter.emit_start_element(&mut self.sink, name, &attributes)
}
XmlEvent::EndElement { name } => {
let r = self.emitter.emit_end_element(&mut self.sink, name);
self.emitter.namespace_stack_mut().try_pop();
r
}
XmlEvent::Comment(content) =>
self.emitter.emit_comment(&mut self.sink, content),
XmlEvent::CData(content) =>
self.emitter.emit_cdata(&mut self.sink, content),
XmlEvent::Characters(content) =>
self.emitter.emit_characters(&mut self.sink, content)
}
}
pub fn into_inner(self) -> W {
self.sink
}
}