| 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 #ifndef CHROME_BROWSER_DEVTOOLS_DEVICE_ANDROID_DEVICE_MANAGER_H_ | 5 #ifndef CHROME_BROWSER_DEVTOOLS_DEVICE_ANDROID_DEVICE_MANAGER_H_ |
| 6 #define CHROME_BROWSER_DEVTOOLS_DEVICE_ANDROID_DEVICE_MANAGER_H_ | 6 #define CHROME_BROWSER_DEVTOOLS_DEVICE_ANDROID_DEVICE_MANAGER_H_ |
| 7 | 7 |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 46 ~DeviceInfo(); | 46 ~DeviceInfo(); |
| 47 | 47 |
| 48 std::string model; | 48 std::string model; |
| 49 bool connected; | 49 bool connected; |
| 50 gfx::Size screen_size; | 50 gfx::Size screen_size; |
| 51 std::vector<BrowserInfo> browser_info; | 51 std::vector<BrowserInfo> browser_info; |
| 52 }; | 52 }; |
| 53 | 53 |
| 54 typedef base::Callback<void(const DeviceInfo&)> DeviceInfoCallback; | 54 typedef base::Callback<void(const DeviceInfo&)> DeviceInfoCallback; |
| 55 | 55 |
| 56 class AndroidWebSocket : public base::RefCountedThreadSafe<AndroidWebSocket> { | 56 class AndroidWebSocket { |
| 57 public: | 57 public: |
| 58 class Delegate { | 58 class Delegate { |
| 59 public: | 59 public: |
| 60 virtual void OnSocketOpened() = 0; | 60 virtual void OnSocketOpened() = 0; |
| 61 virtual void OnFrameRead(const std::string& message) = 0; | 61 virtual void OnFrameRead(const std::string& message) = 0; |
| 62 virtual void OnSocketClosed(bool closed_by_device) = 0; | 62 virtual void OnSocketClosed() = 0; |
| 63 | 63 |
| 64 protected: | 64 protected: |
| 65 virtual ~Delegate() {} | 65 virtual ~Delegate() {} |
| 66 }; | 66 }; |
| 67 | 67 |
| 68 AndroidWebSocket() {} | |
| 69 | |
| 70 virtual void Connect() = 0; | |
| 71 virtual void Disconnect() = 0; | |
| 72 virtual void SendFrame(const std::string& message) = 0; | |
| 73 virtual void ClearDelegate() = 0; | |
| 74 | |
| 75 protected: | |
| 76 virtual ~AndroidWebSocket() {} | 68 virtual ~AndroidWebSocket() {} |
| 77 | 69 |
| 78 private: | 70 virtual void SendFrame(const std::string& message) = 0; |
| 79 friend class base::RefCountedThreadSafe<AndroidWebSocket>; | |
| 80 | |
| 81 DISALLOW_COPY_AND_ASSIGN(AndroidWebSocket); | |
| 82 }; | 71 }; |
| 83 | 72 |
| 84 class DeviceProvider; | 73 class DeviceProvider; |
| 85 | 74 |
| 86 class Device : public base::RefCountedThreadSafe<Device>, | 75 class Device : public base::RefCountedThreadSafe<Device>, |
| 87 public base::NonThreadSafe { | 76 public base::NonThreadSafe { |
| 88 public: | 77 public: |
| 89 typedef AndroidDeviceManager::DeviceInfoCallback DeviceInfoCallback; | 78 typedef AndroidDeviceManager::DeviceInfoCallback DeviceInfoCallback; |
| 90 typedef AndroidDeviceManager::CommandCallback CommandCallback; | 79 typedef AndroidDeviceManager::CommandCallback CommandCallback; |
| 91 typedef AndroidDeviceManager::SocketCallback SocketCallback; | 80 typedef AndroidDeviceManager::SocketCallback SocketCallback; |
| 92 | 81 |
| 93 void QueryDeviceInfo(const DeviceInfoCallback& callback); | 82 void QueryDeviceInfo(const DeviceInfoCallback& callback); |
| 94 | 83 |
| 95 void OpenSocket(const std::string& socket_name, | 84 void OpenSocket(const std::string& socket_name, |
| 96 const SocketCallback& callback); | 85 const SocketCallback& callback); |
| 97 | 86 |
| 98 void SendJsonRequest(const std::string& socket_name, | 87 void SendJsonRequest(const std::string& socket_name, |
| 99 const std::string& request, | 88 const std::string& request, |
| 100 const CommandCallback& callback); | 89 const CommandCallback& callback); |
| 101 | 90 |
| 102 void HttpUpgrade(const std::string& socket_name, | 91 void HttpUpgrade(const std::string& socket_name, |
| 103 const std::string& url, | 92 const std::string& url, |
| 104 const SocketCallback& callback); | 93 const SocketCallback& callback); |
| 105 | 94 |
| 106 scoped_refptr<AndroidWebSocket> CreateWebSocket( | 95 AndroidWebSocket* CreateWebSocket( |
| 107 const std::string& socket_name, | 96 const std::string& socket_name, |
| 108 const std::string& url, | 97 const std::string& url, |
| 109 AndroidWebSocket::Delegate* delegate); | 98 AndroidWebSocket::Delegate* delegate); |
| 110 | 99 |
| 111 std::string serial() { return serial_; } | 100 std::string serial() { return serial_; } |
| 112 | 101 |
| 113 private: | 102 private: |
| 114 friend class AndroidDeviceManager; | 103 friend class AndroidDeviceManager; |
| 115 Device(scoped_refptr<base::MessageLoopProxy> device_message_loop, | 104 Device(scoped_refptr<base::MessageLoopProxy> device_message_loop, |
| 116 scoped_refptr<DeviceProvider> provider, | 105 scoped_refptr<DeviceProvider> provider, |
| (...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 208 DeviceDescriptors* descriptors); | 197 DeviceDescriptors* descriptors); |
| 209 | 198 |
| 210 typedef std::map<std::string, base::WeakPtr<Device> > DeviceWeakMap; | 199 typedef std::map<std::string, base::WeakPtr<Device> > DeviceWeakMap; |
| 211 | 200 |
| 212 scoped_refptr<HandlerThread> handler_thread_; | 201 scoped_refptr<HandlerThread> handler_thread_; |
| 213 DeviceProviders providers_; | 202 DeviceProviders providers_; |
| 214 DeviceWeakMap devices_; | 203 DeviceWeakMap devices_; |
| 215 }; | 204 }; |
| 216 | 205 |
| 217 #endif // CHROME_BROWSER_DEVTOOLS_DEVICE_ANDROID_DEVICE_MANAGER_H_ | 206 #endif // CHROME_BROWSER_DEVTOOLS_DEVICE_ANDROID_DEVICE_MANAGER_H_ |
| OLD | NEW |