9 unstable releases

0.13.0 Mar 27, 2025
0.13.0-pre.0 Mar 21, 2025
0.10.3 Feb 16, 2022
0.10.2 Dec 21, 2021
0.1.0 Nov 7, 2018

#6 in No standard library

Download history 59915/week @ 2024-12-20 54747/week @ 2024-12-27 116821/week @ 2025-01-03 171175/week @ 2025-01-10 121209/week @ 2025-01-17 124164/week @ 2025-01-24 143027/week @ 2025-01-31 163515/week @ 2025-02-07 147849/week @ 2025-02-14 151148/week @ 2025-02-21 150656/week @ 2025-02-28 148556/week @ 2025-03-07 151437/week @ 2025-03-14 143623/week @ 2025-03-21 135076/week @ 2025-03-28 106591/week @ 2025-04-04

566,953 downloads per month
Used in 324 crates (15 directly)

MIT/Apache

17KB
273 lines

askama_escape: HTML escaping, extracted from Askama

Crates.io GitHub Workflow Status docs.rs

Useful if you don't need a template engine, but if you need to escape a text for HTML or XML.

This implementation escapes '"', '&', '\'', '<' and '>'.

Example

use askama_escape::{escape, escape_html, escape_html_char, Html};

assert_eq!(
    escape("<script>alert('Hello & bye!')</script>", Html).to_string(),
    "&#60;script&#62;alert(&#39;Hello &#38; bye!&#39;)&#60;/script&#62;",
);

let mut dest = String::new();
escape_html(&mut dest, "<script>alert('Hello & bye!')</script>").unwrap();
assert_eq!(
    dest,
    "&#60;script&#62;alert(&#39;Hello &#38; bye!&#39;)&#60;/script&#62;",
);

let mut dest = String::new();
escape_html_char(&mut dest, '&').unwrap();
assert_eq!(dest, "&#38;");

No runtime deps