diff options
author | kingdido999 <info@desmonding.me> | 2018-12-13 10:53:31 -0800 |
---|---|---|
committer | kingdido999 <info@desmonding.me> | 2018-12-13 10:53:31 -0800 |
commit | 3b855b132998c472672c2b076cb7929b2a2922aa (patch) | |
tree | c1ff7b3e9572c403ffcfa502d0d132fc6a924176 /components/script/dom/window.rs | |
parent | eab848df3e5fd7521140d8470e142016f6409c66 (diff) | |
download | servo-3b855b132998c472672c2b076cb7929b2a2922aa.tar.gz servo-3b855b132998c472672c2b076cb7929b2a2922aa.zip |
Avoid sending idle message more than once after a reflow is complete
Diffstat (limited to 'components/script/dom/window.rs')
-rw-r--r-- | components/script/dom/window.rs | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/components/script/dom/window.rs b/components/script/dom/window.rs index d8353157cc1..f5bdec446f4 100644 --- a/components/script/dom/window.rs +++ b/components/script/dom/window.rs @@ -289,6 +289,10 @@ pub struct Window { /// Webrender API Sender #[ignore_malloc_size_of = "defined in webrender_api"] webrender_api_sender: RenderApiSender, + + /// Indicate whether a SetDocumentStatus message has been sent after a reflow is complete. + /// It is used to avoid sending idle message more than once, which is unneccessary. + has_sent_idle_message: Cell<bool>, } impl Window { @@ -1548,12 +1552,14 @@ impl Window { elem.has_class(&atom!("reftest-wait"), CaseSensitivity::CaseSensitive) }); - let ready_state = document.ReadyState(); - + let has_sent_idle_message = self.has_sent_idle_message.get(); + let is_ready_state_complete = document.ReadyState() == DocumentReadyState::Complete; let pending_images = self.pending_layout_images.borrow().is_empty(); - if ready_state == DocumentReadyState::Complete && !reftest_wait && pending_images { + + if !has_sent_idle_message && is_ready_state_complete && !reftest_wait && pending_images { let event = ScriptMsg::SetDocumentState(DocumentState::Idle); self.send_to_constellation(event); + self.has_sent_idle_message.set(true); } } @@ -2101,6 +2107,7 @@ impl Window { webrender_document, exists_mut_observer: Cell::new(false), webrender_api_sender, + has_sent_idle_message: Cell::new(false), }); unsafe { WindowBinding::Wrap(runtime.cx(), win) } |