From e3728f616747325201bac468d5ddbd8973d02b74 Mon Sep 17 00:00:00 2001 From: Corey Farwell Date: Fri, 8 Jan 2016 20:56:49 -0500 Subject: [PATCH] Refactor 'listed element' logic for HTMLFieldSetElement::Elements `HTMLElement::is_listed_element` method was added, which matches the `HTMLElement::is_labelable_element` method directly above --- components/script/dom/htmlelement.rs | 24 ++++++++++++++++++++ components/script/dom/htmlfieldsetelement.rs | 7 +++--- 2 files changed, 27 insertions(+), 4 deletions(-) diff --git a/components/script/dom/htmlelement.rs b/components/script/dom/htmlelement.rs index d0f3f35d0ab..8c718c5ab29 100644 --- a/components/script/dom/htmlelement.rs +++ b/components/script/dom/htmlelement.rs @@ -354,6 +354,30 @@ impl HTMLElement { } } + // https://html.spec.whatwg.org/multipage/#category-listed + pub fn is_listed_element(&self) -> bool { + // Servo does not implement HTMLKeygenElement + // https://github.com/servo/servo/issues/2782 + if self.upcast::().local_name() == &atom!("keygen") { + return true; + } + + match self.upcast::().type_id() { + NodeTypeId::Element(ElementTypeId::HTMLElement(type_id)) => + match type_id { + HTMLElementTypeId::HTMLButtonElement | + HTMLElementTypeId::HTMLFieldSetElement | + HTMLElementTypeId::HTMLInputElement | + HTMLElementTypeId::HTMLObjectElement | + HTMLElementTypeId::HTMLOutputElement | + HTMLElementTypeId::HTMLSelectElement | + HTMLElementTypeId::HTMLTextAreaElement => true, + _ => false, + }, + _ => false, + } + } + pub fn supported_prop_names_custom_attr(&self) -> Vec { let element = self.upcast::(); element.attrs().iter().filter_map(|attr| { diff --git a/components/script/dom/htmlfieldsetelement.rs b/components/script/dom/htmlfieldsetelement.rs index 8dc1cc043ee..009f9f93282 100644 --- a/components/script/dom/htmlfieldsetelement.rs +++ b/components/script/dom/htmlfieldsetelement.rs @@ -18,7 +18,7 @@ use dom::validitystate::ValidityState; use dom::virtualmethods::VirtualMethods; use selectors::states::*; use string_cache::Atom; -use util::str::{DOMString, StaticStringVec}; +use util::str::DOMString; #[dom_struct] pub struct HTMLFieldSetElement { @@ -52,9 +52,8 @@ impl HTMLFieldSetElementMethods for HTMLFieldSetElement { struct ElementsFilter; impl CollectionFilter for ElementsFilter { fn filter<'a>(&self, elem: &'a Element, _root: &'a Node) -> bool { - static TAG_NAMES: StaticStringVec = &["button", "fieldset", "input", - "keygen", "object", "output", "select", "textarea"]; - TAG_NAMES.iter().any(|&tag_name| tag_name == &**elem.local_name()) + elem.downcast::() + .map_or(false, HTMLElement::is_listed_element) } } let filter = box ElementsFilter;