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/printing/cloud_print/cloud_print_proxy_service.h" | 5 #include "chrome/browser/printing/cloud_print/cloud_print_proxy_service.h" |
6 | 6 |
7 #include <stack> | 7 #include <stack> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
11 #include "base/bind_helpers.h" | 11 #include "base/bind_helpers.h" |
12 #include "base/command_line.h" | 12 #include "base/command_line.h" |
13 #include "base/files/file_util.h" | 13 #include "base/files/file_util.h" |
14 #include "base/json/json_reader.h" | 14 #include "base/json/json_reader.h" |
15 #include "base/message_loop/message_loop.h" | 15 #include "base/location.h" |
16 #include "base/metrics/histogram.h" | 16 #include "base/metrics/histogram.h" |
17 #include "base/prefs/pref_service.h" | 17 #include "base/prefs/pref_service.h" |
| 18 #include "base/single_thread_task_runner.h" |
18 #include "base/strings/utf_string_conversions.h" | 19 #include "base/strings/utf_string_conversions.h" |
| 20 #include "base/thread_task_runner_handle.h" |
19 #include "chrome/browser/browser_process.h" | 21 #include "chrome/browser/browser_process.h" |
20 #include "chrome/browser/chrome_notification_types.h" | 22 #include "chrome/browser/chrome_notification_types.h" |
21 #include "chrome/browser/lifetime/application_lifetime.h" | 23 #include "chrome/browser/lifetime/application_lifetime.h" |
22 #include "chrome/browser/notifications/desktop_notification_service.h" | 24 #include "chrome/browser/notifications/desktop_notification_service.h" |
23 #include "chrome/browser/notifications/notification.h" | 25 #include "chrome/browser/notifications/notification.h" |
24 #include "chrome/browser/notifications/notification_ui_manager.h" | 26 #include "chrome/browser/notifications/notification_ui_manager.h" |
25 #include "chrome/browser/profiles/profile.h" | 27 #include "chrome/browser/profiles/profile.h" |
26 #include "chrome/browser/service_process/service_process_control.h" | 28 #include "chrome/browser/service_process/service_process_control.h" |
27 #include "chrome/common/chrome_switches.h" | 29 #include "chrome/common/chrome_switches.h" |
28 #include "chrome/common/cloud_print/cloud_print_proxy_info.h" | 30 #include "chrome/common/cloud_print/cloud_print_proxy_info.h" |
(...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
137 std::vector<std::string> printers; | 139 std::vector<std::string> printers; |
138 if (value && value->GetAsList(&list) && list) { | 140 if (value && value->GetAsList(&list) && list) { |
139 for (size_t i = 0; i < list->GetSize(); ++i) { | 141 for (size_t i = 0; i < list->GetSize(); ++i) { |
140 std::string printer; | 142 std::string printer; |
141 if (list->GetString(i, &printer)) | 143 if (list->GetString(i, &printer)) |
142 printers.push_back(printer); | 144 printers.push_back(printer); |
143 } | 145 } |
144 } | 146 } |
145 UMA_HISTOGRAM_COUNTS_10000("CloudPrint.AvailablePrintersList", | 147 UMA_HISTOGRAM_COUNTS_10000("CloudPrint.AvailablePrintersList", |
146 printers.size()); | 148 printers.size()); |
147 base::MessageLoop::current()->PostTask(FROM_HERE, | 149 base::ThreadTaskRunnerHandle::Get()->PostTask( |
148 base::Bind(callback, printers)); | 150 FROM_HERE, base::Bind(callback, printers)); |
149 } else { | 151 } else { |
150 InvokeServiceTask( | 152 InvokeServiceTask( |
151 base::Bind(&CloudPrintProxyService::GetCloudPrintProxyPrinters, | 153 base::Bind(&CloudPrintProxyService::GetCloudPrintProxyPrinters, |
152 weak_factory_.GetWeakPtr(), | 154 weak_factory_.GetWeakPtr(), |
153 callback)); | 155 callback)); |
154 } | 156 } |
155 } | 157 } |
156 | 158 |
157 void CloudPrintProxyService::GetCloudPrintProxyPrinters( | 159 void CloudPrintProxyService::GetCloudPrintProxyPrinters( |
158 const PrintersCallback& callback) { | 160 const PrintersCallback& callback) { |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
203 } | 205 } |
204 | 206 |
205 bool CloudPrintProxyService::InvokeServiceTask(const base::Closure& task) { | 207 bool CloudPrintProxyService::InvokeServiceTask(const base::Closure& task) { |
206 GetServiceProcessControl()->Launch(task, base::Closure()); | 208 GetServiceProcessControl()->Launch(task, base::Closure()); |
207 return true; | 209 return true; |
208 } | 210 } |
209 | 211 |
210 ServiceProcessControl* CloudPrintProxyService::GetServiceProcessControl() { | 212 ServiceProcessControl* CloudPrintProxyService::GetServiceProcessControl() { |
211 return ServiceProcessControl::GetInstance(); | 213 return ServiceProcessControl::GetInstance(); |
212 } | 214 } |
OLD | NEW |