Index: device/bluetooth/adapter_factory.cc |
diff --git a/device/bluetooth/adapter_factory.cc b/device/bluetooth/adapter_factory.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..8723b20587991cf2ce1339a18aa3c4d9e159072f |
--- /dev/null |
+++ b/device/bluetooth/adapter_factory.cc |
@@ -0,0 +1,49 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include <utility> |
+ |
+#include "base/memory/ptr_util.h" |
+#include "device/bluetooth/adapter.h" |
+#include "device/bluetooth/adapter_factory.h" |
+#include "device/bluetooth/bluetooth_adapter_factory.h" |
+#include "mojo/public/cpp/bindings/strong_binding.h" |
+ |
+namespace bluetooth { |
+ |
+AdapterFactory::AdapterFactory() : weak_ptr_factory_(this) {} |
+AdapterFactory::~AdapterFactory() {} |
+ |
+// static |
+void AdapterFactory::Create(mojom::AdapterFactoryRequest request) { |
+ mojo::MakeStrongBinding(base::MakeUnique<AdapterFactory>(), |
+ std::move(request)); |
+} |
+ |
+void AdapterFactory::GetAdapter(mojom::AdapterRequest request, |
+ mojom::AdapterClientPtr client, |
+ const GetAdapterCallback& callback) { |
+ if (device::BluetoothAdapterFactory::IsBluetoothAdapterAvailable()) { |
+ device::BluetoothAdapterFactory::GetAdapter(base::Bind( |
+ &AdapterFactory::OnGetAdapter, weak_ptr_factory_.GetWeakPtr(), |
+ base::Passed(&request), base::Passed(&client), callback)); |
+ } else { |
+ callback.Run(false); |
ortuno
2016/10/05 02:07:51
nit: You should always add comments to booleans an
mbrunson
2016/10/05 17:59:04
Done.
|
+ } |
+} |
+ |
+void AdapterFactory::OnGetAdapter( |
+ mojom::AdapterRequest request, |
+ mojom::AdapterClientPtr client, |
+ const GetAdapterCallback& callback, |
+ scoped_refptr<device::BluetoothAdapter> adapter) { |
+ if (adapter) { |
ortuno
2016/10/05 02:07:51
I think we are always guaranteed to get an adapter
mbrunson
2016/10/05 17:59:04
It seems to be always guaranteed.
|
+ Adapter::Create(std::move(request), std::move(client), adapter); |
ortuno
2016/10/05 02:07:51
We were forced to make a Create method because of
mbrunson
2016/10/05 17:59:04
Done.
|
+ callback.Run(true); |
+ } else { |
+ callback.Run(false); |
+ } |
+} |
+ |
+} // namespace bluetooth |