mirror of
https://github.com/servo/servo.git
synced 2025-08-04 05:00:08 +01:00
Implement src setter for HTMLIFrameElement #2529
This commit is contained in:
parent
78991c896e
commit
b01a4d7a69
1 changed files with 40 additions and 26 deletions
|
@ -4,7 +4,8 @@
|
||||||
|
|
||||||
use dom::bindings::codegen::Bindings::HTMLIFrameElementBinding;
|
use dom::bindings::codegen::Bindings::HTMLIFrameElementBinding;
|
||||||
use dom::bindings::codegen::Bindings::HTMLIFrameElementBinding::HTMLIFrameElementMethods;
|
use dom::bindings::codegen::Bindings::HTMLIFrameElementBinding::HTMLIFrameElementMethods;
|
||||||
use dom::bindings::codegen::InheritTypes::{ElementCast, HTMLIFrameElementDerived, HTMLElementCast};
|
use dom::bindings::codegen::InheritTypes::{NodeCast, ElementCast};
|
||||||
|
use dom::bindings::codegen::InheritTypes::{HTMLElementCast, HTMLIFrameElementDerived};
|
||||||
use dom::bindings::js::{JSRef, Temporary, OptionalRootable};
|
use dom::bindings::js::{JSRef, Temporary, OptionalRootable};
|
||||||
use dom::bindings::trace::Traceable;
|
use dom::bindings::trace::Traceable;
|
||||||
use dom::bindings::utils::{Reflectable, Reflector};
|
use dom::bindings::utils::{Reflectable, Reflector};
|
||||||
|
@ -13,7 +14,7 @@ use dom::element::{HTMLIFrameElementTypeId, Element};
|
||||||
use dom::element::AttributeHandlers;
|
use dom::element::AttributeHandlers;
|
||||||
use dom::eventtarget::{EventTarget, NodeTargetTypeId};
|
use dom::eventtarget::{EventTarget, NodeTargetTypeId};
|
||||||
use dom::htmlelement::HTMLElement;
|
use dom::htmlelement::HTMLElement;
|
||||||
use dom::node::{Node, ElementNodeTypeId, window_from_node};
|
use dom::node::{Node, NodeHelpers, ElementNodeTypeId, window_from_node};
|
||||||
use dom::virtualmethods::VirtualMethods;
|
use dom::virtualmethods::VirtualMethods;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
use page::IterablePage;
|
use page::IterablePage;
|
||||||
|
@ -59,6 +60,8 @@ pub struct IFrameSize {
|
||||||
pub trait HTMLIFrameElementHelpers {
|
pub trait HTMLIFrameElementHelpers {
|
||||||
fn is_sandboxed(&self) -> bool;
|
fn is_sandboxed(&self) -> bool;
|
||||||
fn get_url(&self) -> Option<Url>;
|
fn get_url(&self) -> Option<Url>;
|
||||||
|
/// http://www.whatwg.org/html/#process-the-iframe-attributes
|
||||||
|
fn process_the_iframe_attributes(&self);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> HTMLIFrameElementHelpers for JSRef<'a, HTMLIFrameElement> {
|
impl<'a> HTMLIFrameElementHelpers for JSRef<'a, HTMLIFrameElement> {
|
||||||
|
@ -74,6 +77,32 @@ impl<'a> HTMLIFrameElementHelpers for JSRef<'a, HTMLIFrameElement> {
|
||||||
.parse(src.deref().value().as_slice()).ok()
|
.parse(src.deref().value().as_slice()).ok()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn process_the_iframe_attributes(&self) {
|
||||||
|
match self.get_url() {
|
||||||
|
Some(url) => {
|
||||||
|
let sandboxed = if self.is_sandboxed() {
|
||||||
|
IFrameSandboxed
|
||||||
|
} else {
|
||||||
|
IFrameUnsandboxed
|
||||||
|
};
|
||||||
|
|
||||||
|
// Subpage Id
|
||||||
|
let window = window_from_node(self).root();
|
||||||
|
let page = window.deref().page();
|
||||||
|
let subpage_id = page.get_next_subpage_id();
|
||||||
|
|
||||||
|
self.deref().size.deref().set(Some(IFrameSize {
|
||||||
|
pipeline_id: page.id,
|
||||||
|
subpage_id: subpage_id,
|
||||||
|
}));
|
||||||
|
|
||||||
|
let ConstellationChan(ref chan) = *page.constellation_chan.deref();
|
||||||
|
chan.send(LoadIframeUrlMsg(url, page.id, subpage_id, sandboxed));
|
||||||
|
}
|
||||||
|
_ => ()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl HTMLIFrameElement {
|
impl HTMLIFrameElement {
|
||||||
|
@ -155,6 +184,13 @@ impl<'a> VirtualMethods for JSRef<'a, HTMLIFrameElement> {
|
||||||
}
|
}
|
||||||
self.deref().sandbox.deref().set(Some(modes));
|
self.deref().sandbox.deref().set(Some(modes));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if "src" == name.as_slice() {
|
||||||
|
let node: &JSRef<Node> = NodeCast::from_ref(self);
|
||||||
|
if node.is_in_doc() {
|
||||||
|
self.process_the_iframe_attributes()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn before_remove_attr(&self, name: DOMString, value: DOMString) {
|
fn before_remove_attr(&self, name: DOMString, value: DOMString) {
|
||||||
|
@ -174,30 +210,8 @@ impl<'a> VirtualMethods for JSRef<'a, HTMLIFrameElement> {
|
||||||
_ => (),
|
_ => (),
|
||||||
}
|
}
|
||||||
|
|
||||||
if !tree_in_doc { return; }
|
if tree_in_doc {
|
||||||
|
self.process_the_iframe_attributes();
|
||||||
match self.get_url() {
|
|
||||||
Some(url) => {
|
|
||||||
let sandboxed = if self.is_sandboxed() {
|
|
||||||
IFrameSandboxed
|
|
||||||
} else {
|
|
||||||
IFrameUnsandboxed
|
|
||||||
};
|
|
||||||
|
|
||||||
// Subpage Id
|
|
||||||
let window = window_from_node(self).root();
|
|
||||||
let page = window.deref().page();
|
|
||||||
let subpage_id = page.get_next_subpage_id();
|
|
||||||
|
|
||||||
self.deref().size.deref().set(Some(IFrameSize {
|
|
||||||
pipeline_id: page.id,
|
|
||||||
subpage_id: subpage_id,
|
|
||||||
}));
|
|
||||||
|
|
||||||
let ConstellationChan(ref chan) = *page.constellation_chan.deref();
|
|
||||||
chan.send(LoadIframeUrlMsg(url, page.id, subpage_id, sandboxed));
|
|
||||||
}
|
|
||||||
_ => ()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue