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 #include "chrome/browser/ui/webui/extensions/extensions_ui.h" | 5 #include "chrome/browser/ui/webui/extensions/extensions_ui.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 | 8 |
9 #include "base/metrics/histogram_macros.h" | 9 #include "base/metrics/histogram_macros.h" |
10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
49 void DidStartProvisionalLoadForFrame( | 49 void DidStartProvisionalLoadForFrame( |
50 content::RenderFrameHost* render_frame_host, | 50 content::RenderFrameHost* render_frame_host, |
51 const GURL& validated_url, | 51 const GURL& validated_url, |
52 bool is_error_page, | 52 bool is_error_page, |
53 bool is_iframe_srcdoc) override { | 53 bool is_iframe_srcdoc) override { |
54 timer_.reset(new base::ElapsedTimer()); | 54 timer_.reset(new base::ElapsedTimer()); |
55 } | 55 } |
56 | 56 |
57 void DocumentLoadedInFrame( | 57 void DocumentLoadedInFrame( |
58 content::RenderFrameHost* render_frame_host) override { | 58 content::RenderFrameHost* render_frame_host) override { |
59 if (render_frame_host != web_contents()->GetMainFrame()) | 59 if (render_frame_host != web_contents()->GetMainFrame() || |
| 60 !timer_) { // See comment in DocumentOnLoadCompletedInMainFrame() |
60 return; | 61 return; |
| 62 } |
61 if (is_md_) { | 63 if (is_md_) { |
62 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.MD", | 64 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.MD", |
63 timer_->Elapsed()); | 65 timer_->Elapsed()); |
64 } else { | 66 } else { |
65 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.Uber", | 67 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.Uber", |
66 timer_->Elapsed()); | 68 timer_->Elapsed()); |
67 } | 69 } |
68 } | 70 } |
69 | 71 |
70 void DocumentOnLoadCompletedInMainFrame() override { | 72 void DocumentOnLoadCompletedInMainFrame() override { |
| 73 // Sometimes*, DidStartProvisionalLoadForFrame() isn't called before this |
| 74 // or DocumentLoadedInFrame(). Don't log anything in those cases. |
| 75 // *This appears to be for in-page navigations like hash changes. |
| 76 // TODO(devlin): The usefulness of these metrics remains to be seen. |
| 77 if (!timer_) |
| 78 return; |
71 if (is_md_) { | 79 if (is_md_) { |
72 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.MD", | 80 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.MD", |
73 timer_->Elapsed()); | 81 timer_->Elapsed()); |
74 } else { | 82 } else { |
75 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.Uber", | 83 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.Uber", |
76 timer_->Elapsed()); | 84 timer_->Elapsed()); |
77 } | 85 } |
| 86 timer_.reset(); |
78 } | 87 } |
79 | 88 |
80 void WebContentsDestroyed() override { delete this; } | 89 void WebContentsDestroyed() override { delete this; } |
81 | 90 |
82 private: | 91 private: |
83 // Whether this is the MD version of the chrome://extensions page. | 92 // Whether this is the MD version of the chrome://extensions page. |
84 bool is_md_; | 93 bool is_md_; |
85 | 94 |
86 std::unique_ptr<base::ElapsedTimer> timer_; | 95 std::unique_ptr<base::ElapsedTimer> timer_; |
87 | 96 |
(...skipping 232 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
320 ExtensionsUI::~ExtensionsUI() {} | 329 ExtensionsUI::~ExtensionsUI() {} |
321 | 330 |
322 // static | 331 // static |
323 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes( | 332 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes( |
324 ui::ScaleFactor scale_factor) { | 333 ui::ScaleFactor scale_factor) { |
325 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | 334 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
326 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor); | 335 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor); |
327 } | 336 } |
328 | 337 |
329 } // namespace extensions | 338 } // namespace extensions |
OLD | NEW |