You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
77 lines
2.9 KiB
77 lines
2.9 KiB
6 years ago
|
From 45ab6d492c1a031485962e17d2af932d8af069d8 Mon Sep 17 00:00:00 2001
|
||
|
From: Kevin Ballard <kevin@sb.org>
|
||
|
Date: Wed, 16 May 2018 14:28:31 -0700
|
||
|
Subject: [PATCH] Update xml-rs to 0.8.0, reimplement plist prologue
|
||
|
|
||
|
xml-rs 0.8.0 has an `inner_mut()` method we can use instead of turning
|
||
|
off character escaping.
|
||
|
---
|
||
|
src/xml/writer.rs | 17 ++++++-----------
|
||
|
1 file changed, 6 insertions(+), 11 deletions(-)
|
||
|
|
||
|
diff --git a/src/xml/writer.rs b/src/xml/writer.rs
|
||
|
index e168128..4facfd2 100644
|
||
|
--- a/src/xml/writer.rs
|
||
|
+++ b/src/xml/writer.rs
|
||
|
@@ -1,7 +1,6 @@
|
||
|
use base64;
|
||
|
use std::borrow::Cow;
|
||
|
use std::io::Write;
|
||
|
-use xml_rs::escape::escape_str_pcdata;
|
||
|
use xml_rs::name::Name;
|
||
|
use xml_rs::namespace::Namespace;
|
||
|
use xml_rs::writer::events::XmlEvent as WriteXmlEvent;
|
||
|
@@ -38,7 +37,7 @@ pub struct EventWriter<W: Write> {
|
||
|
|
||
|
impl<W: Write> EventWriter<W> {
|
||
|
pub fn new(writer: W) -> EventWriter<W> {
|
||
|
- let mut config = EmitterConfig::new()
|
||
|
+ let config = EmitterConfig::new()
|
||
|
.line_separator("\n")
|
||
|
.indent_string("\t")
|
||
|
.perform_indent(true)
|
||
|
@@ -47,7 +46,6 @@ impl<W: Write> EventWriter<W> {
|
||
|
.cdata_to_characters(true)
|
||
|
.keep_element_names_stack(false)
|
||
|
.autopad_comments(true);
|
||
|
- config.perform_escaping = false;
|
||
|
|
||
|
EventWriter {
|
||
|
xml_writer: XmlEventWriter::new_with_config(writer, config),
|
||
|
@@ -80,19 +78,16 @@ impl<W: Write> EventWriter<W> {
|
||
|
}
|
||
|
|
||
|
fn write_value(&mut self, value: &str) -> Result<()> {
|
||
|
- self.xml_writer
|
||
|
- .write(WriteXmlEvent::Characters(&escape_str_pcdata(value)))?;
|
||
|
+ self.xml_writer.write(WriteXmlEvent::Characters(value))?;
|
||
|
Ok(())
|
||
|
}
|
||
|
|
||
|
fn maybe_end_plist(&mut self) -> Result<()> {
|
||
|
// If there are no more open tags then write the </plist> element
|
||
|
if self.stack.len() == 1 {
|
||
|
- // We didn't tell the xml_writer about the <plist> tag so it thinks we're already at
|
||
|
- // the root. As such, it's not going to prettify our output, so we need to include
|
||
|
- // the newline ourselves.
|
||
|
- self.xml_writer.write(WriteXmlEvent::Characters("\n"))?;
|
||
|
- self.end_element("plist")?;
|
||
|
+ // We didn't tell the xml_writer about the <plist> tag so we'll skip telling it
|
||
|
+ // about the </plist> tag as well.
|
||
|
+ self.xml_writer.inner_mut().write(b"\n</plist>")?;
|
||
|
if let Some(Element::Root) = self.stack.pop() {
|
||
|
} else {
|
||
|
return Err(Error::InvalidData);
|
||
|
@@ -134,7 +129,7 @@ impl<W: Write> PlistEventWriter for EventWriter<W> {
|
||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||
|
<plist version="1.0">
|
||
|
"#;
|
||
|
- self.xml_writer.write(WriteXmlEvent::Characters(prologue))?;
|
||
|
+ self.xml_writer.inner_mut().write(prologue.as_bytes())?;
|
||
|
|
||
|
self.stack.push(Element::Root);
|
||
|
}
|
||
|
--
|
||
|
2.19.0.rc1
|
||
|
|