| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CHROME_RENDERER_PAGE_LOAD_HISTOGRAMS_H_ | 5 #ifndef CHROME_RENDERER_PAGE_LOAD_HISTOGRAMS_H_ |
| 6 #define CHROME_RENDERER_PAGE_LOAD_HISTOGRAMS_H_ | 6 #define CHROME_RENDERER_PAGE_LOAD_HISTOGRAMS_H_ |
| 7 | 7 |
| 8 #include "base/macros.h" | 8 #include "base/macros.h" |
| 9 #include "base/memory/weak_ptr.h" | |
| 10 #include "content/public/renderer/render_view_observer.h" | 9 #include "content/public/renderer/render_view_observer.h" |
| 11 | 10 |
| 12 namespace blink { | 11 namespace blink { |
| 13 class WebDataSource; | 12 class WebDataSource; |
| 14 } | 13 } |
| 15 | 14 |
| 16 namespace content { | 15 namespace content { |
| 17 class DocumentState; | 16 class DocumentState; |
| 18 } | 17 } |
| 19 | 18 |
| 20 class PageLoadHistograms : public content::RenderViewObserver { | 19 class PageLoadHistograms : public content::RenderViewObserver { |
| 21 public: | 20 public: |
| 22 explicit PageLoadHistograms(content::RenderView* render_view); | 21 explicit PageLoadHistograms(content::RenderView* render_view); |
| 23 ~PageLoadHistograms() override; | 22 ~PageLoadHistograms() override; |
| 24 | 23 |
| 25 private: | 24 private: |
| 26 // RenderViewObserver implementation. | 25 // RenderViewObserver implementation. |
| 27 void FrameWillClose(blink::WebFrame* frame) override; | 26 void FrameWillClose(blink::WebFrame* frame) override; |
| 28 void ClosePage() override; | 27 void ClosePage() override; |
| 29 void DidUpdateLayout() override; | |
| 30 | 28 |
| 31 // Dump all page load histograms appropriate for the given frame. | 29 // Dump all page load histograms appropriate for the given frame. |
| 32 // | 30 // |
| 33 // This method will only dump once-per-instance, so it is safe to call | 31 // This method will only dump once-per-instance, so it is safe to call |
| 34 // multiple times. | 32 // multiple times. |
| 35 // | 33 // |
| 36 // The time points we keep are | 34 // The time points we keep are |
| 37 // request: time document was requested by user | 35 // request: time document was requested by user |
| 38 // start: time load of document started | 36 // start: time load of document started |
| 39 // commit: time load of document started | 37 // commit: time load of document started |
| 40 // finish_document: main document loaded, before onload() | 38 // finish_document: main document loaded, before onload() |
| 41 // finish_all_loads: after onload() and all resources are loaded | 39 // finish_all_loads: after onload() and all resources are loaded |
| 42 // first_paint: first paint performed | 40 // first_paint: first paint performed |
| 43 // first_paint_after_load: first paint performed after load is finished | 41 // first_paint_after_load: first paint performed after load is finished |
| 44 // begin: request if it was user requested, start otherwise | 42 // begin: request if it was user requested, start otherwise |
| 45 // | 43 // |
| 46 // It's possible for the request time not to be set, if a client | 44 // It's possible for the request time not to be set, if a client |
| 47 // redirect had been done (the user never requested the page) | 45 // redirect had been done (the user never requested the page) |
| 48 // Also, it's possible to load a page without ever laying it out | 46 // Also, it's possible to load a page without ever laying it out |
| 49 // so first_paint and first_paint_after_load can be 0. | 47 // so first_paint and first_paint_after_load can be 0. |
| 50 void Dump(blink::WebFrame* frame); | 48 void Dump(blink::WebFrame* frame); |
| 51 | 49 |
| 52 bool ShouldDump(blink::WebFrame* frame); | |
| 53 void MaybeDumpFirstLayoutHistograms(); | |
| 54 void LogPageLoadTime(const content::DocumentState* load_times, | 50 void LogPageLoadTime(const content::DocumentState* load_times, |
| 55 const blink::WebDataSource* ds) const; | 51 const blink::WebDataSource* ds) const; |
| 56 | 52 |
| 57 bool dumped_first_layout_histograms_; | |
| 58 base::WeakPtrFactory<PageLoadHistograms> weak_factory_; | |
| 59 | |
| 60 DISALLOW_COPY_AND_ASSIGN(PageLoadHistograms); | 53 DISALLOW_COPY_AND_ASSIGN(PageLoadHistograms); |
| 61 }; | 54 }; |
| 62 | 55 |
| 63 #endif // CHROME_RENDERER_PAGE_LOAD_HISTOGRAMS_H_ | 56 #endif // CHROME_RENDERER_PAGE_LOAD_HISTOGRAMS_H_ |
| OLD | NEW |