Skip to content

Commit

Permalink
Factor out the name handling in Element::{Get,Set,Remove}Attribute.
Browse files Browse the repository at this point in the history
  • Loading branch information
brunoabinader authored and Ms2ger committed Dec 23, 2014
1 parent e0bab08 commit 63ed36c
Showing 1 changed file with 13 additions and 15 deletions.
28 changes: 13 additions & 15 deletions components/script/dom/element.rs
Expand Up @@ -459,6 +459,7 @@ impl LayoutElementHelpers for JS<Element> {
pub trait ElementHelpers<'a> {
fn html_element_in_html_document(self) -> bool;
fn local_name(self) -> &'a Atom;
fn parsed_name(self, name: DOMString) -> DOMString;
fn namespace(self) -> &'a Namespace;
fn prefix(self) -> &'a Option<DOMString>;
fn attrs(&self) -> Ref<Vec<JS<Attr>>>;
Expand All @@ -481,6 +482,15 @@ impl<'a> ElementHelpers<'a> for JSRef<'a, Element> {
&self.extended_deref().local_name
}

// https://dom.spec.whatwg.org/#concept-element-attributes-get-by-name
fn parsed_name(self, name: DOMString) -> DOMString {
if self.html_element_in_html_document() {
name.as_slice().to_ascii_lower()
} else {
name
}
}

fn namespace(self) -> &'a Namespace {
&self.extended_deref().namespace
}
Expand Down Expand Up @@ -902,11 +912,7 @@ impl<'a> ElementMethods for JSRef<'a, Element> {

// http://dom.spec.whatwg.org/#dom-element-getattribute
fn GetAttribute(self, name: DOMString) -> Option<DOMString> {
let name = if self.html_element_in_html_document() {
name.as_slice().to_ascii_lower()
} else {
name
};
let name = self.parsed_name(name);
self.get_attribute(ns!(""), &Atom::from_slice(name.as_slice())).root()
.map(|s| s.Value())
}
Expand All @@ -931,11 +937,7 @@ impl<'a> ElementMethods for JSRef<'a, Element> {
}

// Step 2.
let name = if self.html_element_in_html_document() {
name.as_slice().to_ascii_lower()
} else {
name
};
let name = self.parsed_name(name);

// Step 3-5.
let name = Atom::from_slice(name.as_slice());
Expand Down Expand Up @@ -1012,11 +1014,7 @@ impl<'a> ElementMethods for JSRef<'a, Element> {

// http://dom.spec.whatwg.org/#dom-element-removeattribute
fn RemoveAttribute(self, name: DOMString) {
let name = if self.html_element_in_html_document() {
name.as_slice().to_ascii_lower()
} else {
name
};
let name = self.parsed_name(name);
self.remove_attribute(ns!(""), name.as_slice())
}

Expand Down

0 comments on commit 63ed36c

Please sign in to comment.