Skip to content

Commit

Permalink
Auto merge of #7829 - frewsxcv:htmltablecellelement-cellindex, r=Ms2ger
Browse files Browse the repository at this point in the history
Implement HTMLTableCellElement::CellIndex

Extracted from #6936

<!-- Reviewable:start -->
[<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/7829)
<!-- Reviewable:end -->
  • Loading branch information
bors-servo committed Oct 14, 2015
2 parents dd2f8b6 + 899f1ca commit 55769b2
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 28 deletions.
20 changes: 19 additions & 1 deletion components/script/dom/htmltablecellelement.rs
Expand Up @@ -5,7 +5,11 @@
use cssparser::RGBA;
use dom::attr::{Attr, AttrValue};
use dom::bindings::codegen::Bindings::HTMLTableCellElementBinding::HTMLTableCellElementMethods;
use dom::bindings::codegen::InheritTypes::{HTMLElementCast, HTMLTableCellElementDerived};
use dom::bindings::codegen::Bindings::NodeBinding::NodeMethods;
use dom::bindings::codegen::InheritTypes::HTMLElementCast;
use dom::bindings::codegen::InheritTypes::HTMLTableCellElementDerived;
use dom::bindings::codegen::InheritTypes::HTMLTableRowElementDerived;
use dom::bindings::codegen::InheritTypes::NodeCast;
use dom::bindings::js::LayoutJS;
use dom::document::Document;
use dom::element::{AttributeMutation, ElementTypeId};
Expand Down Expand Up @@ -78,6 +82,20 @@ impl HTMLTableCellElementMethods for HTMLTableCellElement {

// https://html.spec.whatwg.org/multipage/#dom-tdth-colspan
make_uint_setter!(SetColSpan, "colspan");

// https://html.spec.whatwg.org/multipage/#dom-tdth-cellindex
fn CellIndex(&self) -> i32 {
let self_node = NodeCast::from_ref(self);

let parent_children = match self_node.GetParentNode() {
Some(ref parent_node) if parent_node.is_htmltablerowelement() => parent_node.children(),
_ => return -1,
};

parent_children.filter(|c| c.is_htmltablecellelement())
.position(|c| c.r() == self_node)
.map(|p| p as i32).unwrap_or(-1)
}
}


Expand Down
2 changes: 1 addition & 1 deletion components/script/dom/webidls/HTMLTableCellElement.webidl
Expand Up @@ -9,7 +9,7 @@ interface HTMLTableCellElement : HTMLElement {
attribute unsigned long colSpan;
// attribute unsigned long rowSpan;
//[PutForwards=value] readonly attribute DOMSettableTokenList headers;
//readonly attribute long cellIndex;
readonly attribute long cellIndex;

// also has obsolete members
};
Expand Down
9 changes: 0 additions & 9 deletions tests/wpt/metadata/html/dom/interfaces.html.ini
Expand Up @@ -4770,9 +4770,6 @@
[HTMLTableCellElement interface: document.createElement("td") must inherit property "headers" with the proper type (2)]
expected: FAIL

[HTMLTableCellElement interface: document.createElement("td") must inherit property "cellIndex" with the proper type (3)]
expected: FAIL

[HTMLTableCellElement interface: document.createElement("td") must inherit property "align" with the proper type (4)]
expected: FAIL

Expand Down Expand Up @@ -4833,9 +4830,6 @@
[HTMLTableCellElement interface: document.createElement("th") must inherit property "headers" with the proper type (2)]
expected: FAIL

[HTMLTableCellElement interface: document.createElement("th") must inherit property "cellIndex" with the proper type (3)]
expected: FAIL

[HTMLTableCellElement interface: document.createElement("th") must inherit property "align" with the proper type (4)]
expected: FAIL

Expand Down Expand Up @@ -4872,9 +4866,6 @@
[HTMLTableCellElement interface: attribute headers]
expected: FAIL

[HTMLTableCellElement interface: attribute cellIndex]
expected: FAIL

[HTMLTableCellElement interface: attribute align]
expected: FAIL

Expand Down

This file was deleted.

Expand Up @@ -38,4 +38,13 @@
var td = tr.appendChild(document.createElement("td"));
assert_equals(td.cellIndex, 1);
}, "For cells whose parent is a tr, cellIndex should be the index.")
test(function() {
var tr = document.createElement("tr");
var th = tr.appendChild(document.createElement("th"));
assert_equals(th.cellIndex, 0);
tr.appendChild(document.createElement("div"));
tr.appendChild(document.createTextNode("Hello World"));
var td = tr.appendChild(document.createElement("td"));
assert_equals(td.cellIndex, 1)
}, "For cells whose parent is a tr with non td/th sibling, cellIndex should skip those non td/th siblings.")
</script>

0 comments on commit 55769b2

Please sign in to comment.