OLD | NEW |
---|---|
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 part of dart.developer; | 5 part of dart.developer; |
6 | 6 |
7 class ServiceExtensionResponse { | 7 class ServiceExtensionResponse { |
8 final String _result; | 8 final String _result; |
9 final int _errorCode; | 9 final int _errorCode; |
10 final String _errorDetail; | 10 final String _errorDetail; |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
99 'handler', | 99 'handler', |
100 'Must be a ServiceExtensionHandler'); | 100 'Must be a ServiceExtensionHandler'); |
101 } | 101 } |
102 _extensions[method] = handler; | 102 _extensions[method] = handler; |
103 } | 103 } |
104 | 104 |
105 bool _extensionExists(String method) { | 105 bool _extensionExists(String method) { |
106 return _extensions[method] != null; | 106 return _extensions[method] != null; |
107 } | 107 } |
108 | 108 |
109 bool _invokeExtension(String method, | 109 bool _invokeExtension(String method, |
Ivan Posva
2015/08/10 21:40:21
_scheduleExtension?
Cutch
2015/08/10 21:56:20
Done.
| |
110 List<String> parameterKeys, | 110 List<String> parameterKeys, |
111 List<String> parameterValues, | 111 List<String> parameterValues, |
112 SendPort replyPort, | 112 SendPort replyPort, |
113 Object id) { | 113 Object id) { |
114 ServiceExtensionHandler handler = _extensions[method]; | 114 ServiceExtensionHandler handler = _extensions[method]; |
Ivan Posva
2015/08/10 21:40:21
Combine this with the check for extension and retu
Cutch
2015/08/10 21:56:20
Done.
| |
115 assert(handler != null); | 115 assert(handler != null); |
116 var parameters = {}; | 116 // Defer execution of handler until next event loop. |
117 for (var i = 0; i < parameterKeys.length; i++) { | 117 Timer.run(() { |
118 parameters[parameterKeys[i]] = parameterValues[i]; | 118 var parameters = {}; |
119 } | 119 for (var i = 0; i < parameterKeys.length; i++) { |
120 var response; | 120 parameters[parameterKeys[i]] = parameterValues[i]; |
121 try { | 121 } |
122 response = handler(method, parameters); | 122 var response; |
123 } catch (e, st) { | 123 try { |
124 var errorDetails = (st == null) ? '$e' : '$e\n$st'; | 124 response = handler(method, parameters); |
125 response = new ServiceExtensionResponse.error( | 125 } catch (e, st) { |
126 ServiceExtensionResponse.kExtensionError, | 126 var errorDetails = (st == null) ? '$e' : '$e\n$st'; |
127 errorDetails); | |
128 _postResponse(replyPort, id, response); | |
129 return true; | |
130 } | |
131 if (response is! Future) { | |
132 response = new ServiceExtensionResponse.error( | |
133 ServiceExtensionResponse.kExtensionError, | |
134 "Extension handler must return a Future"); | |
135 _postResponse(replyPort, id, response); | |
136 return true; | |
137 } | |
138 response.catchError((e, st) { | |
139 var errorDetails = (st == null) ? '$e' : '$e\n$st'; | |
140 return new ServiceExtensionResponse.error( | |
141 ServiceExtensionResponse.kExtensionError, | |
142 errorDetails); | |
143 }).then((response) { | |
144 if (response == null) { | |
145 response = new ServiceExtensionResponse.error( | 127 response = new ServiceExtensionResponse.error( |
146 ServiceExtensionResponse.kExtensionError, | 128 ServiceExtensionResponse.kExtensionError, |
147 "Extension handler returned null"); | 129 errorDetails); |
130 _postResponse(replyPort, id, response); | |
131 return; | |
148 } | 132 } |
149 _postResponse(replyPort, id, response); | 133 if (response is! Future) { |
134 response = new ServiceExtensionResponse.error( | |
135 ServiceExtensionResponse.kExtensionError, | |
136 "Extension handler must return a Future"); | |
137 _postResponse(replyPort, id, response); | |
138 return; | |
139 } | |
140 response.catchError((e, st) { | |
141 var errorDetails = (st == null) ? '$e' : '$e\n$st'; | |
142 return new ServiceExtensionResponse.error( | |
143 ServiceExtensionResponse.kExtensionError, | |
144 errorDetails); | |
145 }).then((response) { | |
146 if (response == null) { | |
147 response = new ServiceExtensionResponse.error( | |
148 ServiceExtensionResponse.kExtensionError, | |
149 "Extension handler returned null"); | |
150 } | |
151 _postResponse(replyPort, id, response); | |
152 }); | |
150 }); | 153 }); |
151 // Push an event on the event loop so that we invoke the scheduled microtasks. | |
152 Timer.run(() {}); | |
153 return true; | 154 return true; |
154 } | 155 } |
155 | 156 |
156 _postResponse(SendPort replyPort, | 157 _postResponse(SendPort replyPort, |
157 Object id, | 158 Object id, |
158 ServiceExtensionResponse response) { | 159 ServiceExtensionResponse response) { |
159 assert(replyPort != null); | 160 assert(replyPort != null); |
160 if (id == null) { | 161 if (id == null) { |
161 // No id -> no response. | 162 // No id -> no response. |
162 // TODO(johnmccutchan): This code and the code in service.cc leave the | 163 // TODO(johnmccutchan): This code and the code in service.cc leave the |
(...skipping 10 matching lines...) Expand all Loading... | |
173 sb.write('"result":'); | 174 sb.write('"result":'); |
174 } | 175 } |
175 sb.write('${response._toString()},'); | 176 sb.write('${response._toString()},'); |
176 if (id is String) { | 177 if (id is String) { |
177 sb.write('"id":"$id"}'); | 178 sb.write('"id":"$id"}'); |
178 } else { | 179 } else { |
179 sb.write('"id":$id}'); | 180 sb.write('"id":$id}'); |
180 } | 181 } |
181 replyPort.send(sb.toString()); | 182 replyPort.send(sb.toString()); |
182 } | 183 } |
OLD | NEW |