Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/hid/hid_service.h" | 5 #include "device/hid/hid_service.h" |
| 6 | 6 |
| 7 #include "base/lazy_instance.h" | |
| 8 #include "base/logging.h" | 7 #include "base/logging.h" |
| 9 #include "base/memory/scoped_vector.h" | |
| 10 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
| 11 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 12 | 10 |
| 13 #if defined(OS_LINUX) && defined(USE_UDEV) | 11 #if defined(OS_LINUX) && defined(USE_UDEV) |
| 14 #include "device/hid/hid_service_linux.h" | 12 #include "device/hid/hid_service_linux.h" |
| 15 #elif defined(OS_MACOSX) | 13 #elif defined(OS_MACOSX) |
| 16 #include "device/hid/hid_service_mac.h" | 14 #include "device/hid/hid_service_mac.h" |
| 17 #else | 15 #else |
| 18 #include "device/hid/hid_service_win.h" | 16 #include "device/hid/hid_service_win.h" |
| 19 #endif | 17 #endif |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 38 base::MessageLoop::current()->RemoveDestructionObserver(this); | 36 base::MessageLoop::current()->RemoveDestructionObserver(this); |
| 39 delete hid_service_; | 37 delete hid_service_; |
| 40 delete this; | 38 delete this; |
| 41 g_service = NULL; | 39 g_service = NULL; |
| 42 } | 40 } |
| 43 | 41 |
| 44 HidService* hid_service_; | 42 HidService* hid_service_; |
| 45 }; | 43 }; |
| 46 | 44 |
| 47 HidService* HidService::GetInstance( | 45 HidService* HidService::GetInstance( |
| 48 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner, | 46 scoped_refptr<base::SingleThreadTaskRunner> file_task_runner) { |
| 49 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner) { | |
| 50 if (g_service == NULL) { | 47 if (g_service == NULL) { |
| 51 #if defined(OS_LINUX) && defined(USE_UDEV) | 48 #if defined(OS_LINUX) && defined(USE_UDEV) |
| 52 g_service = new HidServiceLinux(ui_task_runner); | 49 g_service = new HidServiceLinux(file_task_runner); |
| 53 #elif defined(OS_MACOSX) | 50 #elif defined(OS_MACOSX) |
| 54 g_service = new HidServiceMac(file_task_runner); | 51 g_service = new HidServiceMac(file_task_runner); |
| 55 #elif defined(OS_WIN) | 52 #elif defined(OS_WIN) |
| 56 g_service = new HidServiceWin(); | 53 g_service = new HidServiceWin(); |
| 57 #endif | 54 #endif |
| 58 if (g_service != nullptr) { | 55 if (g_service != nullptr) { |
| 59 Destroyer* destroyer = new Destroyer(g_service); | 56 Destroyer* destroyer = new Destroyer(g_service); |
| 60 base::MessageLoop::current()->AddDestructionObserver(destroyer); | 57 base::MessageLoop::current()->AddDestructionObserver(destroyer); |
| 61 } | 58 } |
| 62 } | 59 } |
| 63 return g_service; | 60 return g_service; |
| 64 } | 61 } |
| 65 | 62 |
| 66 void HidService::SetInstanceForTest(HidService* instance) { | 63 void HidService::SetInstanceForTest(HidService* instance) { |
| 67 DCHECK(!g_service); | 64 DCHECK(!g_service); |
| 68 g_service = instance; | 65 g_service = instance; |
| 69 Destroyer* destroyer = new Destroyer(g_service); | 66 Destroyer* destroyer = new Destroyer(g_service); |
| 70 base::MessageLoop::current()->AddDestructionObserver(destroyer); | 67 base::MessageLoop::current()->AddDestructionObserver(destroyer); |
| 71 } | 68 } |
| 72 | 69 |
| 73 HidService::~HidService() { | 70 HidService::~HidService() { |
| 74 DCHECK(thread_checker_.CalledOnValidThread()); | |
|
Ken Rockot(use gerrit already)
2014/12/03 22:35:10
Why do we want to remove this one?
Reilly Grant (use Gerrit)
2014/12/03 23:10:28
I mistakenly recalled that base::ThreadChecker has
| |
| 75 } | 71 } |
| 76 | 72 |
| 77 void HidService::GetDevices(std::vector<HidDeviceInfo>* devices) { | 73 void HidService::GetDevices(std::vector<HidDeviceInfo>* devices) { |
| 78 DCHECK(thread_checker_.CalledOnValidThread()); | 74 DCHECK(thread_checker_.CalledOnValidThread()); |
| 79 STLClearObject(devices); | 75 STLClearObject(devices); |
| 80 for (DeviceMap::iterator it = devices_.begin(); | 76 for (DeviceMap::iterator it = devices_.begin(); |
| 81 it != devices_.end(); | 77 it != devices_.end(); |
| 82 ++it) { | 78 ++it) { |
| 83 devices->push_back(it->second); | 79 devices->push_back(it->second); |
| 84 } | 80 } |
| 85 } | 81 } |
| 86 | 82 |
| 87 // Fills in the device info struct of the given device_id. | 83 // Fills in the device info struct of the given device_id. |
| 88 bool HidService::GetDeviceInfo(const HidDeviceId& device_id, | 84 bool HidService::GetDeviceInfo(const HidDeviceId& device_id, |
| 89 HidDeviceInfo* info) const { | 85 HidDeviceInfo* info) const { |
| 86 DCHECK(thread_checker_.CalledOnValidThread()); | |
| 90 DeviceMap::const_iterator it = devices_.find(device_id); | 87 DeviceMap::const_iterator it = devices_.find(device_id); |
| 91 if (it == devices_.end()) | 88 if (it == devices_.end()) |
| 92 return false; | 89 return false; |
| 93 *info = it->second; | 90 *info = it->second; |
| 94 return true; | 91 return true; |
| 95 } | 92 } |
| 96 | 93 |
| 97 HidService::HidService() { | 94 HidService::HidService() { |
| 98 DCHECK(thread_checker_.CalledOnValidThread()); | |
| 99 } | 95 } |
| 100 | 96 |
| 101 void HidService::AddDevice(const HidDeviceInfo& info) { | 97 void HidService::AddDevice(const HidDeviceInfo& info) { |
| 102 DCHECK(thread_checker_.CalledOnValidThread()); | 98 DCHECK(thread_checker_.CalledOnValidThread()); |
| 103 if (!ContainsKey(devices_, info.device_id)) { | 99 if (!ContainsKey(devices_, info.device_id)) { |
| 104 devices_[info.device_id] = info; | 100 devices_[info.device_id] = info; |
| 105 } | 101 } |
| 106 } | 102 } |
| 107 | 103 |
| 108 void HidService::RemoveDevice(const HidDeviceId& device_id) { | 104 void HidService::RemoveDevice(const HidDeviceId& device_id) { |
| 109 DCHECK(thread_checker_.CalledOnValidThread()); | 105 DCHECK(thread_checker_.CalledOnValidThread()); |
| 110 DeviceMap::iterator it = devices_.find(device_id); | 106 DeviceMap::iterator it = devices_.find(device_id); |
| 111 if (it != devices_.end()) | 107 if (it != devices_.end()) |
| 112 devices_.erase(it); | 108 devices_.erase(it); |
| 113 } | 109 } |
| 114 | 110 |
| 115 } // namespace device | 111 } // namespace device |
| OLD | NEW |