Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(34)

Side by Side Diff: third_party/WebKit/Source/modules/bluetooth/BluetoothError.cpp

Issue 2680783002: bluetooth: show better error messages for services, characteristics and descriptors (Closed)
Patch Set: Added UUID to DESCRIPTOR_NOT_FOUND, INVALID_DESCRIPTOR and INVALID_CHARACTERISTIC. Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 "modules/bluetooth/BluetoothError.h" 5 #include "modules/bluetooth/BluetoothError.h"
6 6
7 #include "core/dom/DOMException.h" 7 #include "core/dom/DOMException.h"
8 #include "core/dom/ExceptionCode.h" 8 #include "core/dom/ExceptionCode.h"
9 9
10 namespace blink { 10 namespace blink {
11 11
12 DOMException* BluetoothError::take(ScriptPromiseResolver*, 12 // static
13 mojom::blink::WebBluetoothResult error) { 13 DOMException* BluetoothError::createDOMException(
14 mojom::blink::WebBluetoothResult error,
15 const String& detailedMessage) {
14 switch (error) { 16 switch (error) {
15 case mojom::blink::WebBluetoothResult::SUCCESS: 17 case mojom::blink::WebBluetoothResult::SUCCESS:
16 ASSERT_NOT_REACHED(); 18 NOTREACHED();
19 return DOMException::create(UnknownError);
20 case mojom::blink::WebBluetoothResult::SERVICE_NOT_FOUND:
21 return DOMException::create(NotFoundError, detailedMessage);
22 case mojom::blink::WebBluetoothResult::CHARACTERISTIC_NOT_FOUND:
23 return DOMException::create(NotFoundError, detailedMessage);
24 case mojom::blink::WebBluetoothResult::DESCRIPTOR_NOT_FOUND:
25 return DOMException::create(NotFoundError, detailedMessage);
26 case mojom::blink::WebBluetoothResult::INVALID_SERVICE:
27 return DOMException::create(InvalidStateError, detailedMessage);
28 case mojom::blink::WebBluetoothResult::INVALID_CHARACTERISTIC:
29 return DOMException::create(InvalidStateError, detailedMessage);
30 case mojom::blink::WebBluetoothResult::INVALID_DESCRIPTOR:
31 return DOMException::create(InvalidStateError, detailedMessage);
32 default:
33 NOTREACHED();
34 return DOMException::create(UnknownError);
35 }
36 }
37
38 // static
39 DOMException* BluetoothError::createDOMException(
40 mojom::blink::WebBluetoothResult error) {
41 switch (error) {
42 case mojom::blink::WebBluetoothResult::SUCCESS:
43 NOTREACHED();
17 return DOMException::create(UnknownError); 44 return DOMException::create(UnknownError);
18 #define MAP_ERROR(enumeration, name, message) \ 45 #define MAP_ERROR(enumeration, name, message) \
19 case mojom::blink::WebBluetoothResult::enumeration: \ 46 case mojom::blink::WebBluetoothResult::enumeration: \
20 return DOMException::create(name, message) 47 return DOMException::create(name, message);
21 48
22 // InvalidModificationErrors: 49 // InvalidModificationErrors:
23 MAP_ERROR(GATT_INVALID_ATTRIBUTE_LENGTH, InvalidModificationError, 50 MAP_ERROR(GATT_INVALID_ATTRIBUTE_LENGTH, InvalidModificationError,
24 "GATT Error: invalid attribute length."); 51 "GATT Error: invalid attribute length.");
25 52
26 // InvalidStateErrors: 53 // InvalidStateErrors:
27 MAP_ERROR(SERVICE_NO_LONGER_EXISTS, InvalidStateError, 54 MAP_ERROR(SERVICE_NO_LONGER_EXISTS, InvalidStateError,
28 "GATT Service no longer exists."); 55 "GATT Service no longer exists.");
29 MAP_ERROR(CHARACTERISTIC_NO_LONGER_EXISTS, InvalidStateError, 56 MAP_ERROR(CHARACTERISTIC_NO_LONGER_EXISTS, InvalidStateError,
30 "GATT Characteristic no longer exists."); 57 "GATT Characteristic no longer exists.");
31 MAP_ERROR(DESCRIPTOR_NO_LONGER_EXISTS, InvalidStateError, 58 MAP_ERROR(DESCRIPTOR_NO_LONGER_EXISTS, InvalidStateError,
32 "GATT Descriptor no longer exists."); 59 "GATT Descriptor no longer exists.");
60 MAP_ERROR(INVALID_CHARACTERISTIC, InvalidStateError,
61 "Characteristic is no longer valid. Remember to retrieve the "
62 "characteristic again after reconnecting.");
63 MAP_ERROR(INVALID_DESCRIPTOR, InvalidStateError,
64 "Descriptor is no longer valid. Remember to retrieve the "
65 "Descriptor again after reconnecting.");
66 MAP_ERROR(INVALID_SERVICE, InvalidStateError,
scheib 2017/02/10 18:25:34 This new pattern does not LGTM. (Sorry for noticin
67 "Service is no longer valid. Remember to retrieve the service "
68 "again after reconnecting.");
33 69
34 // NetworkErrors: 70 // NetworkErrors:
35 MAP_ERROR(CONNECT_ALREADY_IN_PROGRESS, NetworkError, 71 MAP_ERROR(CONNECT_ALREADY_IN_PROGRESS, NetworkError,
36 "Connection already in progress."); 72 "Connection already in progress.");
37 MAP_ERROR(CONNECT_ATTRIBUTE_LENGTH_INVALID, NetworkError, 73 MAP_ERROR(CONNECT_ATTRIBUTE_LENGTH_INVALID, NetworkError,
38 "Write operation exceeds the maximum length of the attribute."); 74 "Write operation exceeds the maximum length of the attribute.");
39 MAP_ERROR(CONNECT_AUTH_CANCELED, NetworkError, 75 MAP_ERROR(CONNECT_AUTH_CANCELED, NetworkError,
40 "Authentication canceled."); 76 "Authentication canceled.");
41 MAP_ERROR(CONNECT_AUTH_FAILED, NetworkError, "Authentication failed."); 77 MAP_ERROR(CONNECT_AUTH_FAILED, NetworkError, "Authentication failed.");
42 MAP_ERROR(CONNECT_AUTH_REJECTED, NetworkError, 78 MAP_ERROR(CONNECT_AUTH_REJECTED, NetworkError,
(...skipping 18 matching lines...) Expand all
61 "Unsupported device."); 97 "Unsupported device.");
62 MAP_ERROR(CONNECT_WRITE_NOT_PERMITTED, NetworkError, 98 MAP_ERROR(CONNECT_WRITE_NOT_PERMITTED, NetworkError,
63 "GATT write operation is not permitted."); 99 "GATT write operation is not permitted.");
64 MAP_ERROR(DEVICE_NO_LONGER_IN_RANGE, NetworkError, 100 MAP_ERROR(DEVICE_NO_LONGER_IN_RANGE, NetworkError,
65 "Bluetooth Device is no longer in range."); 101 "Bluetooth Device is no longer in range.");
66 MAP_ERROR(GATT_NOT_PAIRED, NetworkError, "GATT Error: Not paired."); 102 MAP_ERROR(GATT_NOT_PAIRED, NetworkError, "GATT Error: Not paired.");
67 MAP_ERROR(GATT_OPERATION_IN_PROGRESS, NetworkError, 103 MAP_ERROR(GATT_OPERATION_IN_PROGRESS, NetworkError,
68 "GATT operation already in progress."); 104 "GATT operation already in progress.");
69 MAP_ERROR(UNTRANSLATED_CONNECT_ERROR_CODE, NetworkError, 105 MAP_ERROR(UNTRANSLATED_CONNECT_ERROR_CODE, NetworkError,
70 "Unknown ConnectErrorCode."); 106 "Unknown ConnectErrorCode.");
107 MAP_ERROR(GATT_SERVER_NOT_CONNECTED, NetworkError,
108 "GATT Server is disconnected. Cannot perform GATT operations.");
109 MAP_ERROR(GATT_SERVER_DISCONNECTED, NetworkError,
110 "GATT Server disconnected while performing a GATT operation.");
111 MAP_ERROR(GATT_SERVER_DISCONNECTED_WHILE_RETRIEVING_CHARACTERISTICS,
112 NetworkError,
113 "GATT Server disconnected while retrieving characteristics.");
114 MAP_ERROR(
115 GATT_SERVER_NOT_CONNECTED_CANNOT_RETRIEVE_CHARACTERISTICS,
116 NetworkError,
117 "GATT Server is disconnected. Cannot retrieve characteristics.");
71 118
72 // NotFoundErrors: 119 // NotFoundErrors:
73 MAP_ERROR(WEB_BLUETOOTH_NOT_SUPPORTED, NotFoundError, 120 MAP_ERROR(WEB_BLUETOOTH_NOT_SUPPORTED, NotFoundError,
74 "Web Bluetooth is not supported on this platform. For a list " 121 "Web Bluetooth is not supported on this platform. For a list "
75 "of supported platforms see: https://goo.gl/J6ASzs"); 122 "of supported platforms see: https://goo.gl/J6ASzs");
76 MAP_ERROR(NO_BLUETOOTH_ADAPTER, NotFoundError, 123 MAP_ERROR(NO_BLUETOOTH_ADAPTER, NotFoundError,
77 "Bluetooth adapter not available."); 124 "Bluetooth adapter not available.");
78 MAP_ERROR(CHOSEN_DEVICE_VANISHED, NotFoundError, 125 MAP_ERROR(CHOSEN_DEVICE_VANISHED, NotFoundError,
79 "User selected a device that doesn't exist anymore."); 126 "User selected a device that doesn't exist anymore.");
80 MAP_ERROR(CHOOSER_CANCELLED, NotFoundError, 127 MAP_ERROR(CHOOSER_CANCELLED, NotFoundError,
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
139 "requestDevice() called with a filter containing a blocklisted " 186 "requestDevice() called with a filter containing a blocklisted "
140 "UUID. https://goo.gl/4NeimX"); 187 "UUID. https://goo.gl/4NeimX");
141 MAP_ERROR(REQUEST_DEVICE_FROM_CROSS_ORIGIN_IFRAME, SecurityError, 188 MAP_ERROR(REQUEST_DEVICE_FROM_CROSS_ORIGIN_IFRAME, SecurityError,
142 "requestDevice() called from cross-origin iframe."); 189 "requestDevice() called from cross-origin iframe.");
143 MAP_ERROR(REQUEST_DEVICE_WITHOUT_FRAME, SecurityError, 190 MAP_ERROR(REQUEST_DEVICE_WITHOUT_FRAME, SecurityError,
144 "No window to show the requestDevice() dialog."); 191 "No window to show the requestDevice() dialog.");
145 192
146 #undef MAP_ERROR 193 #undef MAP_ERROR
147 } 194 }
148 195
149 ASSERT_NOT_REACHED(); 196 NOTREACHED();
150 return DOMException::create(UnknownError); 197 return DOMException::create(UnknownError);
151 } 198 }
152 199
153 } // namespace blink 200 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698