Chromium Code Reviews| Index: chrome/browser/metrics/first_web_contents_profiler.h |
| diff --git a/chrome/browser/metrics/first_web_contents_profiler.h b/chrome/browser/metrics/first_web_contents_profiler.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c1aa331c368b1368fbe65e9fa9d98c0eb8b8a072 |
| --- /dev/null |
| +++ b/chrome/browser/metrics/first_web_contents_profiler.h |
| @@ -0,0 +1,64 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef CHROME_BROWSER_METRICS_FIRST_WEB_CONTENTS_PROFILER_H_ |
| +#define CHROME_BROWSER_METRICS_FIRST_WEB_CONTENTS_PROFILER_H_ |
| + |
| +#include "base/memory/scoped_ptr.h" |
| +#include "content/public/browser/web_contents_observer.h" |
| + |
| +namespace content { |
| +class WebContents; |
| +} // namespace content |
| + |
| +class FirstWebContentsProfilerDelegate { |
|
Alexei Svitkine (slow)
2014/12/03 20:05:57
Nit: Any reason to not just nest it under FirstWeb
erikchen
2014/12/03 21:38:41
sounds reasonable to me.
|
| + public: |
| + // Called by the FirstWebContentsProfiler when it is finished collecting |
| + // metrics. The delegate should take this opportunity to destroy the |
| + // FirstWebContentsProfiler. |
| + virtual void ProfilerFinishedCollectingMetrics() = 0; |
| +}; |
| + |
| +// Measures start up performance of the first active web contents. |
| +class FirstWebContentsProfiler : public content::WebContentsObserver { |
| + public: |
| + // Creates a profiler for the active web contents. If there are multiple |
| + // browsers, the first one is chosen. If there are no browsers, returns |
| + // nullptr. |
| + static scoped_ptr<FirstWebContentsProfiler> CreateProfilerForFirstWebContents( |
| + FirstWebContentsProfilerDelegate* delegate); |
| + |
| + // These metrics are currently experimental, and are only collected in the |
| + // dev and canary channels. |
| + static bool ShouldCollectMetrics(); |
| + |
| + private: |
| + FirstWebContentsProfiler(content::WebContents* web_contents, |
| + FirstWebContentsProfilerDelegate* delegate); |
| + |
| + // WebContentsObserver overrides. |
|
Alexei Svitkine (slow)
2014/12/03 20:05:57
Nit: I think for new code, the preferred notation
erikchen
2014/12/03 21:38:41
sure, done. I kept the old style for chrome/browse
|
| + void DidFirstVisuallyNonEmptyPaint() override; |
| + void DocumentOnLoadCompletedInMainFrame() override; |
| + void WebContentsDestroyed() override; |
| + |
| + // Whether this instance has finished collecting all of its metrics. |
| + bool IsFinishedCollectingMetrics(); |
| + |
| + // Informs the delegate that this instance has finished collecting all of its |
| + // metrics. |
| + void FinishedCollectingMetrics(); |
| + |
| + // Whether the "NonEmptyPaint" metric has been collected. |
| + bool collected_paint_metric_; |
| + |
| + // Whether the "MainFrameLoad" metric has been collected. |
| + bool collected_load_metric_; |
| + |
| + // |delegate_| owns |this|. |
| + FirstWebContentsProfilerDelegate* delegate_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(FirstWebContentsProfiler); |
| +}; |
| + |
| +#endif // CHROME_BROWSER_METRICS_FIRST_WEB_CONTENTS_PROFILER_H_ |