servo/components/selectors
Emilio Cobos Álvarez 7a556a7f03
Bug 1360399: Don't deduplicate revalidation selectors. r=bholley
It's unfortunate, but it's a correctness issue. I was looking at the
expectations update here:

 * https://hg.mozilla.org/integration/autoland/rev/659cddddd434

And investigating it I realised that it's wrong to coalesce selectors like that,
because we keep the bloom filter flags.

So in the test cases disabled, we have a selector that looks like this:

msub > :not(:first-child),
msup > :not(:first-child),
msubsup > :not(:first-child),
mmultiscripts > :not(:first-child) {
    -moz-script-level: +1;
    -moz-math-display: inline;
}

And an element that looks like this:

<msubsup><mi></mi><mi></mi></msubsup>

We're only inserting the first selector msub > :not(:first-child) into the set,
so when we're going to match the <mi> elements we fast-reject it in both cases
due to the bloom filter, so they share style.

I can't see an easy way to fix this keeping the deduplication. If we keep it, we
need to remove the bloom filter optimization, which means that we'd trash the
cache for every first-child in the document (the :not(:first-child) effectively
becomes a global rule).

MozReview-Commit-ID: 9VPkmdj9zDg
Signed-off-by: Emilio Cobos Álvarez <emilio@crisal.io>
2017-04-28 02:57:54 +02:00
..
arcslice.rs Store selectors and combinators inline in a single sequence. 2017-04-20 15:00:43 -07:00
bloom.rs selectors: Unbust tests, and add a way to override the hash for the bloom filter. 2017-04-08 02:00:31 +02:00
Cargo.toml Update to cssparser 0.13 2017-04-25 01:45:33 +02:00
lib.rs Store selectors and combinators inline in a single sequence. 2017-04-20 15:00:43 -07:00
matching.rs Fix overflow in ::nth-child() 2017-04-26 19:20:13 +09:00
parser.rs Bug 1360399: Don't deduplicate revalidation selectors. r=bholley 2017-04-28 02:57:54 +02:00
README.md Move rust-selectors in-tree. 2017-02-07 22:53:10 -08:00
tree.rs Bug 1345950: stylo: Fix slow selector flags. r=bholley 2017-03-22 11:21:24 +01:00
visitor.rs Rename SimpleSelector to Component. 2017-04-20 15:04:48 -07:00

rust-selectors

CSS Selectors library for Rust. Includes parsing and serilization of selectors, as well as matching against a generic tree of elements. Pseudo-elements and most pseudo-classes are generic as well.

Warning: breaking changes are made to this library fairly frequently (13 times in 2016, for example). However you can use this crate without updating it that often, old versions stay available on crates.io and Cargo will only automatically update to versions that are numbered as compatible.

To see how to use this library with your own tree representation, see Kuchikis src/select.rs. (Note however that Kuchiki is not always up to date with the latest rust-selectors version, so that code may need to be tweaked.) If you dont already have a tree data structure, consider using Kuchiki itself.