diff options
author | reillyg <reillyg@chromium.org> | 2015-08-28 16:08:10 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2015-08-28 23:08:46 +0000 |
commit | badbc5415c4cd4d4870b2ca2122b1b9988e341d7 (patch) | |
tree | 154dd8ff7ab4edd48de2921b43f1316849311f4c /device/usb/usb_service.cc | |
parent | e7bcbf464b505face0ed490930f9ba4bbb24ed6c (diff) | |
download | chromium_src-badbc5415c4cd4d4870b2ca2122b1b9988e341d7.zip chromium_src-badbc5415c4cd4d4870b2ca2122b1b9988e341d7.tar.gz chromium_src-badbc5415c4cd4d4870b2ca2122b1b9988e341d7.tar.bz2 |
Manage UsbService lifetime in DeviceClient implementations.
To make it easier to reason about when the UsbService is destroyed this
patch makes its lifetime managed by the DeviceClient implementation that
created it. This means that in Chrome the UsbService is (indirectly)
owned by BrowserProcessImpl.
BUG=None
TBR=dgozman@chromium.org
Review URL: https://codereview.chromium.org/1314273002
Cr-Commit-Position: refs/heads/master@{#346264}
Diffstat (limited to 'device/usb/usb_service.cc')
-rw-r--r-- | device/usb/usb_service.cc | 28 |
1 files changed, 4 insertions, 24 deletions
diff --git a/device/usb/usb_service.cc b/device/usb/usb_service.cc index 9f9f02c2..ef6763a 100644 --- a/device/usb/usb_service.cc +++ b/device/usb/usb_service.cc @@ -12,12 +12,6 @@ namespace device { -namespace { - -UsbService* g_service; - -} // namespace - UsbService::Observer::~Observer() {} void UsbService::Observer::OnDeviceAdded(scoped_refptr<UsbDevice> device) { @@ -31,28 +25,14 @@ void UsbService::Observer::OnDeviceRemovedCleanup( } // static -UsbService* UsbService::GetInstance( +scoped_ptr<UsbService> UsbService::Create( scoped_refptr<base::SequencedTaskRunner> blocking_task_runner) { - if (!g_service) { - // |g_service| is set by the UsbService constructor. - new UsbServiceImpl(blocking_task_runner); - if (!g_service) { - base::AtExitManager::RegisterTask(base::Bind( - &base::DeletePointer<UsbService>, base::Unretained(g_service))); - } - } - return g_service; + return make_scoped_ptr(new UsbServiceImpl(blocking_task_runner)); } -UsbService::UsbService() { - DCHECK(!g_service); - g_service = this; -} +UsbService::~UsbService() {} -UsbService::~UsbService() { - DCHECK(g_service); - g_service = nullptr; -} +UsbService::UsbService() {} void UsbService::AddObserver(Observer* observer) { DCHECK(CalledOnValidThread()); |