Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(189)

Side by Side Diff: device/test/usb_test_gadget_impl.cc

Issue 1314273002: Manage UsbService lifetime in DeviceClient implementations. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « device/test/test_device_client.cc ('k') | device/usb/usb_context.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "device/test/usb_test_gadget.h" 5 #include "device/test/usb_test_gadget.h"
6 6
7 #include <string> 7 #include <string>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/command_line.h" 10 #include "base/command_line.h"
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "base/files/file.h" 12 #include "base/files/file.h"
13 #include "base/files/file_path.h" 13 #include "base/files/file_path.h"
14 #include "base/logging.h" 14 #include "base/logging.h"
15 #include "base/macros.h" 15 #include "base/macros.h"
16 #include "base/memory/ref_counted.h" 16 #include "base/memory/ref_counted.h"
17 #include "base/memory/scoped_ptr.h" 17 #include "base/memory/scoped_ptr.h"
18 #include "base/path_service.h" 18 #include "base/path_service.h"
19 #include "base/process/process_handle.h" 19 #include "base/process/process_handle.h"
20 #include "base/run_loop.h" 20 #include "base/run_loop.h"
21 #include "base/scoped_observer.h" 21 #include "base/scoped_observer.h"
22 #include "base/strings/stringprintf.h" 22 #include "base/strings/stringprintf.h"
23 #include "base/strings/utf_string_conversions.h" 23 #include "base/strings/utf_string_conversions.h"
24 #include "base/thread_task_runner_handle.h" 24 #include "base/thread_task_runner_handle.h"
25 #include "base/time/time.h" 25 #include "base/time/time.h"
26 #include "device/core/device_client.h"
26 #include "device/usb/usb_device.h" 27 #include "device/usb/usb_device.h"
27 #include "device/usb/usb_device_handle.h" 28 #include "device/usb/usb_device_handle.h"
28 #include "device/usb/usb_service.h" 29 #include "device/usb/usb_service.h"
29 #include "net/proxy/proxy_service.h" 30 #include "net/proxy/proxy_service.h"
30 #include "net/url_request/url_fetcher.h" 31 #include "net/url_request/url_fetcher.h"
31 #include "net/url_request/url_fetcher_delegate.h" 32 #include "net/url_request/url_fetcher_delegate.h"
32 #include "net/url_request/url_request_context.h" 33 #include "net/url_request/url_request_context.h"
33 #include "net/url_request/url_request_context_builder.h" 34 #include "net/url_request/url_request_context_builder.h"
34 #include "net/url_request/url_request_context_getter.h" 35 #include "net/url_request/url_request_context_getter.h"
35 #include "url/gurl.h" 36 #include "url/gurl.h"
(...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after
185 delegate.WaitForCompletion(); 186 delegate.WaitForCompletion();
186 187
187 return url_fetcher->GetResponseCode(); 188 return url_fetcher->GetResponseCode();
188 } 189 }
189 190
190 class UsbGadgetFactory : public UsbService::Observer, 191 class UsbGadgetFactory : public UsbService::Observer,
191 public net::URLFetcherDelegate { 192 public net::URLFetcherDelegate {
192 public: 193 public:
193 UsbGadgetFactory(scoped_refptr<base::SingleThreadTaskRunner> io_task_runner) 194 UsbGadgetFactory(scoped_refptr<base::SingleThreadTaskRunner> io_task_runner)
194 : observer_(this), weak_factory_(this) { 195 : observer_(this), weak_factory_(this) {
195 usb_service_ = UsbService::GetInstance(io_task_runner); 196 usb_service_ = DeviceClient::Get()->GetUsbService();
196 request_context_getter_ = new URLRequestContextGetter(io_task_runner); 197 request_context_getter_ = new URLRequestContextGetter(io_task_runner);
197 198
198 static uint32 next_session_id; 199 static uint32 next_session_id;
199 base::ProcessId process_id = base::GetCurrentProcId(); 200 base::ProcessId process_id = base::GetCurrentProcId();
200 session_id_ = base::StringPrintf("%d-%d", process_id, next_session_id++); 201 session_id_ = base::StringPrintf("%d-%d", process_id, next_session_id++);
201 202
202 observer_.Add(usb_service_); 203 observer_.Add(usb_service_);
203 } 204 }
204 205
205 ~UsbGadgetFactory() override {} 206 ~UsbGadgetFactory() override {}
(...skipping 396 matching lines...) Expand 10 before | Expand all | Expand 10 after
602 return false; 603 return false;
603 } 604 }
604 605
605 DeviceAddListener add_listener(usb_service_, device_address_, -1); 606 DeviceAddListener add_listener(usb_service_, device_address_, -1);
606 device_ = add_listener.WaitForAdd(); 607 device_ = add_listener.WaitForAdd();
607 DCHECK(device_.get()); 608 DCHECK(device_.get());
608 return true; 609 return true;
609 } 610 }
610 611
611 } // namespace device 612 } // namespace device
OLDNEW
« no previous file with comments | « device/test/test_device_client.cc ('k') | device/usb/usb_context.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698