aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2015-11-09 05:28:51 +0530
committerbors-servo <lbergstrom+bors@mozilla.com>2015-11-09 05:28:51 +0530
commit3780fb7fe02ed66bd391421a0c5506b5635279dd (patch)
treeb7344f5d183a414e495c972e2dbe278c5e8f4e05
parent97791dd317893c3b1c203c5d248846ff4fd9daba (diff)
parentee0800abe9a00b089d703a28b3a58b13529bfdbd (diff)
downloadservo-3780fb7fe02ed66bd391421a0c5506b5635279dd.tar.gz
servo-3780fb7fe02ed66bd391421a0c5506b5635279dd.zip
Auto merge of #8419 - frewsxcv:html-hr-element-color-attribute, r=eefriedman
Implement <hr> 'color' attribute <!-- Reviewable:start --> [<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/8419) <!-- Reviewable:end -->
-rw-r--r--components/script/dom/element.rs4
-rw-r--r--components/script/dom/htmlhrelement.rs51
-rw-r--r--components/script/dom/virtualmethods.rs4
-rw-r--r--components/script/dom/webidls/HTMLHRElement.webidl2
-rw-r--r--tests/wpt/metadata/MANIFEST.json10
-rw-r--r--tests/wpt/metadata/html/dom/interfaces.html.ini6
-rw-r--r--tests/wpt/metadata/html/dom/reflection-grouping.html.ini129
-rw-r--r--tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color-ref.html22
-rw-r--r--tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color.html7
9 files changed, 97 insertions, 138 deletions
diff --git a/components/script/dom/element.rs b/components/script/dom/element.rs
index d420e9b5405..9b5fb30c1c6 100644
--- a/components/script/dom/element.rs
+++ b/components/script/dom/element.rs
@@ -40,6 +40,7 @@ use dom::htmlbodyelement::HTMLBodyElement;
use dom::htmlcollection::HTMLCollection;
use dom::htmlfieldsetelement::HTMLFieldSetElement;
use dom::htmlfontelement::HTMLFontElement;
+use dom::htmlhrelement::{HTMLHRElement, HTMLHRLayoutHelpers};
use dom::htmliframeelement::HTMLIFrameElement;
use dom::htmlinputelement::{HTMLInputElement, LayoutHTMLInputElementHelpers};
use dom::htmllabelelement::HTMLLabelElement;
@@ -309,6 +310,9 @@ impl LayoutElementHelpers for LayoutJS<Element> {
} else if let Some(this) = self.downcast::<HTMLBodyElement>() {
// https://html.spec.whatwg.org/multipage/#the-page:the-body-element-20
(*this.unsafe_get()).get_color()
+ } else if let Some(this) = self.downcast::<HTMLHRElement>() {
+ // https://html.spec.whatwg.org/multipage/#the-hr-element-2:presentational-hints-5
+ this.get_color()
} else {
None
};
diff --git a/components/script/dom/htmlhrelement.rs b/components/script/dom/htmlhrelement.rs
index dc5ab695d6b..6f2362f592c 100644
--- a/components/script/dom/htmlhrelement.rs
+++ b/components/script/dom/htmlhrelement.rs
@@ -2,11 +2,17 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-use dom::bindings::codegen::Bindings::HTMLHRElementBinding;
-use dom::bindings::js::Root;
+use cssparser::RGBA;
+use dom::attr::AttrValue;
+use dom::bindings::codegen::Bindings::HTMLHRElementBinding::{self, HTMLHRElementMethods};
+use dom::bindings::inheritance::Castable;
+use dom::bindings::js::{LayoutJS, Root};
use dom::document::Document;
+use dom::element::{Element, RawLayoutElementHelpers};
use dom::htmlelement::HTMLElement;
use dom::node::Node;
+use dom::virtualmethods::VirtualMethods;
+use string_cache::Atom;
use util::str::DOMString;
#[dom_struct]
@@ -29,3 +35,44 @@ impl HTMLHRElement {
Node::reflect_node(box element, document, HTMLHRElementBinding::Wrap)
}
}
+
+impl HTMLHRElementMethods for HTMLHRElement {
+ // https://html.spec.whatwg.org/multipage/#dom-hr-color
+ make_getter!(Color);
+
+ // https://html.spec.whatwg.org/multipage/#dom-hr-color
+ fn SetColor(&self, value: DOMString) {
+ self.upcast::<Element>()
+ .set_attribute(&atom!("color"), AttrValue::from_legacy_color(value));
+ }
+}
+
+pub trait HTMLHRLayoutHelpers {
+ fn get_color(&self) -> Option<RGBA>;
+}
+
+impl HTMLHRLayoutHelpers for LayoutJS<HTMLHRElement> {
+ #[allow(unsafe_code)]
+ fn get_color(&self) -> Option<RGBA> {
+ unsafe {
+ (&*self.upcast::<Element>().unsafe_get())
+ .get_attr_for_layout(&ns!(""), &atom!("color"))
+ .and_then(AttrValue::as_color)
+ .cloned()
+ }
+ }
+}
+
+
+impl VirtualMethods for HTMLHRElement {
+ fn super_type(&self) -> Option<&VirtualMethods> {
+ Some(self.upcast::<HTMLElement>() as &VirtualMethods)
+ }
+
+ fn parse_plain_attribute(&self, name: &Atom, value: DOMString) -> AttrValue {
+ match name {
+ &atom!("color") => AttrValue::from_legacy_color(value),
+ _ => self.super_type().unwrap().parse_plain_attribute(name, value),
+ }
+ }
+}
diff --git a/components/script/dom/virtualmethods.rs b/components/script/dom/virtualmethods.rs
index 7223ffd8b37..d2a436606d7 100644
--- a/components/script/dom/virtualmethods.rs
+++ b/components/script/dom/virtualmethods.rs
@@ -22,6 +22,7 @@ use dom::htmlfieldsetelement::HTMLFieldSetElement;
use dom::htmlfontelement::HTMLFontElement;
use dom::htmlformelement::HTMLFormElement;
use dom::htmlheadelement::HTMLHeadElement;
+use dom::htmlhrelement::HTMLHRElement;
use dom::htmliframeelement::HTMLIFrameElement;
use dom::htmlimageelement::HTMLImageElement;
use dom::htmlinputelement::HTMLInputElement;
@@ -156,6 +157,9 @@ pub fn vtable_for(node: &Node) -> &VirtualMethods {
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLHeadElement)) => {
node.downcast::<HTMLHeadElement>().unwrap() as &VirtualMethods
}
+ NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLHRElement)) => {
+ node.downcast::<HTMLHRElement>().unwrap() as &VirtualMethods
+ }
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLImageElement)) => {
node.downcast::<HTMLImageElement>().unwrap() as &VirtualMethods
}
diff --git a/components/script/dom/webidls/HTMLHRElement.webidl b/components/script/dom/webidls/HTMLHRElement.webidl
index 5036d6c20b3..185100712f5 100644
--- a/components/script/dom/webidls/HTMLHRElement.webidl
+++ b/components/script/dom/webidls/HTMLHRElement.webidl
@@ -11,7 +11,7 @@ interface HTMLHRElement : HTMLElement {
// https://html.spec.whatwg.org/multipage/#HTMLHRElement-partial
partial interface HTMLHRElement {
// attribute DOMString align;
- // attribute DOMString color;
+ attribute DOMString color;
// attribute boolean noShade;
// attribute DOMString size;
// attribute DOMString width;
diff --git a/tests/wpt/metadata/MANIFEST.json b/tests/wpt/metadata/MANIFEST.json
index 22cd43f2f37..329cdeeacbf 100644
--- a/tests/wpt/metadata/MANIFEST.json
+++ b/tests/wpt/metadata/MANIFEST.json
@@ -4486,6 +4486,16 @@
"url": "/html/rendering/non-replaced-elements/the-fieldset-element-0/min-width-not-important.html"
},
{
+ "path": "html/rendering/non-replaced-elements/the-hr-element-0/color.html",
+ "references": [
+ [
+ "html/rendering/non-replaced-elements/the-hr-element-0/color-ref.html",
+ "=="
+ ]
+ ],
+ "url": "/html/rendering/non-replaced-elements/the-hr-element-0/color.html"
+ },
+ {
"path": "html/rendering/non-replaced-elements/the-page/body_text_00ffff.xhtml",
"references": [
[
diff --git a/tests/wpt/metadata/html/dom/interfaces.html.ini b/tests/wpt/metadata/html/dom/interfaces.html.ini
index cd95e91d7d6..2d529c28d0c 100644
--- a/tests/wpt/metadata/html/dom/interfaces.html.ini
+++ b/tests/wpt/metadata/html/dom/interfaces.html.ini
@@ -2316,9 +2316,6 @@
[HTMLHRElement interface: attribute align]
expected: FAIL
- [HTMLHRElement interface: attribute color]
- expected: FAIL
-
[HTMLHRElement interface: attribute noShade]
expected: FAIL
@@ -2331,9 +2328,6 @@
[HTMLHRElement interface: document.createElement("hr") must inherit property "align" with the proper type (0)]
expected: FAIL
- [HTMLHRElement interface: document.createElement("hr") must inherit property "color" with the proper type (1)]
- expected: FAIL
-
[HTMLHRElement interface: document.createElement("hr") must inherit property "noShade" with the proper type (2)]
expected: FAIL
diff --git a/tests/wpt/metadata/html/dom/reflection-grouping.html.ini b/tests/wpt/metadata/html/dom/reflection-grouping.html.ini
index 74f632a737c..cc2a70be8d5 100644
--- a/tests/wpt/metadata/html/dom/reflection-grouping.html.ini
+++ b/tests/wpt/metadata/html/dom/reflection-grouping.html.ini
@@ -1449,135 +1449,6 @@
[hr.align: IDL set to object "test-valueOf" followed by IDL get]
expected: FAIL
- [hr.color: typeof IDL attribute]
- expected: FAIL
-
- [hr.color: IDL get with DOM attribute unset]
- expected: FAIL
-
- [hr.color: setAttribute() to "" followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo " followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to undefined followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to 7 followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to 1.5 followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to true followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to false followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to object "[object Object\]" followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to NaN followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to Infinity followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to -Infinity followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to "\\0" followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to null followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to object "test-toString" followed by IDL get]
- expected: FAIL
-
- [hr.color: setAttribute() to object "test-valueOf" followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to "" followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo " followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to undefined followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to undefined followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to 7 followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to 7 followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to 1.5 followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to 1.5 followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to true followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to true followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to false followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to false followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to object "[object Object\]" followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to object "[object Object\]" followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to NaN followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to NaN followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to Infinity followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to Infinity followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to -Infinity followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to -Infinity followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to "\\0" followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to null followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to null followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to object "test-toString" followed by getAttribute()]
- expected: FAIL
-
- [hr.color: IDL set to object "test-toString" followed by IDL get]
- expected: FAIL
-
- [hr.color: IDL set to object "test-valueOf" followed by IDL get]
- expected: FAIL
-
[hr.noShade: typeof IDL attribute]
expected: FAIL
diff --git a/tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color-ref.html b/tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color-ref.html
new file mode 100644
index 00000000000..5cd35c83ada
--- /dev/null
+++ b/tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color-ref.html
@@ -0,0 +1,22 @@
+<!doctype html>
+<meta charset=utf-8>
+<style>
+.hr {
+ color: gray;
+ border-style: inset;
+ border-width: 1px;
+ margin: 0.5em auto;
+}
+
+.green {
+ color: green;
+}
+
+.no-inset {
+ border-style: solid;
+}
+</style>
+<div class='hr'></div>
+<div class='hr no-inset'></div>
+<div class='hr no-inset'></div>
+<div class='hr green no-inset'></div>
diff --git a/tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color.html b/tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color.html
new file mode 100644
index 00000000000..750f77e5fbb
--- /dev/null
+++ b/tests/wpt/web-platform-tests/html/rendering/non-replaced-elements/the-hr-element-0/color.html
@@ -0,0 +1,7 @@
+<!doctype html>
+<meta charset=utf-8>
+<link rel=match href="color-ref.html">
+<hr>
+<hr color="">
+<hr color=transparent>
+<hr color=green>