mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
Auto merge of #16090 - bzbarsky:required-optional, r=emilio
Implement :required/:optional support for stylo. Servo side of https://bugzilla.mozilla.org/show_bug.cgi?id=1349659 <!-- 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 - [ ] These changes fix #__ (github issue number if applicable). <!-- Either: --> - [ ] There are tests for these changes OR - [ ] These changes do not require tests because _____ <!-- 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/16090) <!-- Reviewable:end -->
This commit is contained in:
commit
2124220a63
3 changed files with 10 additions and 2 deletions
|
@ -57,7 +57,11 @@ bitflags! {
|
|||
const IN_HANDLER_DISABLED_STATE = 1 << 18,
|
||||
#[doc = "Non-standard: https://developer.mozilla.org/en-US/docs/Web/CSS/:-moz-handler-crashed"]
|
||||
const IN_HANDLER_CRASHED_STATE = 1 << 19,
|
||||
#[doc = "https://html.spec.whatwg.org/multipage/#selector-required"]
|
||||
const IN_REQUIRED_STATE = 1 << 20,
|
||||
#[doc = "https://html.spec.whatwg.org/multipage/#selector-optional"]
|
||||
const IN_OPTIONAL_STATE = 1 << 21,
|
||||
#[doc = "https://html.spec.whatwg.org/multipage/#selector-read-write"]
|
||||
const IN_READ_WRITE_STATE = 1 << 20,
|
||||
const IN_READ_WRITE_STATE = 1 << 22,
|
||||
}
|
||||
}
|
||||
|
|
|
@ -59,6 +59,8 @@ macro_rules! apply_non_ts_list {
|
|||
PSEUDO_CLASS_INTERNAL),
|
||||
("-moz-handler-crashed", MozHandlerCrashed, mozHandlerCrashed, IN_HANDLER_CRASHED_STATE,
|
||||
PSEUDO_CLASS_INTERNAL),
|
||||
("required", Required, required, IN_REQUIRED_STATE, _),
|
||||
("optional", Optional, optional, IN_OPTIONAL_STATE, _),
|
||||
("read-write", ReadWrite, _, IN_READ_WRITE_STATE, _),
|
||||
("read-only", ReadOnly, _, IN_READ_WRITE_STATE, _),
|
||||
|
||||
|
|
|
@ -707,7 +707,9 @@ impl<'le> ::selectors::Element for GeckoElement<'le> {
|
|||
NonTSPseudoClass::MozLoading |
|
||||
NonTSPseudoClass::MozHandlerBlocked |
|
||||
NonTSPseudoClass::MozHandlerDisabled |
|
||||
NonTSPseudoClass::MozHandlerCrashed => {
|
||||
NonTSPseudoClass::MozHandlerCrashed |
|
||||
NonTSPseudoClass::Required |
|
||||
NonTSPseudoClass::Optional => {
|
||||
self.get_state().contains(pseudo_class.state_flag())
|
||||
},
|
||||
NonTSPseudoClass::ReadOnly => {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue