Add stubs for src and currentSrc for HTMLMediaElement.

This commit is contained in:
Josh Matthews 2015-11-06 16:50:34 -06:00
parent b8b4be34c0
commit 53f9307fb7
5 changed files with 45 additions and 344 deletions

View file

@ -2,10 +2,15 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this * License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
use dom::attr::Attr;
use dom::bindings::cell::DOMRefCell;
use dom::bindings::codegen::Bindings::HTMLMediaElementBinding::HTMLMediaElementMethods; use dom::bindings::codegen::Bindings::HTMLMediaElementBinding::HTMLMediaElementMethods;
use dom::bindings::codegen::Bindings::HTMLMediaElementBinding::HTMLMediaElementConstants; use dom::bindings::codegen::Bindings::HTMLMediaElementBinding::HTMLMediaElementConstants;
use dom::bindings::inheritance::Castable;
use dom::document::Document; use dom::document::Document;
use dom::element::AttributeMutation;
use dom::htmlelement::HTMLElement; use dom::htmlelement::HTMLElement;
use dom::virtualmethods::VirtualMethods;
use std::cell::Cell; use std::cell::Cell;
use string_cache::Atom; use string_cache::Atom;
use util::str::DOMString; use util::str::DOMString;
@ -15,6 +20,7 @@ pub struct HTMLMediaElement {
htmlelement: HTMLElement, htmlelement: HTMLElement,
network_state: Cell<u16>, network_state: Cell<u16>,
ready_state: Cell<u16>, ready_state: Cell<u16>,
current_src: DOMRefCell<String>,
} }
impl HTMLMediaElement { impl HTMLMediaElement {
@ -26,6 +32,7 @@ impl HTMLMediaElement {
HTMLElement::new_inherited(tag_name, prefix, document), HTMLElement::new_inherited(tag_name, prefix, document),
network_state: Cell::new(HTMLMediaElementConstants::NETWORK_EMPTY), network_state: Cell::new(HTMLMediaElementConstants::NETWORK_EMPTY),
ready_state: Cell::new(HTMLMediaElementConstants::HAVE_NOTHING), ready_state: Cell::new(HTMLMediaElementConstants::HAVE_NOTHING),
current_src: DOMRefCell::new("".to_owned()),
} }
} }
@ -33,6 +40,9 @@ impl HTMLMediaElement {
pub fn htmlelement(&self) -> &HTMLElement { pub fn htmlelement(&self) -> &HTMLElement {
&self.htmlelement &self.htmlelement
} }
fn media_element_load_algorithm(&self, _src: &str) {
}
} }
impl HTMLMediaElementMethods for HTMLMediaElement { impl HTMLMediaElementMethods for HTMLMediaElement {
@ -43,4 +53,33 @@ impl HTMLMediaElementMethods for HTMLMediaElement {
fn ReadyState(&self) -> u16 { fn ReadyState(&self) -> u16 {
self.ready_state.get() self.ready_state.get()
} }
// https://html.spec.whatwg.org/multipage/#dom-media-src
make_url_getter!(Src, "src");
// https://html.spec.whatwg.org/multipage/#dom-media-src
make_setter!(SetSrc, "src");
// https://html.spec.whatwg.org/multipage/#dom-media-currentsrc
fn CurrentSrc(&self) -> DOMString {
DOMString::from(self.current_src.borrow().clone())
}
}
impl VirtualMethods for HTMLMediaElement {
fn super_type(&self) -> Option<&VirtualMethods> {
Some(self.upcast::<HTMLElement>() as &VirtualMethods)
}
fn attribute_mutated(&self, attr: &Attr, mutation: AttributeMutation) {
self.super_type().unwrap().attribute_mutated(attr, mutation);
match attr.local_name() {
&atom!("src") => {
if let Some(value) = mutation.new_value(attr) {
self.media_element_load_algorithm(&value);
}
}
_ => (),
};
}
} }

View file

@ -29,6 +29,7 @@ use dom::htmlimageelement::HTMLImageElement;
use dom::htmlinputelement::HTMLInputElement; use dom::htmlinputelement::HTMLInputElement;
use dom::htmllabelelement::HTMLLabelElement; use dom::htmllabelelement::HTMLLabelElement;
use dom::htmllinkelement::HTMLLinkElement; use dom::htmllinkelement::HTMLLinkElement;
use dom::htmlmediaelement::HTMLMediaElement;
use dom::htmlmetaelement::HTMLMetaElement; use dom::htmlmetaelement::HTMLMetaElement;
use dom::htmlobjectelement::HTMLObjectElement; use dom::htmlobjectelement::HTMLObjectElement;
use dom::htmloptgroupelement::HTMLOptGroupElement; use dom::htmloptgroupelement::HTMLOptGroupElement;
@ -181,6 +182,9 @@ pub fn vtable_for(node: &Node) -> &VirtualMethods {
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLLinkElement)) => { NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLLinkElement)) => {
node.downcast::<HTMLLinkElement>().unwrap() as &VirtualMethods node.downcast::<HTMLLinkElement>().unwrap() as &VirtualMethods
} }
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLMediaElement(_))) => {
node.downcast::<HTMLMediaElement>().unwrap() as &VirtualMethods
}
NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLMetaElement)) => { NodeTypeId::Element(ElementTypeId::HTMLElement(HTMLElementTypeId::HTMLMetaElement)) => {
node.downcast::<HTMLMetaElement>().unwrap() as &VirtualMethods node.downcast::<HTMLMetaElement>().unwrap() as &VirtualMethods
} }

View file

@ -11,8 +11,8 @@ interface HTMLMediaElement : HTMLElement {
//readonly attribute MediaError? error; //readonly attribute MediaError? error;
// network state // network state
// attribute DOMString src; attribute DOMString src;
//readonly attribute DOMString currentSrc; readonly attribute DOMString currentSrc;
// attribute DOMString crossOrigin; // attribute DOMString crossOrigin;
const unsigned short NETWORK_EMPTY = 0; const unsigned short NETWORK_EMPTY = 0;
const unsigned short NETWORK_IDLE = 1; const unsigned short NETWORK_IDLE = 1;

View file

@ -2622,12 +2622,6 @@
[HTMLMediaElement interface: document.createElement("video") must inherit property "error" with the proper type (0)] [HTMLMediaElement interface: document.createElement("video") must inherit property "error" with the proper type (0)]
expected: FAIL expected: FAIL
[HTMLMediaElement interface: document.createElement("video") must inherit property "src" with the proper type (1)]
expected: FAIL
[HTMLMediaElement interface: document.createElement("video") must inherit property "currentSrc" with the proper type (2)]
expected: FAIL
[HTMLMediaElement interface: document.createElement("video") must inherit property "crossOrigin" with the proper type (3)] [HTMLMediaElement interface: document.createElement("video") must inherit property "crossOrigin" with the proper type (3)]
expected: FAIL expected: FAIL
@ -2730,12 +2724,6 @@
[HTMLMediaElement interface: document.createElement("audio") must inherit property "error" with the proper type (0)] [HTMLMediaElement interface: document.createElement("audio") must inherit property "error" with the proper type (0)]
expected: FAIL expected: FAIL
[HTMLMediaElement interface: document.createElement("audio") must inherit property "src" with the proper type (1)]
expected: FAIL
[HTMLMediaElement interface: document.createElement("audio") must inherit property "currentSrc" with the proper type (2)]
expected: FAIL
[HTMLMediaElement interface: document.createElement("audio") must inherit property "crossOrigin" with the proper type (3)] [HTMLMediaElement interface: document.createElement("audio") must inherit property "crossOrigin" with the proper type (3)]
expected: FAIL expected: FAIL
@ -3093,12 +3081,6 @@
[HTMLMediaElement interface: attribute error] [HTMLMediaElement interface: attribute error]
expected: FAIL expected: FAIL
[HTMLMediaElement interface: attribute src]
expected: FAIL
[HTMLMediaElement interface: attribute currentSrc]
expected: FAIL
[HTMLMediaElement interface: attribute crossOrigin] [HTMLMediaElement interface: attribute crossOrigin]
expected: FAIL expected: FAIL

View file

@ -9429,168 +9429,6 @@
[video.tabIndex: IDL set to -2147483648 followed by getAttribute()] [video.tabIndex: IDL set to -2147483648 followed by getAttribute()]
expected: FAIL expected: FAIL
[video.src: typeof IDL attribute]
expected: FAIL
[video.src: IDL get with DOM attribute unset]
expected: FAIL
[video.src: setAttribute() to "" followed by IDL get]
expected: FAIL
[video.src: setAttribute() to " foo " followed by IDL get]
expected: FAIL
[video.src: setAttribute() to "http://site.example/" followed by IDL get]
expected: FAIL
[video.src: setAttribute() to "//site.example/path???@#l" followed by IDL get]
expected: FAIL
[video.src: setAttribute() to "\\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f " followed by IDL get]
expected: FAIL
[video.src: setAttribute() to undefined followed by IDL get]
expected: FAIL
[video.src: setAttribute() to 7 followed by IDL get]
expected: FAIL
[video.src: setAttribute() to 1.5 followed by IDL get]
expected: FAIL
[video.src: setAttribute() to true followed by IDL get]
expected: FAIL
[video.src: setAttribute() to false followed by IDL get]
expected: FAIL
[video.src: setAttribute() to object "[object Object\]" followed by IDL get]
expected: FAIL
[video.src: setAttribute() to NaN followed by IDL get]
expected: FAIL
[video.src: setAttribute() to Infinity followed by IDL get]
expected: FAIL
[video.src: setAttribute() to -Infinity followed by IDL get]
expected: FAIL
[video.src: setAttribute() to "\\0" followed by IDL get]
expected: FAIL
[video.src: setAttribute() to null followed by IDL get]
expected: FAIL
[video.src: setAttribute() to object "test-toString" followed by IDL get]
expected: FAIL
[video.src: setAttribute() to object "test-valueOf" followed by IDL get]
expected: FAIL
[video.src: IDL set to "" followed by getAttribute()]
expected: FAIL
[video.src: IDL set to "" followed by IDL get]
expected: FAIL
[video.src: IDL set to " foo " followed by getAttribute()]
expected: FAIL
[video.src: IDL set to " foo " followed by IDL get]
expected: FAIL
[video.src: IDL set to "http://site.example/" followed by getAttribute()]
expected: FAIL
[video.src: IDL set to "//site.example/path???@#l" followed by getAttribute()]
expected: FAIL
[video.src: IDL set to "//site.example/path???@#l" followed by IDL get]
expected: FAIL
[video.src: IDL set to "\\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f " followed by getAttribute()]
expected: FAIL
[video.src: IDL set to "\\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f " followed by IDL get]
expected: FAIL
[video.src: IDL set to undefined followed by getAttribute()]
expected: FAIL
[video.src: IDL set to undefined followed by IDL get]
expected: FAIL
[video.src: IDL set to 7 followed by getAttribute()]
expected: FAIL
[video.src: IDL set to 7 followed by IDL get]
expected: FAIL
[video.src: IDL set to 1.5 followed by getAttribute()]
expected: FAIL
[video.src: IDL set to 1.5 followed by IDL get]
expected: FAIL
[video.src: IDL set to true followed by getAttribute()]
expected: FAIL
[video.src: IDL set to true followed by IDL get]
expected: FAIL
[video.src: IDL set to false followed by getAttribute()]
expected: FAIL
[video.src: IDL set to false followed by IDL get]
expected: FAIL
[video.src: IDL set to object "[object Object\]" followed by getAttribute()]
expected: FAIL
[video.src: IDL set to object "[object Object\]" followed by IDL get]
expected: FAIL
[video.src: IDL set to NaN followed by getAttribute()]
expected: FAIL
[video.src: IDL set to NaN followed by IDL get]
expected: FAIL
[video.src: IDL set to Infinity followed by getAttribute()]
expected: FAIL
[video.src: IDL set to Infinity followed by IDL get]
expected: FAIL
[video.src: IDL set to -Infinity followed by getAttribute()]
expected: FAIL
[video.src: IDL set to -Infinity followed by IDL get]
expected: FAIL
[video.src: IDL set to "\\0" followed by getAttribute()]
expected: FAIL
[video.src: IDL set to "\\0" followed by IDL get]
expected: FAIL
[video.src: IDL set to null followed by getAttribute()]
expected: FAIL
[video.src: IDL set to null followed by IDL get]
expected: FAIL
[video.src: IDL set to object "test-toString" followed by getAttribute()]
expected: FAIL
[video.src: IDL set to object "test-toString" followed by IDL get]
expected: FAIL
[video.src: IDL set to object "test-valueOf" followed by IDL get]
expected: FAIL
[video.crossOrigin: typeof IDL attribute] [video.crossOrigin: typeof IDL attribute]
expected: FAIL expected: FAIL
@ -11739,168 +11577,6 @@
[audio.tabIndex: IDL set to -2147483648 followed by getAttribute()] [audio.tabIndex: IDL set to -2147483648 followed by getAttribute()]
expected: FAIL expected: FAIL
[audio.src: typeof IDL attribute]
expected: FAIL
[audio.src: IDL get with DOM attribute unset]
expected: FAIL
[audio.src: setAttribute() to "" followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to " foo " followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to "http://site.example/" followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to "//site.example/path???@#l" followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to "\\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f " followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to undefined followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to 7 followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to 1.5 followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to true followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to false followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to object "[object Object\]" followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to NaN followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to Infinity followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to -Infinity followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to "\\0" followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to null followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to object "test-toString" followed by IDL get]
expected: FAIL
[audio.src: setAttribute() to object "test-valueOf" followed by IDL get]
expected: FAIL
[audio.src: IDL set to "" followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to "" followed by IDL get]
expected: FAIL
[audio.src: IDL set to " foo " followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to " foo " followed by IDL get]
expected: FAIL
[audio.src: IDL set to "http://site.example/" followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to "//site.example/path???@#l" followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to "//site.example/path???@#l" followed by IDL get]
expected: FAIL
[audio.src: IDL set to "\\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f " followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to "\\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f " followed by IDL get]
expected: FAIL
[audio.src: IDL set to undefined followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to undefined followed by IDL get]
expected: FAIL
[audio.src: IDL set to 7 followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to 7 followed by IDL get]
expected: FAIL
[audio.src: IDL set to 1.5 followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to 1.5 followed by IDL get]
expected: FAIL
[audio.src: IDL set to true followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to true followed by IDL get]
expected: FAIL
[audio.src: IDL set to false followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to false followed by IDL get]
expected: FAIL
[audio.src: IDL set to object "[object Object\]" followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to object "[object Object\]" followed by IDL get]
expected: FAIL
[audio.src: IDL set to NaN followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to NaN followed by IDL get]
expected: FAIL
[audio.src: IDL set to Infinity followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to Infinity followed by IDL get]
expected: FAIL
[audio.src: IDL set to -Infinity followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to -Infinity followed by IDL get]
expected: FAIL
[audio.src: IDL set to "\\0" followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to "\\0" followed by IDL get]
expected: FAIL
[audio.src: IDL set to null followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to null followed by IDL get]
expected: FAIL
[audio.src: IDL set to object "test-toString" followed by getAttribute()]
expected: FAIL
[audio.src: IDL set to object "test-toString" followed by IDL get]
expected: FAIL
[audio.src: IDL set to object "test-valueOf" followed by IDL get]
expected: FAIL
[audio.crossOrigin: typeof IDL attribute] [audio.crossOrigin: typeof IDL attribute]
expected: FAIL expected: FAIL