htmlparser

Crates.iohtmlparser
lib.rshtmlparser
version0.2.1
sourcesrc
created_at2023-06-27 08:11:07.247009
updated_at2024-11-03 10:20:44.274239
descriptionPull-based, zero-allocation HTML parser.
homepagehttps://github.com/jdrouet/htmlparser
repositoryhttps://github.com/jdrouet/htmlparser.git
max_upload_size
id901077
size129,691
Jérémie Drouet (jdrouet)

documentation

https://docs.rs/htmlparser/

README

htmlparser

Build Status Crates.io Documentation Rust 1.31+

htmlparser is a low-level, pull-based, zero-allocation HTML parser.


Example

for token in htmlparser::Tokenizer::from("<tagname name='value'/>") {
    println!("{:?}", token);
}

Why a new library?

This library is basically a low-level XML tokenizer that preserves the positions of the tokens and is not intended to be used directly.

This library is a copy of xmlparser with some adjustments to parse html.


Benefits

  • All tokens contain StrSpan structs which represent the position of the substring in the original document.
  • Good error processing. All error types contain the position (line:column) where it occurred.
  • No heap allocations.
  • No dependencies.
  • Tiny. ~1400 LOC and ~30KiB in the release build according to cargo-bloat.
  • Supports no_std builds. To use without the standard library, disable the default features.

Limitations

  • Currently, only ENTITY objects are parsed from the DOCTYPE. All others are ignored.
  • No tree structure validation. So an XML like <root><child></root></child> or a string without root element will be parsed without errors. You should check for this manually. On the other hand <a/><a/> will lead to an error.
  • Duplicated attributes is not an error. So XML like <item a="v1" a="v2"/> will be parsed without errors. You should check for this manually.
  • UTF-8 only.

Safety

  • The library must not panic. Any panic is considered a critical bug and should be reported.
  • The library forbids unsafe code.

License

Licensed under either of

at your option.


Contribution

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

Commit count: 162

cargo fmt