#codec #html #html-string #entity #decoding #character

htmlescape

A library for HTML entity encoding and decoding

1 unstable release

Uses old Rust 2015

0.3.1 Apr 2, 2017

#1526 in Encoding

Download history 104086/week @ 2024-08-08 99870/week @ 2024-08-15 98214/week @ 2024-08-22 86997/week @ 2024-08-29 94083/week @ 2024-09-05 91336/week @ 2024-09-12 91006/week @ 2024-09-19 95062/week @ 2024-09-26 96709/week @ 2024-10-03 87450/week @ 2024-10-10 76133/week @ 2024-10-17 74068/week @ 2024-10-24 70098/week @ 2024-10-31 75808/week @ 2024-11-07 82539/week @ 2024-11-14 69645/week @ 2024-11-21

311,522 downloads per month
Used in 234 crates (49 directly)

Apache-2.0 / MIT / MPL-2.0

54KB
606 lines

A HTML entity encoding library for Rust

Build Status

Example usage

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

###Encoding htmlescape::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 htmlescape::encode_attribute() function for encoding strings that are to be used as html attribute values.

###Decoding htmlescape::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.

No runtime deps