| 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 #ifndef DEVICE_BLUETOOTH_BLUETOOTH_ADAPTER_FACTORY_H_ | 5 #ifndef DEVICE_BLUETOOTH_BLUETOOTH_ADAPTER_FACTORY_H_ |
| 6 #define DEVICE_BLUETOOTH_BLUETOOTH_ADAPTER_FACTORY_H_ | 6 #define DEVICE_BLUETOOTH_BLUETOOTH_ADAPTER_FACTORY_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/memory/ref_counted.h" | 11 #include "base/memory/ref_counted.h" |
| 12 #include "device/bluetooth/bluetooth_adapter.h" | 12 #include "device/bluetooth/bluetooth_adapter.h" |
| 13 | 13 |
| 14 namespace device { | 14 namespace device { |
| 15 | 15 |
| 16 // BluetoothAdapterFactory is a class that contains static methods, which | 16 // BluetoothAdapterFactory is a class that contains static methods, which |
| 17 // instantiate either a specific Bluetooth adapter, or the generic "default | 17 // instantiate either a specific Bluetooth adapter, or the generic "default |
| 18 // adapter" which may change depending on availability. | 18 // adapter" which may change depending on availability. |
| 19 class BluetoothAdapterFactory { | 19 class BluetoothAdapterFactory { |
| 20 public: | 20 public: |
| 21 typedef base::Callback<void(scoped_refptr<BluetoothAdapter> adapter)> |
| 22 AdapterCallback; |
| 23 |
| 21 // Returns true if the Bluetooth adapter is available for the current | 24 // Returns true if the Bluetooth adapter is available for the current |
| 22 // platform. | 25 // platform. |
| 23 static bool IsBluetoothAdapterAvailable(); | 26 static bool IsBluetoothAdapterAvailable(); |
| 24 | 27 |
| 25 // Runs the callback with the shared instance for the default adapter when the | 28 // Returns the shared instance of the default adapter, creating and |
| 26 // adapter is available to be used. | 29 // initializing it if necessary. |callback| is called with the adapter |
| 27 static void RunCallbackOnAdapterReady( | 30 // instance passed only once the adapter is fully initialized and ready to |
| 28 const BluetoothAdapter::AdapterCallback& callback); | 31 // use. |
| 32 static void GetAdapter(const AdapterCallback& callback); |
| 29 | 33 |
| 30 // Returns the shared instance of the adapter that has already been created. | 34 // Returns the shared instance of the adapter that has already been created, |
| 35 // but may or may not have been initialized. |
| 31 // It returns NULL if no adapter has been created at the time. | 36 // It returns NULL if no adapter has been created at the time. |
| 32 static scoped_refptr<BluetoothAdapter> GetAdapter(); | 37 static scoped_refptr<BluetoothAdapter> MaybeGetAdapter(); |
| 33 | 38 |
| 34 // Creates an instance for a specific adapter at address |address|. | 39 // Creates an instance for a specific adapter at address |address|. |
| 35 static BluetoothAdapter* Create(const std::string& address); | 40 static BluetoothAdapter* Create(const std::string& address); |
| 36 }; | 41 }; |
| 37 | 42 |
| 38 } // namespace device | 43 } // namespace device |
| 39 | 44 |
| 40 #endif // DEVICE_BLUETOOTH_BLUETOOTH_ADAPTER_FACTORY_H_ | 45 #endif // DEVICE_BLUETOOTH_BLUETOOTH_ADAPTER_FACTORY_H_ |
| OLD | NEW |