OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/profiler_ui.h" | 5 #include "chrome/browser/ui/webui/profiler_ui.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 // When testing the javacript code, it is cumbersome to have to keep | 9 // When testing the javacript code, it is cumbersome to have to keep |
10 // re-building the resouces package and reloading the browser. To solve | 10 // re-building the resouces package and reloading the browser. To solve |
11 // this, enable the following flag to read the webapp's source files | 11 // this, enable the following flag to read the webapp's source files |
12 // directly off disk, so all you have to do is refresh the page to | 12 // directly off disk, so all you have to do is refresh the page to |
13 // test the modifications. | 13 // test the modifications. |
14 //#define USE_SOURCE_FILES_DIRECTLY | 14 //#define USE_SOURCE_FILES_DIRECTLY |
15 | 15 |
16 #include "base/bind.h" | 16 #include "base/bind.h" |
17 #include "base/tracked_objects.h" | 17 #include "base/tracked_objects.h" |
18 #include "chrome/browser/metrics/tracking_synchronizer.h" | 18 #include "chrome/browser/metrics/tracking_synchronizer.h" |
19 #include "chrome/browser/profiles/profile.h" | 19 #include "chrome/browser/profiles/profile.h" |
20 #include "chrome/browser/ui/webui/chrome_web_ui_data_source.h" | 20 #include "chrome/browser/ui/webui/chrome_web_ui_data_source.h" |
21 #include "chrome/common/url_constants.h" | 21 #include "chrome/common/url_constants.h" |
22 #include "content/browser/trace_controller.h" | 22 #include "content/browser/trace_controller.h" |
| 23 #include "content/browser/webui/web_ui.h" |
23 #include "content/public/browser/browser_thread.h" | 24 #include "content/public/browser/browser_thread.h" |
24 #include "content/public/browser/web_contents.h" | 25 #include "content/public/browser/web_contents.h" |
25 #include "content/public/browser/web_ui_message_handler.h" | 26 #include "content/public/browser/web_ui_message_handler.h" |
26 #include "grit/browser_resources.h" | 27 #include "grit/browser_resources.h" |
27 #include "grit/generated_resources.h" | 28 #include "grit/generated_resources.h" |
28 | 29 |
29 #ifdef USE_SOURCE_FILES_DIRECTLY | 30 #ifdef USE_SOURCE_FILES_DIRECTLY |
30 #include "base/base_paths.h" | 31 #include "base/base_paths.h" |
31 #include "base/file_util.h" | 32 #include "base/file_util.h" |
32 #include "base/memory/ref_counted_memory.h" | 33 #include "base/memory/ref_counted_memory.h" |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
137 ProfilerUI* profiler_ui = reinterpret_cast<ProfilerUI*>(web_ui()); | 138 ProfilerUI* profiler_ui = reinterpret_cast<ProfilerUI*>(web_ui()); |
138 profiler_ui->GetData(); | 139 profiler_ui->GetData(); |
139 } | 140 } |
140 | 141 |
141 void ProfilerMessageHandler::OnResetData(const ListValue* list) { | 142 void ProfilerMessageHandler::OnResetData(const ListValue* list) { |
142 tracked_objects::ThreadData::ResetAllThreadData(); | 143 tracked_objects::ThreadData::ResetAllThreadData(); |
143 } | 144 } |
144 | 145 |
145 } // namespace | 146 } // namespace |
146 | 147 |
147 ProfilerUI::ProfilerUI(WebContents* contents) : WebUI(contents, this) { | 148 ProfilerUI::ProfilerUI(WebUI* web_ui) : WebUIController(web_ui) { |
148 ui_weak_ptr_factory_.reset(new base::WeakPtrFactory<ProfilerUI>(this)); | 149 ui_weak_ptr_factory_.reset(new base::WeakPtrFactory<ProfilerUI>(this)); |
149 ui_weak_ptr_ = ui_weak_ptr_factory_->GetWeakPtr(); | 150 ui_weak_ptr_ = ui_weak_ptr_factory_->GetWeakPtr(); |
150 | 151 |
151 AddMessageHandler(new ProfilerMessageHandler()); | 152 web_ui->AddMessageHandler(new ProfilerMessageHandler()); |
152 | 153 |
153 // Set up the chrome://profiler/ source. | 154 // Set up the chrome://profiler/ source. |
154 Profile::FromBrowserContext(contents->GetBrowserContext())-> | 155 Profile::FromBrowserContext(web_ui->web_contents()->GetBrowserContext())-> |
155 GetChromeURLDataManager()->AddDataSource(CreateProfilerHTMLSource()); | 156 GetChromeURLDataManager()->AddDataSource(CreateProfilerHTMLSource()); |
156 } | 157 } |
157 | 158 |
158 ProfilerUI::~ProfilerUI() { | 159 ProfilerUI::~ProfilerUI() { |
159 } | 160 } |
160 | 161 |
161 void ProfilerUI::GetData() { | 162 void ProfilerUI::GetData() { |
162 TrackingSynchronizer::FetchProfilerDataAsynchronously(ui_weak_ptr_); | 163 TrackingSynchronizer::FetchProfilerDataAsynchronously(ui_weak_ptr_); |
163 } | 164 } |
164 | 165 |
165 void ProfilerUI::ReceivedData(base::Value* value) { | 166 void ProfilerUI::ReceivedData(base::Value* value) { |
166 // Send the data to the renderer. | 167 // Send the data to the renderer. |
167 scoped_ptr<Value> data_values(value); | 168 scoped_ptr<Value> data_values(value); |
168 CallJavascriptFunction("g_browserBridge.receivedData", *data_values.get()); | 169 web_ui()->CallJavascriptFunction( |
| 170 "g_browserBridge.receivedData", *data_values.get()); |
169 } | 171 } |
170 | 172 |
OLD | NEW |