From b7452f37d9b0d9ba3b660957e21c71795e490270 Mon Sep 17 00:00:00 2001 From: Anthony Ramine Date: Tue, 10 Oct 2017 10:10:39 +0200 Subject: [PATCH] Properly abort any ongoing resource selection on loading a new media --- components/script/dom/htmlmediaelement.rs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/components/script/dom/htmlmediaelement.rs b/components/script/dom/htmlmediaelement.rs index 0d66f1d63aa..db2fef3a821 100644 --- a/components/script/dom/htmlmediaelement.rs +++ b/components/script/dom/htmlmediaelement.rs @@ -430,6 +430,7 @@ impl HTMLMediaElement { let doc = document_from_node(self); let task = MediaElementMicrotask::ResourceSelectionTask { elem: DomRoot::from_ref(self), + generation_id: self.generation_id.get(), base_url: doc.base_url() }; @@ -672,12 +673,10 @@ impl HTMLMediaElement { // this invokation of the load algorithm. self.fired_loadeddata_event.set(false); - // Step 1. - // FIXME(nox): Abort any already-running instance of the - // resource selection algorithm. - - // Steps 2-4. + // Step 1-2. self.generation_id.set(self.generation_id.get() + 1); + + // Steps 3-4. while !self.in_flight_play_promises_queue.borrow().is_empty() { self.fulfill_in_flight_play_promises(|| ()); } @@ -929,7 +928,8 @@ impl VirtualMethods for HTMLMediaElement { pub enum MediaElementMicrotask { ResourceSelectionTask { elem: DomRoot, - base_url: ServoUrl + generation_id: u32, + base_url: ServoUrl, }, PauseIfNotInDocumentTask { elem: DomRoot, @@ -939,8 +939,10 @@ pub enum MediaElementMicrotask { 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::ResourceSelectionTask { ref elem, generation_id, ref base_url } => { + if generation_id == elem.generation_id.get() { + elem.resource_selection_algorithm_sync(base_url.clone()); + } }, &MediaElementMicrotask::PauseIfNotInDocumentTask { ref elem } => { if !elem.upcast::().is_in_doc() {