Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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_BROWSER_PAGE_LOAD_METRICS_OBSERVERS_RESOURCE_PREFETCH_PREDICTOR_P AGE_LOAD_METRICS_OBSERVER_H_ | 5 #ifndef CHROME_BROWSER_PAGE_LOAD_METRICS_OBSERVERS_RESOURCE_PREFETCH_PREDICTOR_P AGE_LOAD_METRICS_OBSERVER_H_ |
| 6 #define CHROME_BROWSER_PAGE_LOAD_METRICS_OBSERVERS_RESOURCE_PREFETCH_PREDICTOR_P AGE_LOAD_METRICS_OBSERVER_H_ | 6 #define CHROME_BROWSER_PAGE_LOAD_METRICS_OBSERVERS_RESOURCE_PREFETCH_PREDICTOR_P AGE_LOAD_METRICS_OBSERVER_H_ |
| 7 | 7 |
| 8 #include "chrome/browser/page_load_metrics/page_load_metrics_observer.h" | 8 #include "chrome/browser/page_load_metrics/page_load_metrics_observer.h" |
| 9 #include "chrome/browser/predictors/resource_prefetch_predictor.h" | |
|
alexilin
2017/03/17 14:46:46
nit:
NavigationID is declared in resource_prefetch
trevordixon
2017/03/27 12:30:08
Done.
| |
| 9 | 10 |
| 10 namespace content { | 11 namespace content { |
| 11 class WebContents; | 12 class WebContents; |
| 12 } | 13 } |
| 13 | 14 |
| 14 namespace predictors { | |
| 15 class ResourcePrefetchPredictor; | |
| 16 } | |
| 17 | |
| 18 namespace internal { | 15 namespace internal { |
| 19 | 16 |
| 20 extern const char kHistogramResourcePrefetchPredictorFirstContentfulPaint[]; | 17 extern const char kHistogramResourcePrefetchPredictorFirstContentfulPaint[]; |
| 21 extern const char kHistogramResourcePrefetchPredictorFirstMeaningfulPaint[]; | 18 extern const char kHistogramResourcePrefetchPredictorFirstMeaningfulPaint[]; |
| 22 | 19 |
| 23 } // namespace internal | 20 } // namespace internal |
| 24 | 21 |
| 25 // Observer responsible for recording page load metrics relevant to | 22 // Observer responsible for recording page load metrics relevant to |
| 26 // ResourcePrefetchPredictor. | 23 // ResourcePrefetchPredictor. |
| 27 class ResourcePrefetchPredictorPageLoadMetricsObserver | 24 class ResourcePrefetchPredictorPageLoadMetricsObserver |
| 28 : public page_load_metrics::PageLoadMetricsObserver { | 25 : public page_load_metrics::PageLoadMetricsObserver { |
| 29 public: | 26 public: |
| 30 // Returns a ResourcePrefetchPredictorPageLoadMetricsObserver, or nullptr if | 27 // Returns a ResourcePrefetchPredictorPageLoadMetricsObserver, or nullptr if |
| 31 // it is not needed. | 28 // it is not needed. |
| 32 static std::unique_ptr<ResourcePrefetchPredictorPageLoadMetricsObserver> | 29 static std::unique_ptr<ResourcePrefetchPredictorPageLoadMetricsObserver> |
| 33 CreateIfNeeded(content::WebContents* web_contents); | 30 CreateIfNeeded(content::WebContents* web_contents); |
| 34 | 31 |
| 35 // Public for testing. Normally one should use CreateIfNeeded. Predictor must | 32 // Public for testing. Normally one should use CreateIfNeeded. Predictor must |
| 36 // outlive this observer. | 33 // outlive this observer. |
| 37 explicit ResourcePrefetchPredictorPageLoadMetricsObserver( | 34 explicit ResourcePrefetchPredictorPageLoadMetricsObserver( |
| 38 predictors::ResourcePrefetchPredictor* predictor); | 35 predictors::ResourcePrefetchPredictor* predictor, |
| 36 predictors::NavigationID navigation_id); | |
| 39 | 37 |
| 40 ~ResourcePrefetchPredictorPageLoadMetricsObserver() override; | 38 ~ResourcePrefetchPredictorPageLoadMetricsObserver() override; |
| 41 | 39 |
| 42 // page_load_metrics::PageLoadMetricsObserver: | 40 // page_load_metrics::PageLoadMetricsObserver: |
| 43 ObservePolicy OnStart(content::NavigationHandle* navigation_handle, | 41 ObservePolicy OnStart(content::NavigationHandle* navigation_handle, |
| 44 const GURL& currently_commited_url, | 42 const GURL& currently_commited_url, |
| 45 bool started_in_foreground) override; | 43 bool started_in_foreground) override; |
| 46 ObservePolicy OnHidden( | 44 ObservePolicy OnHidden( |
| 47 const page_load_metrics::PageLoadTiming& timing, | 45 const page_load_metrics::PageLoadTiming& timing, |
| 48 const page_load_metrics::PageLoadExtraInfo& extra_info) override; | 46 const page_load_metrics::PageLoadExtraInfo& extra_info) override; |
| 49 void OnFirstContentfulPaint( | 47 void OnFirstContentfulPaint( |
| 50 const page_load_metrics::PageLoadTiming& timing, | 48 const page_load_metrics::PageLoadTiming& timing, |
| 51 const page_load_metrics::PageLoadExtraInfo& extra_info) override; | 49 const page_load_metrics::PageLoadExtraInfo& extra_info) override; |
| 52 void OnFirstMeaningfulPaint( | 50 void OnFirstMeaningfulPaint( |
| 53 const page_load_metrics::PageLoadTiming& timing, | 51 const page_load_metrics::PageLoadTiming& timing, |
| 54 const page_load_metrics::PageLoadExtraInfo& extra_info) override; | 52 const page_load_metrics::PageLoadExtraInfo& extra_info) override; |
| 55 | 53 |
| 56 private: | 54 private: |
| 57 predictors::ResourcePrefetchPredictor* predictor_; | 55 predictors::ResourcePrefetchPredictor* predictor_; |
| 58 | 56 |
| 57 predictors::NavigationID navigation_id_; | |
| 58 | |
| 59 DISALLOW_COPY_AND_ASSIGN(ResourcePrefetchPredictorPageLoadMetricsObserver); | 59 DISALLOW_COPY_AND_ASSIGN(ResourcePrefetchPredictorPageLoadMetricsObserver); |
| 60 }; | 60 }; |
| 61 | 61 |
| 62 #endif // CHROME_BROWSER_PAGE_LOAD_METRICS_OBSERVERS_RESOURCE_PREFETCH_PREDICTO R_PAGE_LOAD_METRICS_OBSERVER_H_ | 62 #endif // CHROME_BROWSER_PAGE_LOAD_METRICS_OBSERVERS_RESOURCE_PREFETCH_PREDICTO R_PAGE_LOAD_METRICS_OBSERVER_H_ |
| OLD | NEW |