aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/script_thread.rs
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2019-09-27 12:37:27 -0400
committerGitHub <noreply@github.com>2019-09-27 12:37:27 -0400
commit75c201f78e8bb5dc9a9722380b17461924d94ee6 (patch)
tree933b9aee37721658681cd1af36ed5d9837414148 /components/script/script_thread.rs
parent44ee9159ca826ecb9d59590d2b077728810b1a68 (diff)
parent45ec250b0a989643865880734ff898de4b15bd7d (diff)
downloadservo-75c201f78e8bb5dc9a9722380b17461924d94ee6.tar.gz
servo-75c201f78e8bb5dc9a9722380b17461924d94ee6.zip
Auto merge of #24143 - gterzian:improve_spec_comp_bc_discarding, r=asajeffrey
Improve spec compliance of discarding BCs <!-- Please describe your changes on the following line: --> Came-up at https://github.com/servo/servo/pull/23637#issuecomment-528254988 --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `___` with appropriate data: --> - [ ] `./mach build -d` does not report any errors - [ ] `./mach test-tidy` does not report any errors - [ ] These changes fix #___ (GitHub issue number if applicable) <!-- Either: --> - [ ] There are tests for these changes OR - [ ] These changes do not require tests because ___ <!-- Also, please make sure that "Allow edits from maintainers" checkbox is checked, so that we can help you if you get stuck somewhere along the way.--> <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> <!-- Reviewable:start --> --- This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/24143) <!-- Reviewable:end -->
Diffstat (limited to 'components/script/script_thread.rs')
-rw-r--r--components/script/script_thread.rs31
1 files changed, 28 insertions, 3 deletions
diff --git a/components/script/script_thread.rs b/components/script/script_thread.rs
index 440de991ceb..b4363f5ada3 100644
--- a/components/script/script_thread.rs
+++ b/components/script/script_thread.rs
@@ -1973,7 +1973,15 @@ impl ScriptThread {
let window = self.documents.borrow().find_window(pipeline_id);
let window = match window {
- Some(w) => w,
+ Some(w) => {
+ if w.Closed() {
+ return warn!(
+ "Received fire timer msg for a discarded browsing context whose pipeline is pending exit {}.",
+ pipeline_id
+ );
+ }
+ w
+ },
None => {
return warn!(
"Received fire timer msg for a closed pipeline {}.",
@@ -2848,7 +2856,7 @@ impl ScriptThread {
// to avoid running layout on detached iframes.
let window = document.window();
if discard_bc == DiscardBrowsingContext::Yes {
- window.window_proxy().discard_browsing_context();
+ window.discard_browsing_context();
}
window.clear_js_runtime();
}
@@ -3378,9 +3386,26 @@ impl ScriptThread {
///
/// TODO: Actually perform DOM event dispatch.
fn handle_event(&self, pipeline_id: PipelineId, event: CompositorEvent) {
+ // Do not handle events if the pipeline exited.
+ let window = match { self.documents.borrow().find_window(pipeline_id) } {
+ Some(win) => win,
+ None => {
+ return warn!(
+ "Compositor event sent to a pipeline that already exited {}.",
+ pipeline_id
+ )
+ },
+ };
+ // Do not handle events if the BC has been, or is being, discarded
+ if window.Closed() {
+ return warn!(
+ "Compositor event sent to a pipeline with a closed window {}.",
+ pipeline_id
+ );
+ }
+
// Assuming all CompositionEvent are generated by user interactions.
ScriptThread::set_user_interacting(true);
-
match event {
ResizeEvent(new_size, size_type) => {
self.handle_resize_event(pipeline_id, new_size, size_type);