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 "tools/android/forwarder2/device_controller.h" | 5 #include "tools/android/forwarder2/device_controller.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
134 // TODO(felipeg): add a KillAllListeners command. | 134 // TODO(felipeg): add a KillAllListeners command. |
135 LOG(ERROR) << "Invalid command received. Port: " << port | 135 LOG(ERROR) << "Invalid command received. Port: " << port |
136 << " Command: " << command; | 136 << " Command: " << command; |
137 } | 137 } |
138 } | 138 } |
139 | 139 |
140 // static | 140 // static |
141 void DeviceController::DeleteListenerOnError( | 141 void DeviceController::DeleteListenerOnError( |
142 const base::WeakPtr<DeviceController>& device_controller_ptr, | 142 const base::WeakPtr<DeviceController>& device_controller_ptr, |
143 scoped_ptr<DeviceListener> device_listener) { | 143 scoped_ptr<DeviceListener> device_listener) { |
| 144 DeviceListener* const listener = device_listener.release(); |
144 DeviceController* const controller = device_controller_ptr.get(); | 145 DeviceController* const controller = device_controller_ptr.get(); |
145 if (!controller) { | 146 if (!controller) { |
146 // |device_listener| was already deleted by the controller that did have | 147 // |listener| was already deleted by the controller that did have its |
147 // its ownership. | 148 // ownership. |
148 ignore_result(device_listener.release()); | |
149 return; | 149 return; |
150 } | 150 } |
151 DCHECK(controller->construction_task_runner_->RunsTasksOnCurrentThread()); | 151 DCHECK(controller->construction_task_runner_->RunsTasksOnCurrentThread()); |
152 bool listener_did_exist = DeleteRefCountedValueInMap( | 152 bool listener_did_exist = DeleteRefCountedValueInMap( |
153 device_listener->listener_port(), &controller->listeners_); | 153 listener->listener_port(), &controller->listeners_); |
154 DCHECK(listener_did_exist); | 154 DCHECK(listener_did_exist); |
| 155 // Note that |listener| was deleted by DeleteRefCountedValueInMap(). |
155 } | 156 } |
156 | 157 |
157 } // namespace forwarder | 158 } // namespace forwarder |
OLD | NEW |