Chromium Code Reviews| Index: chrome/browser/ui/webui/chromeos/power_ui.cc |
| diff --git a/chrome/browser/ui/webui/chromeos/power_ui.cc b/chrome/browser/ui/webui/chromeos/power_ui.cc |
| index b7f35eb990ca6e6215b5734a756d58a10b9706e0..8561d3e80664c88e0ee006ca2df4b78a03e7dac0 100644 |
| --- a/chrome/browser/ui/webui/chromeos/power_ui.cc |
| +++ b/chrome/browser/ui/webui/chromeos/power_ui.cc |
| @@ -24,10 +24,19 @@ namespace chromeos { |
| namespace { |
| const char kStringsJsFile[] = "strings.js"; |
| + |
| const char kRequestBatteryChargeDataCallback[] = "requestBatteryChargeData"; |
| const char kOnRequestBatteryChargeDataFunction[] = |
| "powerUI.showBatteryChargeData"; |
| +const char kRequestCpuIdleDataCallback[] = "requestCpuIdleData"; |
| +const char kOnRequestCpuIdleDataFunction[] = |
| + "powerUI.showCpuIdleData"; |
| + |
| +const char kRequestCpuFreqDataCallback[] = "requestCpuFreqData"; |
| +const char kOnRequestCpuFreqDataFunction[] = |
| + "powerUI.showCpuFreqData"; |
| + |
| class PowerMessageHandler : public content::WebUIMessageHandler { |
| public: |
| PowerMessageHandler(); |
| @@ -38,6 +47,12 @@ class PowerMessageHandler : public content::WebUIMessageHandler { |
| private: |
| void OnGetBatteryChargeData(const base::ListValue* value); |
| + void OnGetCpuIdleData(const base::ListValue* value); |
| + void OnGetCpuFreqData(const base::ListValue* value); |
| + void GetJsStateOccupancyData( |
| + const std::vector<CpuDataCollector::StateOccupancySampleDeque>& data, |
| + base::ListValue* js_data); |
| + void GetJsSystemResumedData(base::ListValue* value); |
| }; |
| PowerMessageHandler::PowerMessageHandler() { |
| @@ -51,6 +66,14 @@ void PowerMessageHandler::RegisterMessages() { |
| kRequestBatteryChargeDataCallback, |
| base::Bind(&PowerMessageHandler::OnGetBatteryChargeData, |
| base::Unretained(this))); |
| + web_ui()->RegisterMessageCallback( |
| + kRequestCpuIdleDataCallback, |
| + base::Bind(&PowerMessageHandler::OnGetCpuIdleData, |
| + base::Unretained(this))); |
| + web_ui()->RegisterMessageCallback( |
| + kRequestCpuFreqDataCallback, |
| + base::Bind(&PowerMessageHandler::OnGetCpuFreqData, |
| + base::Unretained(this))); |
| } |
| void PowerMessageHandler::OnGetBatteryChargeData(const base::ListValue* value) { |
| @@ -68,9 +91,53 @@ void PowerMessageHandler::OnGetBatteryChargeData(const base::ListValue* value) { |
| js_power_supply_data.Append(element.release()); |
| } |
| + base::ListValue js_system_resumed_data; |
| + GetJsSystemResumedData(&js_system_resumed_data); |
| + |
| + web_ui()->CallJavascriptFunction(kOnRequestBatteryChargeDataFunction, |
| + js_power_supply_data, |
| + js_system_resumed_data); |
| +} |
| + |
| +void PowerMessageHandler::OnGetCpuIdleData(const base::ListValue* value) { |
| + const CpuDataCollector& cpu_data_collector = |
| + PowerDataCollector::Get()->cpu_data_collector(); |
| + |
| + const std::vector<CpuDataCollector::StateOccupancySampleDeque>& idle_data = |
| + cpu_data_collector.cpu_idle_state_data(); |
| + base::ListValue js_idle_data; |
| + GetJsStateOccupancyData(idle_data, &js_idle_data); |
| + |
| + base::ListValue js_system_resumed_data; |
| + GetJsSystemResumedData(&js_system_resumed_data); |
| + |
| + web_ui()->CallJavascriptFunction(kOnRequestCpuIdleDataFunction, |
| + js_idle_data, |
| + js_system_resumed_data); |
| +} |
| + |
| +void PowerMessageHandler::OnGetCpuFreqData(const base::ListValue* value) { |
| + const CpuDataCollector& cpu_data_collector = |
| + PowerDataCollector::Get()->cpu_data_collector(); |
| + |
| + const std::vector<CpuDataCollector::StateOccupancySampleDeque>& freq_data = |
| + cpu_data_collector.cpu_freq_state_data(); |
| + base::ListValue js_freq_data; |
| + GetJsStateOccupancyData(freq_data, &js_freq_data); |
| + |
| + base::ListValue js_system_resumed_data; |
| + GetJsSystemResumedData(&js_system_resumed_data); |
| + |
| + web_ui()->CallJavascriptFunction(kOnRequestCpuFreqDataFunction, |
| + js_freq_data, |
| + js_system_resumed_data); |
| +} |
| + |
| +void PowerMessageHandler::GetJsSystemResumedData(base::ListValue *data) { |
| + DCHECK(data != NULL); |
| + |
| const std::deque<PowerDataCollector::SystemResumedSample>& system_resumed = |
| PowerDataCollector::Get()->system_resumed_data(); |
| - base::ListValue js_system_resumed_data; |
| for (size_t i = 0; i < system_resumed.size(); ++i) { |
| const PowerDataCollector::SystemResumedSample& sample = system_resumed[i]; |
| scoped_ptr<base::DictionaryValue> element(new base::DictionaryValue); |
| @@ -78,12 +145,34 @@ void PowerMessageHandler::OnGetBatteryChargeData(const base::ListValue* value) { |
| sample.sleep_duration.InMillisecondsF()); |
| element->SetDouble("time", sample.time.ToJsTime()); |
| - js_system_resumed_data.Append(element.release()); |
| + data->Append(element.release()); |
| } |
| +} |
| - web_ui()->CallJavascriptFunction(kOnRequestBatteryChargeDataFunction, |
| - js_power_supply_data, |
| - js_system_resumed_data); |
| +void PowerMessageHandler::GetJsStateOccupancyData( |
| + const std::vector<CpuDataCollector::StateOccupancySampleDeque>& data, |
| + base::ListValue *js_data) { |
| + for (unsigned int cpu = 0; cpu < data.size(); ++cpu) { |
| + const CpuDataCollector::StateOccupancySampleDeque& sample_deque = data[cpu]; |
| + scoped_ptr<base::ListValue> js_sample_list(new base::ListValue); |
| + for (unsigned int i = 0; i < sample_deque.size(); ++i) { |
| + const CpuDataCollector::StateOccupancySample& sample = sample_deque[i]; |
| + scoped_ptr<base::DictionaryValue> js_sample(new base::DictionaryValue); |
| + js_sample->SetDouble("time", sample.time.ToJsTime()); |
| + js_sample->SetBoolean("cpuOnline", sample.cpu_online); |
| + |
| + scoped_ptr<base::DictionaryValue> state_dict(new base::DictionaryValue); |
| + std::map<std::string, int64>::const_iterator it = |
| + sample.state_occupancy.begin(); |
| + for (; it != sample.state_occupancy.end(); ++it) { |
|
Daniel Erat
2014/02/15 15:31:25
nit: omit curly brackets
Siva Chandra
2014/02/19 20:02:30
Done.
|
| + state_dict->SetDouble(it->first, static_cast<double>(it->second)); |
| + } |
| + js_sample->Set("stateOccupancy", state_dict.release()); |
| + |
| + js_sample_list->Append(js_sample.release()); |
| + } |
| + js_data->Append(js_sample_list.release()); |
| + } |
| } |
| } // namespace |
| @@ -96,17 +185,35 @@ PowerUI::PowerUI(content::WebUI* web_ui) : content::WebUIController(web_ui) { |
| html->SetUseJsonJSFormatV2(); |
| html->AddLocalizedString("titleText", IDS_ABOUT_POWER_TITLE); |
| + html->AddLocalizedString("expandButton", IDS_ABOUT_POWER_EXPAND_BUTTON); |
| + html->AddLocalizedString("hideButton", IDS_ABOUT_POWER_HIDE_BUTTON); |
| html->AddLocalizedString("reloadButton", IDS_ABOUT_POWER_RELOAD_BUTTON); |
| - html->AddLocalizedString("batteryChargePercentageHeader", |
| - IDS_ABOUT_POWER_BATTERY_CHARGE_PERCENTAGE_HEADER); |
| - html->AddLocalizedString("batteryDischargeRateHeader", |
| - IDS_ABOUT_POWER_BATTERY_DISCHARGE_RATE_HEADER); |
| - html->AddLocalizedString("negativeDischargeRateInfo", |
| - IDS_ABOUT_POWER_NEGATIVE_DISCHARGE_RATE_INFO); |
| html->AddLocalizedString("notEnoughDataAvailableYet", |
| IDS_ABOUT_POWER_NOT_ENOUGH_DATA); |
| html->AddLocalizedString("systemSuspended", |
| IDS_ABOUT_POWER_SYSTEM_SUSPENDED); |
| + html->AddLocalizedString("invalidData", IDS_ABOUT_POWER_INVALID); |
| + html->AddLocalizedString("offlineText", IDS_ABOUT_POWER_OFFLINE); |
| + |
| + html->AddLocalizedString("batteryChargeSectionTitle", |
| + IDS_ABOUT_POWER_BATTERY_CHARGE_SECTION_TITLE); |
| + html->AddLocalizedString("batteryChargePercentageHeader", |
| + IDS_ABOUT_POWER_BATTERY_CHARGE_PERCENTAGE_HEADER); |
| + html->AddLocalizedString("batteryDischargeRateHeader", |
| + IDS_ABOUT_POWER_BATTERY_DISCHARGE_RATE_HEADER); |
| + html->AddLocalizedString("dischargeRateLegendText", |
| + IDS_ABOUT_POWER_DISCHARGE_RATE_LEGEND_TEXT); |
| + |
| + html->AddLocalizedString("cpuIdleSectionTitle", |
| + IDS_ABOUT_POWER_CPU_IDLE_SECTION_TITLE); |
| + html->AddLocalizedString("idleStateOccupancyPercentageHeader", |
| + IDS_ABOUT_POWER_CPU_IDLE_STATE_OCCUPANCY_PERCENTAGE); |
| + |
| + html->AddLocalizedString("cpuFreqSectionTitle", |
| + IDS_ABOUT_POWER_CPU_FREQ_SECTION_TITLE); |
| + html->AddLocalizedString("frequencyStateOccupancyPercentageHeader", |
| + IDS_ABOUT_POWER_CPU_FREQ_STATE_OCCUPANCY_PERCENTAGE); |
| + |
| html->SetJsonPath(kStringsJsFile); |
| html->AddResourcePath("power.css", IDR_ABOUT_POWER_CSS); |