summaryrefslogtreecommitdiffstats
path: root/device/usb/usb_service.cc
diff options
context:
space:
mode:
authorreillyg <reillyg@chromium.org>2015-08-28 16:08:10 -0700
committerCommit bot <commit-bot@chromium.org>2015-08-28 23:08:46 +0000
commitbadbc5415c4cd4d4870b2ca2122b1b9988e341d7 (patch)
tree154dd8ff7ab4edd48de2921b43f1316849311f4c /device/usb/usb_service.cc
parente7bcbf464b505face0ed490930f9ba4bbb24ed6c (diff)
downloadchromium_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.cc28
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());