#codec #entity #html-escape #html-decode #html-encode #html-entities

htmlentity

A library for encoding and decoding HTML entities

14 releases (stable)

1.3.2 Jun 7, 2024
1.3.1 Apr 17, 2023
1.2.0 Mar 19, 2021
1.1.1 Feb 18, 2021
0.1.2 Nov 30, 2020

#125 in Encoding

Download history 1154/week @ 2024-10-27 624/week @ 2024-11-03 635/week @ 2024-11-10 707/week @ 2024-11-17 614/week @ 2024-11-24 1057/week @ 2024-12-01 2399/week @ 2024-12-08 2008/week @ 2024-12-15 1171/week @ 2024-12-22 1246/week @ 2024-12-29 2198/week @ 2025-01-05 1546/week @ 2025-01-12 1715/week @ 2025-01-19 1603/week @ 2025-01-26 2182/week @ 2025-02-02 2050/week @ 2025-02-09

7,658 downloads per month
Used in 31 crates (11 directly)

MIT license

155KB
5.5K SLoC

htmlentity

A library for encoding and decoding HTML entities.

Docs Build Status codecov

How to use

use htmlentity::entity::{ encode, decode, EncodeType, CharacterSet, ICodedDataTrait };
use htmlentity::types::{ AnyhowResult, Byte };
fn main() -> AnyhowResult<()> {
  let html = "<div name='htmlentity'>Hello!世界!</div>";
  let html_after_encoded = "&lt;div name='htmlentity'&gt;Hello!&#x4e16;&#x754c;!&lt;/div&gt;";
  // encode
  let encoded_data = encode(
    html.as_bytes(), 
    // encode format
    &EncodeType::NamedOrHex,
    // charcters need to be encoded 
    &CharacterSet::HtmlAndNonASCII
  );
  assert_eq!(encoded_data.to_bytes(), html_after_encoded.as_bytes());
  assert_eq!(encoded_data.to_string()?, String::from(html_after_encoded));
  let char_list = String::from(html_after_encoded).chars().collect::<Vec<char>>();
  assert_eq!(encoded_data.to_chars()?, char_list);
  // decode
  let bytes = encoded_data.into_iter().map(|(byte, _)| *byte).collect::<Vec<Byte>>();
  let decoded_data = decode(&bytes);
  assert_eq!(decoded_data.to_bytes(), html.as_bytes());
  assert_eq!(decoded_data.to_string()?, String::from(html));
  let char_list = String::from(html).chars().collect::<Vec<char>>();
  assert_eq!(decoded_data.to_chars()?, char_list);
  // shortcut usage
  assert_eq!(
    encode(
      html.as_bytes(), 
      &EncodeType::NamedOrHex,
      &CharacterSet::HtmlAndNonASCII,
    ).to_string()?,
    String::from(html)
  );
  Ok(())
}

For more details, please see the document in Docs.rs

License

MIT License.

Dependencies

~0.3–0.8MB
~18K SLoC