| 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 "chrome/browser/devtools/device/android_device_manager.h" | 5 #include "chrome/browser/devtools/device/android_device_manager.h" |
| 6 | 6 |
| 7 #include "base/strings/string_number_conversions.h" | 7 #include "base/strings/string_number_conversions.h" |
| 8 #include "base/strings/string_util.h" | 8 #include "base/strings/string_util.h" |
| 9 #include "base/strings/stringprintf.h" | 9 #include "base/strings/stringprintf.h" |
| 10 #include "net/base/io_buffer.h" | 10 #include "net/base/io_buffer.h" |
| (...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 319 } | 319 } |
| 320 | 320 |
| 321 AndroidDeviceManager::DeviceProvider::DeviceProvider() { | 321 AndroidDeviceManager::DeviceProvider::DeviceProvider() { |
| 322 } | 322 } |
| 323 | 323 |
| 324 AndroidDeviceManager::DeviceProvider::~DeviceProvider() { | 324 AndroidDeviceManager::DeviceProvider::~DeviceProvider() { |
| 325 } | 325 } |
| 326 | 326 |
| 327 void AndroidDeviceManager::Device::QueryDeviceInfo( | 327 void AndroidDeviceManager::Device::QueryDeviceInfo( |
| 328 const DeviceInfoCallback& callback) { | 328 const DeviceInfoCallback& callback) { |
| 329 device_message_loop_->PostTask( | 329 message_loop_proxy_->PostTask( |
| 330 FROM_HERE, | 330 FROM_HERE, |
| 331 base::Bind(&DeviceProvider::QueryDeviceInfo, | 331 base::Bind(&DeviceProvider::QueryDeviceInfo, |
| 332 provider_, | 332 provider_, |
| 333 serial_, | 333 serial_, |
| 334 base::Bind(&PostDeviceInfoCallback, | 334 base::Bind(&PostDeviceInfoCallback, |
| 335 base::MessageLoopProxy::current(), | 335 base::MessageLoopProxy::current(), |
| 336 callback))); | 336 callback))); |
| 337 } | 337 } |
| 338 | 338 |
| 339 void AndroidDeviceManager::Device::OpenSocket(const std::string& socket_name, | 339 void AndroidDeviceManager::Device::OpenSocket(const std::string& socket_name, |
| 340 const SocketCallback& callback) { | 340 const SocketCallback& callback) { |
| 341 device_message_loop_->PostTask( | 341 message_loop_proxy_->PostTask( |
| 342 FROM_HERE, | 342 FROM_HERE, |
| 343 base::Bind(&DeviceProvider::OpenSocket, | 343 base::Bind(&DeviceProvider::OpenSocket, |
| 344 provider_, | 344 provider_, |
| 345 serial_, | 345 serial_, |
| 346 socket_name, | 346 socket_name, |
| 347 callback)); | 347 callback)); |
| 348 } | 348 } |
| 349 | 349 |
| 350 void AndroidDeviceManager::Device::SendJsonRequest( | 350 void AndroidDeviceManager::Device::SendJsonRequest( |
| 351 const std::string& socket_name, | 351 const std::string& socket_name, |
| 352 const std::string& request, | 352 const std::string& request, |
| 353 const CommandCallback& callback) { | 353 const CommandCallback& callback) { |
| 354 device_message_loop_->PostTask( | 354 message_loop_proxy_->PostTask( |
| 355 FROM_HERE, | 355 FROM_HERE, |
| 356 base::Bind(&DeviceProvider::SendJsonRequest, | 356 base::Bind(&DeviceProvider::SendJsonRequest, |
| 357 provider_, | 357 provider_, |
| 358 serial_, | 358 serial_, |
| 359 socket_name, | 359 socket_name, |
| 360 request, | 360 request, |
| 361 base::Bind(&PostCommandCallback, | 361 base::Bind(&PostCommandCallback, |
| 362 base::MessageLoopProxy::current(), | 362 base::MessageLoopProxy::current(), |
| 363 callback))); | 363 callback))); |
| 364 } | 364 } |
| 365 | 365 |
| 366 void AndroidDeviceManager::Device::HttpUpgrade(const std::string& socket_name, | 366 void AndroidDeviceManager::Device::HttpUpgrade(const std::string& socket_name, |
| 367 const std::string& url, | 367 const std::string& url, |
| 368 const SocketCallback& callback) { | 368 const SocketCallback& callback) { |
| 369 device_message_loop_->PostTask( | 369 message_loop_proxy_->PostTask( |
| 370 FROM_HERE, | 370 FROM_HERE, |
| 371 base::Bind(&DeviceProvider::HttpUpgrade, | 371 base::Bind(&DeviceProvider::HttpUpgrade, |
| 372 provider_, | 372 provider_, |
| 373 serial_, | 373 serial_, |
| 374 socket_name, | 374 socket_name, |
| 375 url, | 375 url, |
| 376 base::Bind(&PostSocketCallback, | 376 base::Bind(&PostSocketCallback, |
| 377 base::MessageLoopProxy::current(), | 377 base::MessageLoopProxy::current(), |
| 378 callback))); | 378 callback))); |
| 379 } | 379 } |
| 380 | 380 |
| 381 AndroidDeviceManager::Device::Device( | 381 AndroidDeviceManager::Device::Device( |
| 382 scoped_refptr<base::MessageLoopProxy> device_message_loop, | 382 scoped_refptr<base::MessageLoopProxy> device_message_loop, |
| 383 scoped_refptr<DeviceProvider> provider, | 383 scoped_refptr<DeviceProvider> provider, |
| 384 const std::string& serial) | 384 const std::string& serial) |
| 385 : device_message_loop_(device_message_loop), | 385 : message_loop_proxy_(device_message_loop), |
| 386 provider_(provider), | 386 provider_(provider), |
| 387 serial_(serial), | 387 serial_(serial), |
| 388 weak_factory_(this) { | 388 weak_factory_(this) { |
| 389 } | 389 } |
| 390 | 390 |
| 391 AndroidDeviceManager::Device::~Device() { | 391 AndroidDeviceManager::Device::~Device() { |
| 392 std::set<AndroidWebSocket*> sockets_copy(sockets_); |
| 393 for (AndroidWebSocket* socket : sockets_copy) |
| 394 socket->OnSocketClosed(); |
| 395 |
| 392 provider_->AddRef(); | 396 provider_->AddRef(); |
| 393 DeviceProvider* raw_ptr = provider_.get(); | 397 DeviceProvider* raw_ptr = provider_.get(); |
| 394 provider_ = NULL; | 398 provider_ = NULL; |
| 395 device_message_loop_->PostTask( | 399 message_loop_proxy_->PostTask( |
| 396 FROM_HERE, | 400 FROM_HERE, |
| 397 base::Bind(&ReleaseDeviceAndProvider, | 401 base::Bind(&ReleaseDeviceAndProvider, |
| 398 base::Unretained(raw_ptr), | 402 base::Unretained(raw_ptr), |
| 399 serial_)); | 403 serial_)); |
| 400 } | 404 } |
| 401 | 405 |
| 402 AndroidDeviceManager::HandlerThread* | 406 AndroidDeviceManager::HandlerThread* |
| 403 AndroidDeviceManager::HandlerThread::instance_ = NULL; | 407 AndroidDeviceManager::HandlerThread::instance_ = NULL; |
| 404 | 408 |
| 405 // static | 409 // static |
| (...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 495 it->provider, it->serial); | 499 it->provider, it->serial); |
| 496 } else { | 500 } else { |
| 497 device = found->second.get(); | 501 device = found->second.get(); |
| 498 } | 502 } |
| 499 response.push_back(device); | 503 response.push_back(device); |
| 500 new_devices[it->serial] = device->weak_factory_.GetWeakPtr(); | 504 new_devices[it->serial] = device->weak_factory_.GetWeakPtr(); |
| 501 } | 505 } |
| 502 devices_.swap(new_devices); | 506 devices_.swap(new_devices); |
| 503 callback.Run(response); | 507 callback.Run(response); |
| 504 } | 508 } |
| OLD | NEW |