servo/components/selectors
bors-servo 4b6e79337e Auto merge of #17538 - jyc:selectorText, r=Manishearth
Implement CSSStyleRule.selectorText.

We parse when assigning using the namespaces of the stylesheet. It isn't
clear if the spec says to do that (Firefox doesn't support the setter at
all, Chrome does, Safari doesn't); the spec issue is here:
https://github.com/w3c/csswg-drafts/issues/1511

Also fix ToCss implementation of AttrSelectorOperator to not pad with
spaces, to conform with CSSOM. This means we have to update some unit
tests that expect operators with spaces around them in attribute
selectors to roundtrip.

See the "attribute selector" section of "Serializing Selectors" here:
https://drafts.csswg.org/cssom/#serializing-selectors

CSSStyleRule.selectorText is specified here:
https://drafts.csswg.org/cssom/#dom-cssstylerule-selectortext

<!-- Please describe your changes on the following line: -->

---
<!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: -->
- [X] `./mach build -d` does not report any errors
- [X] `./mach test-tidy` does not report any errors
- [X] These changes is part of a series to fix #17182

<!-- Either: -->
I am running this to identify what tests will fail; as the other PRs in the series are merged, I believe the tests that pass will change as well.

- [ ] There are tests for these changes OR
- [ ] These changes do not require tests because _____

<!-- Also, please make sure that "Allow edits from maintainers" checkbox is checked, so that we can help you if you get stuck somewhere along the way.-->

<!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. -->

<!-- Reviewable:start -->
---
This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/17538)
<!-- Reviewable:end -->
2017-07-12 11:08:35 -07:00
..
attr.rs Implement CSSStyleRule.selectorText. 2017-07-12 01:03:58 -07:00
bloom.rs Correct bloom hash bitpacking documentation 2017-06-22 21:26:14 -04:00
build.rs Make some attr values case-insensitive in selectors 2017-05-18 17:13:15 +02:00
builder.rs Less unsafe in selectors::builder. 2017-06-20 11:59:11 -07:00
Cargo.toml stylo: Update rust-cssparser; extract more specific error types when reporting (bug 1352669). 2017-07-10 20:46:12 -04:00
context.rs style: Remove StyleRelations. 2017-07-12 09:26:55 +02:00
gecko_like_types.rs Update test in selectors to match types for Gecko. 2017-07-12 20:33:13 +10:00
lib.rs Make selectors benchmark tests work again. 2017-06-21 19:53:15 -07:00
matching.rs style: Remove StyleRelations. 2017-07-12 09:26:55 +02:00
parser.rs Auto merge of #17538 - jyc:selectorText, r=Manishearth 2017-07-12 11:08:35 -07:00
README.md Move rust-selectors in-tree. 2017-02-07 22:53:10 -08:00
sink.rs Hoist sink into selectors. 2017-06-20 11:59:10 -07:00
size_of_tests.rs Update test in selectors to match types for Gecko. 2017-07-12 20:33:13 +10:00
tree.rs Stylo: Correct style match for element instances under a use-element tree. 2017-06-20 18:07:36 +08:00
visitor.rs Allow style sharing for elements with ids as long as the ID is not being used for styling. 2017-06-05 13:32:03 -04: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.