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 |