diff options
author | bors-servo <metajack+bors@gmail.com> | 2015-07-25 11:39:20 -0600 |
---|---|---|
committer | bors-servo <metajack+bors@gmail.com> | 2015-07-25 11:39:20 -0600 |
commit | 705c95dedbbaa60ffd08e70579915e228d5b6ee0 (patch) | |
tree | 4cbafee85f191cfbd96986b4d520610adb27a26c /components/script/dom/htmlstyleelement.rs | |
parent | 8edf1a5ecdecc9f6de8210fc875cff3679fda09e (diff) | |
parent | 7b40cc9fd7ea4dcc3816be0cb1ad6543bb5c88e0 (diff) | |
download | servo-705c95dedbbaa60ffd08e70579915e228d5b6ee0.tar.gz servo-705c95dedbbaa60ffd08e70579915e228d5b6ee0.zip |
Auto merge of #6660 - nox:children-changed, r=jdm
Introduce VirtualMethods::children_changed()
This virtual method mimics the behaviour of mutation observers and make it more viable than the older child_inserted(), which didn't cover removed nodes and was called as many times as there were inserted nodes.
A few other shortcomings where remove_child() was called directly instead of Node::remove() were also fixed while at it.
<!-- Reviewable:start -->
[<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/6660)
<!-- Reviewable:end -->
Diffstat (limited to 'components/script/dom/htmlstyleelement.rs')
-rw-r--r-- | components/script/dom/htmlstyleelement.rs | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/components/script/dom/htmlstyleelement.rs b/components/script/dom/htmlstyleelement.rs index 7c1c06412ef..22c4c705ccb 100644 --- a/components/script/dom/htmlstyleelement.rs +++ b/components/script/dom/htmlstyleelement.rs @@ -11,7 +11,8 @@ use dom::document::Document; use dom::eventtarget::{EventTarget, EventTargetTypeId}; use dom::element::{ElementTypeId, AttributeHandlers}; use dom::htmlelement::{HTMLElement, HTMLElementTypeId}; -use dom::node::{Node, NodeHelpers, NodeTypeId, window_from_node}; +use dom::node::{ChildrenMutation, Node, NodeHelpers, NodeTypeId}; +use dom::node::window_from_node; use dom::virtualmethods::VirtualMethods; use dom::window::WindowHelpers; use layout_interface::{LayoutChan, Msg}; @@ -86,11 +87,10 @@ impl<'a> VirtualMethods for &'a HTMLStyleElement { Some(htmlelement as &VirtualMethods) } - fn child_inserted(&self, child: &Node) { + fn children_changed(&self, mutation: &ChildrenMutation) { if let Some(ref s) = self.super_type() { - s.child_inserted(child); + s.children_changed(mutation); } - let node = NodeCast::from_ref(*self); if node.is_in_doc() { self.parse_own_css(); |