aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/htmlfieldsetelement.rs
diff options
context:
space:
mode:
authorJosh Matthews <josh@joshmatthews.net>2014-03-31 18:41:28 -0400
committerJosh Matthews <josh@joshmatthews.net>2014-05-03 14:18:30 -0400
commitd7b96db33ca8f2b8a162df38e0f00e95f5ea6fa1 (patch)
treeefd1e7f7ec1dd30467c2a67306e1a639837abead /src/components/script/dom/htmlfieldsetelement.rs
parentffdc3f5b32a345b88eed774848924e862d47c093 (diff)
downloadservo-d7b96db33ca8f2b8a162df38e0f00e95f5ea6fa1.tar.gz
servo-d7b96db33ca8f2b8a162df38e0f00e95f5ea6fa1.zip
Implement safe rooting strategy via Unrooted, Root, JSRef, and JS.
Diffstat (limited to 'src/components/script/dom/htmlfieldsetelement.rs')
-rw-r--r--src/components/script/dom/htmlfieldsetelement.rs25
1 files changed, 12 insertions, 13 deletions
diff --git a/src/components/script/dom/htmlfieldsetelement.rs b/src/components/script/dom/htmlfieldsetelement.rs
index 3b1141f403e..1bb9146e4e7 100644
--- a/src/components/script/dom/htmlfieldsetelement.rs
+++ b/src/components/script/dom/htmlfieldsetelement.rs
@@ -4,7 +4,7 @@
use dom::bindings::codegen::BindingDeclarations::HTMLFieldSetElementBinding;
use dom::bindings::codegen::InheritTypes::{ElementCast, HTMLFieldSetElementDerived, NodeCast};
-use dom::bindings::js::{JS, JSRef, RootCollection};
+use dom::bindings::js::{JS, JSRef, RootCollection, Unrooted};
use dom::bindings::error::ErrorResult;
use dom::document::Document;
use dom::element::{Element, HTMLFieldSetElementTypeId};
@@ -37,7 +37,7 @@ impl HTMLFieldSetElement {
}
}
- pub fn new(localName: DOMString, document: &JSRef<Document>) -> JS<HTMLFieldSetElement> {
+ pub fn new(localName: DOMString, document: &JSRef<Document>) -> Unrooted<HTMLFieldSetElement> {
let element = HTMLFieldSetElement::new_inherited(localName, document.unrooted());
Node::reflect_node(~element, document, HTMLFieldSetElementBinding::Wrap)
}
@@ -52,7 +52,7 @@ impl HTMLFieldSetElement {
Ok(())
}
- pub fn GetForm(&self) -> Option<JS<HTMLFormElement>> {
+ pub fn GetForm(&self) -> Option<Unrooted<HTMLFormElement>> {
None
}
@@ -69,33 +69,32 @@ impl HTMLFieldSetElement {
}
// http://www.whatwg.org/html/#dom-fieldset-elements
- pub fn Elements(&self, abstract_self: &JSRef<HTMLFieldSetElement>) -> JS<HTMLCollection> {
+ pub fn Elements(&self, abstract_self: &JSRef<HTMLFieldSetElement>) -> Unrooted<HTMLCollection> {
struct ElementsFilter;
impl CollectionFilter for ElementsFilter {
fn filter(&self, elem: &JSRef<Element>, root: &JSRef<Node>) -> bool {
static tag_names: StaticStringVec = &["button", "fieldset", "input",
"keygen", "object", "output", "select", "textarea"];
- let root: &JS<Element> = &ElementCast::to(&root.unrooted()).unwrap();
- &elem.unrooted() != root && tag_names.iter().any(|&tag_name| tag_name == elem.get().local_name)
+ let root: &JSRef<Element> = ElementCast::to_ref(root).unwrap();
+ elem != root && tag_names.iter().any(|&tag_name| tag_name == elem.get().local_name)
}
}
let roots = RootCollection::new();
let node: &JSRef<Node> = NodeCast::from_ref(abstract_self);
let filter = ~ElementsFilter;
- let window = window_from_node(&node.unrooted()).root(&roots);
- HTMLCollection::create(&window.root_ref(), node, filter)
+ let window = window_from_node(node).root(&roots);
+ HTMLCollection::create(&*window, node, filter)
}
pub fn WillValidate(&self) -> bool {
false
}
- pub fn Validity(&self) -> JS<ValidityState> {
+ pub fn Validity(&self) -> Unrooted<ValidityState> {
let roots = RootCollection::new();
- let doc = self.htmlelement.element.node.owner_doc();
- let doc = doc.get();
- let window = doc.window.root(&roots);
- ValidityState::new(&window.root_ref())
+ let doc = self.htmlelement.element.node.owner_doc().root(&roots);
+ let window = doc.deref().window.root(&roots);
+ ValidityState::new(&*window)
}
pub fn ValidationMessage(&self) -> DOMString {