diff options
author | Gregory Terzian <gterzian@users.noreply.github.com> | 2017-05-15 07:19:58 +0800 |
---|---|---|
committer | Gregory Terzian <gterzian@users.noreply.github.com> | 2017-05-19 17:29:16 +0800 |
commit | a8390aea2451928153bd744e7eeb73fc70564124 (patch) | |
tree | 0848b50b49447aa9ce47a523f75e319f1915a442 | |
parent | 5da0aa9f11b7b1c2dc8b5adf178eebafa92d1849 (diff) | |
download | servo-a8390aea2451928153bd744e7eeb73fc70564124.tar.gz servo-a8390aea2451928153bd744e7eeb73fc70564124.zip |
use microtasks to await a stable state
12 files changed, 47 insertions, 97 deletions
diff --git a/components/script/dom/htmlmediaelement.rs b/components/script/dom/htmlmediaelement.rs index 679294dae1a..eed7020887f 100644 --- a/components/script/dom/htmlmediaelement.rs +++ b/components/script/dom/htmlmediaelement.rs @@ -31,6 +31,7 @@ use dom_struct::dom_struct; use html5ever::{LocalName, Prefix}; use ipc_channel::ipc; use ipc_channel::router::ROUTER; +use microtask::{Microtask, MicrotaskRunnable}; use net_traits::{FetchResponseListener, FetchMetadata, Metadata, NetworkError}; use net_traits::request::{CredentialsMode, Destination, RequestInit, Type as RequestType}; use network_listener::{NetworkListener, PreInvoke}; @@ -429,7 +430,11 @@ impl HTMLMediaElement { // Step 4 let doc = document_from_node(self); - ScriptThread::await_stable_state(ResourceSelectionTask::new(self, doc.base_url())); + let task = MediaElementMicrotask::ResourceSelectionTask { + elem: Root::from_ref(self), + base_url: doc.base_url() + }; + ScriptThread::await_stable_state(Microtask::MediaElement(task)); } // https://html.spec.whatwg.org/multipage/#concept-media-load-algorithm @@ -781,7 +786,36 @@ impl VirtualMethods for HTMLMediaElement { self.super_type().unwrap().unbind_from_tree(context); if context.tree_in_doc { - ScriptThread::await_stable_state(PauseIfNotInDocumentTask::new(self)); + let task = MediaElementMicrotask::PauseIfNotInDocumentTask { + elem: Root::from_ref(self) + }; + ScriptThread::await_stable_state(Microtask::MediaElement(task)); + } + } +} + +#[derive(JSTraceable, HeapSizeOf)] +pub enum MediaElementMicrotask { + ResourceSelectionTask { + elem: Root<HTMLMediaElement>, + base_url: ServoUrl + }, + PauseIfNotInDocumentTask { + elem: Root<HTMLMediaElement>, + } +} + +impl MicrotaskRunnable for MediaElementMicrotask { + fn handler(&self) { + match self { + &MediaElementMicrotask::ResourceSelectionTask { ref elem, ref base_url } => { + elem.resource_selection_algorithm_sync(base_url.clone()); + }, + &MediaElementMicrotask::PauseIfNotInDocumentTask { ref elem } => { + if !elem.upcast::<Node>().is_in_doc() { + elem.internal_pause_steps(); + } + }, } } } @@ -809,28 +843,6 @@ impl Runnable for FireSimpleEventTask { } } -struct ResourceSelectionTask { - elem: Trusted<HTMLMediaElement>, - base_url: ServoUrl, -} - -impl ResourceSelectionTask { - fn new(elem: &HTMLMediaElement, url: ServoUrl) -> ResourceSelectionTask { - ResourceSelectionTask { - elem: Trusted::new(elem), - base_url: url, - } - } -} - -impl Runnable for ResourceSelectionTask { - fn name(&self) -> &'static str { "ResourceSelectionTask" } - - fn handler(self: Box<ResourceSelectionTask>) { - self.elem.root().resource_selection_algorithm_sync(self.base_url); - } -} - struct DedicatedMediaSourceFailureTask { elem: Trusted<HTMLMediaElement>, } @@ -851,29 +863,6 @@ impl Runnable for DedicatedMediaSourceFailureTask { } } -struct PauseIfNotInDocumentTask { - elem: Trusted<HTMLMediaElement>, -} - -impl PauseIfNotInDocumentTask { - fn new(elem: &HTMLMediaElement) -> PauseIfNotInDocumentTask { - PauseIfNotInDocumentTask { - elem: Trusted::new(elem), - } - } -} - -impl Runnable for PauseIfNotInDocumentTask { - fn name(&self) -> &'static str { "PauseIfNotInDocumentTask" } - - fn handler(self: Box<PauseIfNotInDocumentTask>) { - let elem = self.elem.root(); - if !elem.upcast::<Node>().is_in_doc() { - elem.internal_pause_steps(); - } - } -} - enum ResourceSelectionMode { Object, Attribute(String), diff --git a/components/script/microtask.rs b/components/script/microtask.rs index 7fadf111ddb..8f10dbcf489 100644 --- a/components/script/microtask.rs +++ b/components/script/microtask.rs @@ -11,6 +11,7 @@ use dom::bindings::cell::DOMRefCell; use dom::bindings::codegen::Bindings::PromiseBinding::PromiseJobCallback; use dom::bindings::js::Root; use dom::globalscope::GlobalScope; +use dom::htmlmediaelement::MediaElementMicrotask; use dom::mutationobserver::MutationObserver; use msg::constellation_msg::PipelineId; use std::cell::Cell; @@ -29,9 +30,14 @@ pub struct MicrotaskQueue { #[derive(JSTraceable, HeapSizeOf)] pub enum Microtask { Promise(EnqueuedPromiseCallback), + MediaElement(MediaElementMicrotask), NotifyMutationObservers, } +pub trait MicrotaskRunnable { + fn handler(&self) {} +} + /// A promise callback scheduled to run during the next microtask checkpoint (#4283). #[derive(JSTraceable, HeapSizeOf)] pub struct EnqueuedPromiseCallback { @@ -72,6 +78,9 @@ impl MicrotaskQueue { if let Some(target) = target_provider(job.pipeline) { let _ = job.callback.Call_(&*target, ExceptionHandling::Report); } + }, + Microtask::MediaElement(ref task) => { + task.handler(); } Microtask::NotifyMutationObservers => { MutationObserver::notify_mutation_observers(); diff --git a/components/script/script_thread.rs b/components/script/script_thread.rs index a8b20b6cf98..3f6c82b80ef 100644 --- a/components/script/script_thread.rs +++ b/components/script/script_thread.rs @@ -665,14 +665,11 @@ impl ScriptThread { } // https://html.spec.whatwg.org/multipage/#await-a-stable-state - pub fn await_stable_state<T: Runnable + Send + 'static>(task: T) { - //TODO use microtasks when they exist + pub fn await_stable_state(task: Microtask) { SCRIPT_THREAD_ROOT.with(|root| { if let Some(script_thread) = root.get() { let script_thread = unsafe { &*script_thread }; - let _ = script_thread.chan.send(CommonScriptMsg::RunnableMsg( - ScriptThreadEventCategory::DomEvent, - box task)); + script_thread.microtask_queue.enqueue(task); } }); } diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini deleted file mode 100644 index e40c139642f..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-in-sync-event.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-in-sync-event.html] - type: testharness - [await a stable state and sync event handlers] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini deleted file mode 100644 index f27a8b88e16..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-load.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-load.html] - type: testharness - [invoking resource selection with load()] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini deleted file mode 100644 index 3ca07b5635e..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause-networkState.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-pause-networkState.html] - type: testharness - [NOT invoking resource selection with pause() when networkState is not NETWORK_EMPTY] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini deleted file mode 100644 index 778a31e4fc0..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-pause.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-pause.html] - type: testharness - [invoking resource selection with pause()] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini deleted file mode 100644 index e0181017194..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-play.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-play.html] - type: testharness - [invoking resource selection with play()] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini deleted file mode 100644 index 0104538e3a5..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-remove-from-document-networkState.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-remove-from-document-networkState.html] - type: testharness - [NOT invoking resource selection with implicit pause() when networkState is not NETWORK_EMPTY] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini deleted file mode 100644 index b4b13f4b436..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src-not-in-document.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-set-src-not-in-document.html] - type: testharness - [invoking load by setting src on video not in a document] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini deleted file mode 100644 index 7ee9523c423..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-invoke-set-src.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-invoke-set-src.html] - type: testharness - [invoking load by setting src] - expected: FAIL - diff --git a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini b/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini deleted file mode 100644 index 1e560e440e6..00000000000 --- a/tests/wpt/metadata/html/semantics/embedded-content/media-elements/loading-the-media-resource/resource-selection-remove-src.html.ini +++ /dev/null @@ -1,5 +0,0 @@ -[resource-selection-remove-src.html] - type: testharness - [invoking resource selection by setting src; await stable state] - expected: FAIL - |