diff options
author | Jinwoo Song <jinwoo7.song@samsung.com> | 2015-04-29 18:08:37 +0900 |
---|---|---|
committer | Jinwoo Song <jinwoo7.song@samsung.com> | 2015-05-27 16:37:30 +0900 |
commit | 4e8005cd5bc033849e16dd3c164f4d4582c61b5c (patch) | |
tree | 4dc0848df13d7a6e041e852effd601d226d08f58 /components/script/dom/nodeiterator.rs | |
parent | 0e4c792dc5c061ed2b4faad8619ccb63ba30abfe (diff) | |
download | servo-4e8005cd5bc033849e16dd3c164f4d4582c61b5c.tar.gz servo-4e8005cd5bc033849e16dd3c164f4d4582c61b5c.zip |
Implement Document.createNodeIterator and rebase patch
Diffstat (limited to 'components/script/dom/nodeiterator.rs')
-rw-r--r-- | components/script/dom/nodeiterator.rs | 12 |
1 files changed, 5 insertions, 7 deletions
diff --git a/components/script/dom/nodeiterator.rs b/components/script/dom/nodeiterator.rs index 33e630bd8cf..5d2850228fe 100644 --- a/components/script/dom/nodeiterator.rs +++ b/components/script/dom/nodeiterator.rs @@ -7,18 +7,16 @@ use dom::bindings::codegen::Bindings::NodeIteratorBinding::NodeIteratorMethods; use dom::bindings::codegen::Bindings::NodeFilterBinding::NodeFilter; use dom::bindings::error::Fallible; use dom::bindings::global::GlobalRef; -use dom::bindings::js::{JS, JSRef, Temporary}; -use dom::bindings::js::MutNullableJS; +use dom::bindings::js::{JS, JSRef, MutNullableHeap, Temporary, Rootable}; use dom::bindings::utils::{Reflector, reflect_dom_object}; use dom::document::{Document, DocumentHelpers}; use dom::node::{Node}; -use std::default::Default; #[dom_struct] pub struct NodeIterator { reflector_: Reflector, root_node: JS<Node>, - reference_node: MutNullableJS<Node>, + reference_node: MutNullableHeap<JS<Node>>, what_to_show: u32, filter: Filter } @@ -30,7 +28,7 @@ impl NodeIterator { NodeIterator { reflector_: Reflector::new(), root_node: JS::from_rooted(root_node), - reference_node: Default::default(), + reference_node: MutNullableHeap::new(Some(JS::from_rooted(root_node))), what_to_show: what_to_show, filter: filter } @@ -61,7 +59,7 @@ impl NodeIterator { impl<'a> NodeIteratorMethods for JSRef<'a, NodeIterator> { // https://dom.spec.whatwg.org/#dom-nodeiterator-root fn Root(self) -> Temporary<Node> { - Temporary::new(self.root_node) + Temporary::from_rooted(self.root_node) } // https://dom.spec.whatwg.org/#dom-nodeiterator-whattoshow @@ -80,7 +78,7 @@ impl<'a> NodeIteratorMethods for JSRef<'a, NodeIterator> { // https://dom.spec.whatwg.org/#dom-nodeiterator-referencenode fn GetReferenceNode(self) -> Option<Temporary<Node>> { - self.reference_node.get() + self.reference_node.get().map(Temporary::from_rooted) } // https://dom.spec.whatwg.org/#dom-nodeiterator-previousnode |