diff options
Diffstat (limited to 'askama_escape/src')
-rw-r--r-- | askama_escape/src/lib.rs | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/askama_escape/src/lib.rs b/askama_escape/src/lib.rs index 8c23530..a591a9c 100644 --- a/askama_escape/src/lib.rs +++ b/askama_escape/src/lib.rs @@ -1,4 +1,5 @@ use std::fmt::{self, Display, Formatter}; +use std::io::{self, prelude::*}; use std::str; #[derive(Debug, PartialEq)] @@ -37,12 +38,33 @@ where { fn fmt(&self, f: &mut Formatter<'_>) -> fmt::Result { match *self { - MarkupDisplay::Unsafe(ref t) => escape(&t.to_string()).fmt(f), + MarkupDisplay::Unsafe(ref t) => { + let mut w = EscapeWriter { fmt: f }; + write!(w, "{}", t).map_err(|_e| fmt::Error) + } MarkupDisplay::Safe(ref t) => t.fmt(f), } } } +pub struct EscapeWriter<'a, 'b: 'a> { + fmt: &'a mut fmt::Formatter<'b>, +} + +impl io::Write for EscapeWriter<'_, '_> { + fn write(&mut self, bytes: &[u8]) -> io::Result<usize> { + let escaped = Escaped { bytes }; + escaped + .fmt(self.fmt) + .map_err(|e| io::Error::new(io::ErrorKind::Other, e.to_string()))?; + Ok(bytes.len()) + } + + fn flush(&mut self) -> std::io::Result<()> { + Ok(()) + } +} + pub fn escape(s: &str) -> Escaped<'_> { Escaped { bytes: s.as_bytes(), |