Skip to content

Commit

Permalink
Reuse existing method with does the same thing when encoding featur…
Browse files Browse the repository at this point in the history
…e is disabled
  • Loading branch information
Mingun committed Jun 28, 2024
1 parent 80bf12d commit aa1d391
Showing 1 changed file with 2 additions and 12 deletions.
14 changes: 2 additions & 12 deletions src/events/attributes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -63,22 +63,12 @@ impl<'a> Attribute<'a> {
///
/// [`encoding`]: ../../index.html#encoding
#[cfg(any(doc, not(feature = "encoding")))]
#[inline]
pub fn unescape_value_with<'entity>(
&self,
resolve_entity: impl FnMut(&str) -> Option<&'entity str>,
) -> XmlResult<Cow<'a, str>> {
// from_utf8 should never fail because content is always UTF-8 encoded
let decoded = match &self.value {
Cow::Borrowed(bytes) => Cow::Borrowed(std::str::from_utf8(bytes)?),
// Convert to owned, because otherwise Cow will be bound with wrong lifetime
Cow::Owned(bytes) => Cow::Owned(std::str::from_utf8(bytes)?.to_string()),
};

match unescape_with(&decoded, resolve_entity)? {
// Because result is borrowed, no replacements was done and we can use original string
Cow::Borrowed(_) => Ok(decoded),
Cow::Owned(s) => Ok(s.into()),
}
self.decode_and_unescape_value_with(Decoder::utf8(), resolve_entity)
}

/// Decodes then unescapes the value.
Expand Down

0 comments on commit aa1d391

Please sign in to comment.