OLD | NEW |
---|---|
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "modules/bluetooth/BluetoothRemoteGATTService.h" | 5 #include "modules/bluetooth/BluetoothRemoteGATTService.h" |
6 | 6 |
7 #include "bindings/core/v8/CallbackPromiseAdapter.h" | 7 #include "bindings/core/v8/CallbackPromiseAdapter.h" |
8 #include "bindings/core/v8/ScriptPromise.h" | 8 #include "bindings/core/v8/ScriptPromise.h" |
9 #include "bindings/core/v8/ScriptPromiseResolver.h" | 9 #include "bindings/core/v8/ScriptPromiseResolver.h" |
10 #include "core/dom/DOMException.h" | 10 #include "core/dom/DOMException.h" |
(...skipping 12 matching lines...) Expand all Loading... | |
23 } | 23 } |
24 | 24 |
25 BluetoothRemoteGATTService* BluetoothRemoteGATTService::take(ScriptPromiseResolv er*, PassOwnPtr<WebBluetoothRemoteGATTService> webService) | 25 BluetoothRemoteGATTService* BluetoothRemoteGATTService::take(ScriptPromiseResolv er*, PassOwnPtr<WebBluetoothRemoteGATTService> webService) |
26 { | 26 { |
27 if (!webService) { | 27 if (!webService) { |
28 return nullptr; | 28 return nullptr; |
29 } | 29 } |
30 return new BluetoothRemoteGATTService(webService); | 30 return new BluetoothRemoteGATTService(webService); |
31 } | 31 } |
32 | 32 |
33 ScriptPromise BluetoothRemoteGATTService::getCharacteristic(ScriptState* scriptS tate, | 33 // Class that allows us to resolve the promise with a single Characteristic or |
34 const StringOrUnsignedLong& characteristic, ExceptionState& exceptionState) | 34 // with a vector owning the characteristics. |
35 class GetCharacteristicsCallback : public WebBluetoothGetCharacteristicsCallback s { | |
Jeffrey Yasskin
2016/04/22 01:16:38
Are you sure the extra complexity in this class is
ortuno
2016/04/25 15:29:45
Thinking this through:
Right now the reason we us
Jeffrey Yasskin
2016/04/25 17:26:10
Ok, sounds good to keep it. Thanks for explaining
| |
36 public: | |
37 GetCharacteristicsCallback(bool singleCharacteristic, ScriptPromiseResolver* resolver) | |
38 : m_resolver(resolver) | |
39 , m_singleCharacteristic(singleCharacteristic) {} | |
40 | |
41 void onSuccess(const WebVector<WebBluetoothRemoteGATTCharacteristicInit*>& w ebCharacteristics) override | |
42 { | |
43 if (!m_resolver->getExecutionContext() || m_resolver->getExecutionContex t()->activeDOMObjectsAreStopped()) | |
44 return; | |
45 | |
46 if (m_singleCharacteristic) { | |
47 DCHECK_EQ(1u, webCharacteristics.size()); | |
48 m_resolver->resolve(BluetoothRemoteGATTCharacteristic::take(m_resolv er, adoptPtr(webCharacteristics[0]))); | |
49 return; | |
50 } | |
51 | |
52 HeapVector<Member<BluetoothRemoteGATTCharacteristic>> characteristics; | |
53 characteristics.reserveInitialCapacity(webCharacteristics.size()); | |
54 for (WebBluetoothRemoteGATTCharacteristicInit* webCharacteristic : webCh aracteristics) { | |
55 characteristics.append(BluetoothRemoteGATTCharacteristic::take(m_res olver, adoptPtr(webCharacteristic))); | |
56 } | |
57 m_resolver->resolve(characteristics); | |
58 } | |
59 | |
60 void onError(const WebBluetoothError& e) override | |
61 { | |
62 if (!m_resolver->getExecutionContext() || m_resolver->getExecutionContex t()->activeDOMObjectsAreStopped()) | |
63 return; | |
64 m_resolver->reject(BluetoothError::take(m_resolver, e)); | |
65 } | |
66 private: | |
67 Persistent<ScriptPromiseResolver> m_resolver; | |
68 bool m_singleCharacteristic; | |
69 }; | |
70 | |
71 ScriptPromise BluetoothRemoteGATTService::getCharacteristic(ScriptState* scriptS tate, const StringOrUnsignedLong& characteristic, ExceptionState& exceptionState ) | |
35 { | 72 { |
36 WebBluetooth* webbluetooth = BluetoothSupplement::fromScriptState(scriptStat e); | |
37 | |
38 String characteristicUUID = BluetoothUUID::getCharacteristic(characteristic, exceptionState); | 73 String characteristicUUID = BluetoothUUID::getCharacteristic(characteristic, exceptionState); |
39 if (exceptionState.hadException()) | 74 if (exceptionState.hadException()) |
40 return exceptionState.reject(scriptState); | 75 return exceptionState.reject(scriptState); |
41 | 76 |
42 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ; | 77 return getCharacteristicsImpl(scriptState, true /* single_characteristic */, characteristicUUID); |
43 ScriptPromise promise = resolver->promise(); | |
44 webbluetooth->getCharacteristic(m_webService->serviceInstanceID, characteris ticUUID, new CallbackPromiseAdapter<BluetoothRemoteGATTCharacteristic, Bluetooth Error>(resolver)); | |
45 | |
46 return promise; | |
47 } | |
48 | |
49 ScriptPromise BluetoothRemoteGATTService::getCharacteristics(ScriptState* script State, ExceptionState&) | |
50 { | |
51 return getCharacteristicsImpl(scriptState, String()); | |
52 } | 78 } |
53 | 79 |
54 ScriptPromise BluetoothRemoteGATTService::getCharacteristics(ScriptState* script State, const StringOrUnsignedLong& characteristic, ExceptionState& exceptionStat e) | 80 ScriptPromise BluetoothRemoteGATTService::getCharacteristics(ScriptState* script State, const StringOrUnsignedLong& characteristic, ExceptionState& exceptionStat e) |
55 { | 81 { |
56 String characteristicUUID = BluetoothUUID::getCharacteristic(characteristic, exceptionState); | 82 String characteristicUUID = BluetoothUUID::getCharacteristic(characteristic, exceptionState); |
57 if (exceptionState.hadException()) | 83 if (exceptionState.hadException()) |
58 return exceptionState.reject(scriptState); | 84 return exceptionState.reject(scriptState); |
59 | 85 |
60 return getCharacteristicsImpl(scriptState, characteristicUUID); | 86 return getCharacteristicsImpl(scriptState, false /* single_characteristic */ , characteristicUUID); |
61 } | 87 } |
62 | 88 |
63 // Class that allows us to use CallbackPromiseAdapter to resolve a promise with a | 89 ScriptPromise BluetoothRemoteGATTService::getCharacteristics(ScriptState* script State, ExceptionState&) |
64 // vector owning BluetoothRemoteGATTCharacteristics. | 90 { |
65 class RemoteCharacteristicArray { | 91 return getCharacteristicsImpl(scriptState, false /* single_characteristic */ ); |
66 STATIC_ONLY(RemoteCharacteristicArray); | 92 } |
67 public: | |
68 using WebType = OwnPtr<WebVector<WebBluetoothRemoteGATTCharacteristicInit*>> ; | |
69 static HeapVector<Member<BluetoothRemoteGATTCharacteristic>> take(ScriptProm iseResolver* resolver, PassOwnPtr<WebVector<WebBluetoothRemoteGATTCharacteristic Init*>> webCharacteristics) | |
70 { | |
71 HeapVector<Member<BluetoothRemoteGATTCharacteristic>> characteristics; | |
72 characteristics.reserveInitialCapacity(webCharacteristics->size()); | |
73 for (WebBluetoothRemoteGATTCharacteristicInit* webCharacteristic : *webC haracteristics) { | |
74 characteristics.append(BluetoothRemoteGATTCharacteristic::take(resol ver, adoptPtr(webCharacteristic))); | |
75 } | |
76 return characteristics; | |
77 } | |
78 }; | |
79 | 93 |
80 ScriptPromise BluetoothRemoteGATTService::getCharacteristicsImpl(ScriptState* sc riptState, String characteristicsUUID) | 94 ScriptPromise BluetoothRemoteGATTService::getCharacteristicsImpl(ScriptState* sc riptState, bool singleCharacteristic, String characteristicsUUID) |
81 { | 95 { |
82 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ; | 96 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ; |
83 ScriptPromise promise = resolver->promise(); | 97 ScriptPromise promise = resolver->promise(); |
84 | 98 |
85 WebBluetooth* webbluetooth = BluetoothSupplement::fromScriptState(scriptStat e); | 99 WebBluetooth* webbluetooth = BluetoothSupplement::fromScriptState(scriptStat e); |
86 webbluetooth->getCharacteristics(m_webService->serviceInstanceID, characteri sticsUUID, new CallbackPromiseAdapter<RemoteCharacteristicArray, BluetoothError> (resolver)); | 100 webbluetooth->getCharacteristics(m_webService->serviceInstanceID, singleChar acteristic, characteristicsUUID, new GetCharacteristicsCallback(singleCharacteri stic, resolver)); |
87 | 101 |
88 return promise; | 102 return promise; |
89 } | 103 } |
90 | 104 |
91 } // namespace blink | 105 } // namespace blink |
OLD | NEW |