diff options
author | Sankha Narayan Guria <sankha93@gmail.com> | 2014-02-27 03:31:05 +0530 |
---|---|---|
committer | Sankha Narayan Guria <sankha93@gmail.com> | 2014-02-27 03:31:05 +0530 |
commit | 1e9fec9172364346937f375e315e1ce745662611 (patch) | |
tree | a55173568e6dd6a8b4cb4dfcc42ed81204d49874 /src/components/script/dom/text.rs | |
parent | 47e6e6ec8f2dfbd56e50f9f2ec2762b85087d948 (diff) | |
parent | da16e54243e256dee927f720ce6b9903b62ec14e (diff) | |
download | servo-1e9fec9172364346937f375e315e1ce745662611.tar.gz servo-1e9fec9172364346937f375e315e1ce745662611.zip |
Merge master into this branch
Diffstat (limited to 'src/components/script/dom/text.rs')
-rw-r--r-- | src/components/script/dom/text.rs | 31 |
1 files changed, 22 insertions, 9 deletions
diff --git a/src/components/script/dom/text.rs b/src/components/script/dom/text.rs index 9ed8ba7a8b6..2d81937849e 100644 --- a/src/components/script/dom/text.rs +++ b/src/components/script/dom/text.rs @@ -3,35 +3,48 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ use dom::bindings::codegen::TextBinding; +use dom::bindings::codegen::InheritTypes::TextDerived; +use dom::bindings::js::JS; use dom::bindings::utils::Fallible; use dom::characterdata::CharacterData; -use dom::document::AbstractDocument; -use dom::node::{AbstractNode, Node, TextNodeTypeId}; +use dom::document::Document; +use dom::eventtarget::{EventTarget, NodeTargetTypeId}; +use dom::node::{Node, TextNodeTypeId}; use dom::window::Window; use servo_util::str::DOMString; /// An HTML text node. +#[deriving(Encodable)] pub struct Text { characterdata: CharacterData, } +impl TextDerived for EventTarget { + fn is_text(&self) -> bool { + match self.type_id { + NodeTargetTypeId(TextNodeTypeId) => true, + _ => false + } + } +} + impl Text { - pub fn new_inherited(text: DOMString, document: AbstractDocument) -> Text { + pub fn new_inherited(text: DOMString, document: JS<Document>) -> Text { Text { characterdata: CharacterData::new_inherited(TextNodeTypeId, text, document) } } - pub fn new(text: DOMString, document: AbstractDocument) -> AbstractNode { - let node = Text::new_inherited(text, document); - Node::reflect_node(@mut node, document, TextBinding::Wrap) + pub fn new(text: DOMString, document: &JS<Document>) -> JS<Text> { + let node = Text::new_inherited(text, document.clone()); + Node::reflect_node(~node, document, TextBinding::Wrap) } - pub fn Constructor(owner: @mut Window, text: DOMString) -> Fallible<AbstractNode> { - Ok(Text::new(text.clone(), owner.Document())) + pub fn Constructor(owner: &JS<Window>, text: DOMString) -> Fallible<JS<Text>> { + Ok(Text::new(text.clone(), &owner.get().Document())) } - pub fn SplitText(&self, _offset: u32) -> Fallible<AbstractNode> { + pub fn SplitText(&self, _offset: u32) -> Fallible<JS<Text>> { fail!("unimplemented") } |