gecko-dev/third_party/rust/cssparser
Xidorn Quan 46cae3d7aa Bug 1471104 followup - Upgrade cssparser and revendor.
MozReview-Commit-ID: 74rBgkJEcYd

--HG--
extra : rebase_source : a30d17b3d7e24f1a61c01d1dc442d6ce60c1dde3
extra : source : 8ff268ee87b7392391a6b6aa981f9180c45b27b6
2018-06-27 10:43:21 +10:00
..
build Bug 1471104 followup - Upgrade cssparser and revendor. 2018-06-27 10:43:21 +10:00
docs
src Bug 1471104 followup - Upgrade cssparser and revendor. 2018-06-27 10:43:21 +10:00
.cargo-checksum.json Bug 1471104 followup - Upgrade cssparser and revendor. 2018-06-27 10:43:21 +10:00
.travis.yml Bug 1449087 part 1 - Upgrade cssparser to 0.23.4 for serialization fix. r=emilio 2018-04-04 08:42:10 +10:00
Cargo.toml Bug 1471104 followup - Upgrade cssparser and revendor. 2018-06-27 10:43:21 +10:00
LICENSE
README.md No bug - Revendor rust dependencies 2017-07-11 02:17:43 +00:00
build.rs Bug 1466789: Bump cssparser. r=me 2018-06-05 11:51:45 +02:00

README.md

rust-cssparser

Build Status

Documentation

Rust implementation of CSS Syntax Module Level 3

Overview

Parsing CSS involves a series of steps:

  • When parsing from bytes, (e.g. reading a file or fetching an URL from the network,) detect the character encoding (based on a Content-Type HTTP header, an @charset rule, a BOM, etc.) and decode to Unicode text.

    rust-cssparser does not do this yet and just assumes UTF-8.

    This step is skipped when parsing from Unicode, e.g. in an HTML <style> element.

  • Tokenization, a.k.a. lexing. The input, a stream of Unicode text, is transformed into a stream of tokens. Tokenization never fails, although the output may contain error tokens.

  • This flat stream of tokens is then transformed into a tree of component values, which are either preserved tokens, or blocks/functions ({ … }, [ … ], ( … ), foo( … )) that contain more component values.

    rust-cssparser does this at the same time as tokenization: raw tokens are never materialized, you only get component values.

  • Component values can then be parsed into generic rules or declarations. The header and body of rules as well as the value of declarations are still just lists of component values at this point. See the ast module for the data structures.

  • The last step of a full CSS parser is parsing the remaining component values into Selectors, specific CSS properties, etc.

    By design, rust-cssparser does not do this last step which depends a lot on what you want to do: which properties you want to support, what you want to do with selectors, etc.

    It does however provide some helper functions to parse CSS colors and An+B (the argument to :nth-child() and related selectors.

    See Servos style crate for an example of a parser based on rust-cssparser.