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 library unittest.dart; | 5 library unittest.dart; |
6 | 6 |
7 import 'dart:async'; | 7 import 'dart:async'; |
8 import 'dart:io'; | 8 import 'dart:io'; |
9 import 'dart:isolate'; | 9 import 'dart:isolate'; |
10 | 10 |
11 import 'package:path/path.dart' as p; | 11 import 'package:path/path.dart' as p; |
12 | 12 |
13 import 'io.dart'; | |
14 import 'isolate_wrapper.dart'; | 13 import 'isolate_wrapper.dart'; |
15 import 'remote_exception.dart'; | 14 import 'remote_exception.dart'; |
16 | 15 |
17 /// Runs [code] in an isolate. | 16 /// Runs [code] in an isolate. |
18 /// | 17 /// |
19 /// [code] should be the contents of a Dart entrypoint. It may contain imports; | 18 /// [code] should be the contents of a Dart entrypoint. It may contain imports; |
20 /// they will be resolved in the same context as the host isolate. [message] is | 19 /// they will be resolved in the same context as the host isolate. [message] is |
21 /// passed to the [main] method of the code being run; the caller is responsible | 20 /// passed to the [main] method of the code being run; the caller is responsible |
22 /// for using this to establish communication with the isolate. | 21 /// for using this to establish communication with the isolate. |
23 /// | 22 /// |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
63 Isolate.spawnUri(Uri.parse(message['uri']), [], message['message'], | 62 Isolate.spawnUri(Uri.parse(message['uri']), [], message['message'], |
64 packageRoot: packageRoot) | 63 packageRoot: packageRoot) |
65 .then((_) => replyTo.send({'type': 'success'})) | 64 .then((_) => replyTo.send({'type': 'success'})) |
66 .catchError((error, stackTrace) { | 65 .catchError((error, stackTrace) { |
67 replyTo.send({ | 66 replyTo.send({ |
68 'type': 'error', | 67 'type': 'error', |
69 'error': RemoteException.serialize(error, stackTrace) | 68 'error': RemoteException.serialize(error, stackTrace) |
70 }); | 69 }); |
71 }); | 70 }); |
72 } | 71 } |
OLD | NEW |