2 releases

0.1.1 May 10, 2021
0.1.0 Aug 16, 2019

#2130 in Parser implementations

Download history 746/week @ 2024-10-25 1200/week @ 2024-11-01 670/week @ 2024-11-08 730/week @ 2024-11-15 767/week @ 2024-11-22 1216/week @ 2024-11-29 945/week @ 2024-12-06 968/week @ 2024-12-13 710/week @ 2024-12-20 753/week @ 2024-12-27 925/week @ 2025-01-03 922/week @ 2025-01-10 1198/week @ 2025-01-17 932/week @ 2025-01-24 1038/week @ 2025-01-31 958/week @ 2025-02-07

4,323 downloads per month
Used in 15 crates (12 directly)

Apache-2.0 / MIT / MPL-2.0

57KB
426 lines

A HTML entity encoding library for Rust

crates.io version TravisCI build status Docs License

Example usage

All example assume a extern crate escaper; and use escaper::{relevant functions here}; is present.

Encoding

escaper::encode_minimal() encodes an input string using a minimal set of HTML entities.

let title = "Cats & dogs";
let tag = format!("<title>{}</title>", encode_minimal(title));
assert_eq!(tag.as_slice(), "<title>Cats &amp; dogs</title>");

There is also a escaper::encode_attribute() function for encoding strings that are to be used as html attribute values.

Decoding

escaper::decode_html() decodes an encoded string, replacing HTML entities with the

corresponding characters. Named, hex, and decimal entities are supported. A Result value is returned, with either the decoded string in Ok, or an error in Err.

let encoded = "Cats&#x20;&amp;&#32;dogs";
let decoded = match decode_html(encoded) {
  Err(reason) => panic!("Error {:?} at character {}", reason.kind, reason.position),
  Ok(s) => s
};
assert_eq!(decoded.as_slice(), "Cats & dogs");

Avoiding allocations

Both the encoding and decoding functions are available in forms that take a Writer for output rather than returning an String. These version can be used to avoid allocation and copying if the returned String was just going to be written to a Writer anyway.

LICENSE

MIT or Apache 2.0

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in pgp by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies