Index: pkg/dev_compiler/tool/input_sdk/lib/isolate/isolate.dart |
diff --git a/pkg/dev_compiler/tool/input_sdk/lib/isolate/isolate.dart b/pkg/dev_compiler/tool/input_sdk/lib/isolate/isolate.dart |
deleted file mode 100644 |
index f0fd886aa03896702ceea85b8d9b73c1b6da8591..0000000000000000000000000000000000000000 |
--- a/pkg/dev_compiler/tool/input_sdk/lib/isolate/isolate.dart |
+++ /dev/null |
@@ -1,618 +0,0 @@ |
-// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
-// for details. All rights reserved. Use of this source code is governed by a |
-// BSD-style license that can be found in the LICENSE file. |
- |
-/** |
- * Concurrent programming using _isolates_: |
- * independent workers that are similar to threads |
- * but don't share memory, |
- * communicating only via messages. |
- */ |
-library dart.isolate; |
- |
-import "dart:async"; |
- |
-part "capability.dart"; |
- |
-/** |
- * Thrown when an isolate cannot be created. |
- */ |
-class IsolateSpawnException implements Exception { |
- /** Error message reported by the spawn operation. */ |
- final String message; |
- IsolateSpawnException(this.message); |
- String toString() => "IsolateSpawnException: $message"; |
-} |
- |
-/** |
- * An isolated Dart execution context. |
- * |
- * All Dart code runs in an isolate, and code can access classes and values |
- * only from the same isolate. Different isolates can communicate by sending |
- * values through ports (see [ReceivePort], [SendPort]). |
- * |
- * An `Isolate` object is a reference to an isolate, usually different from |
- * the current isolate. |
- * It represents, and can be used control, the other isolate. |
- * |
- * When spawning a new isolate, the spawning isolate receives an `Isolate` |
- * object representing the new isolate when the spawn operation succeeds. |
- * |
- * Isolates run code in its own event loop, and each event may run smaller tasks |
- * in a nested microtask queue. |
- * |
- * An `Isolate` object allows other isolates to control the event loop |
- * of the isolate that it represents, and to inspect the isolate, |
- * for example by pausing the isolate or by getting events when the isolate |
- * has an uncaught error. |
- * |
- * The [controlPort] gives access to controlling the isolate, and the |
- * [pauseCapability] and [terminateCapability] guard access to some control |
- * operations. |
- * The `Isolate` object provided by a spawn operation will have the |
- * control port and capabilities needed to control the isolate. |
- * New isolates objects can be created without some of these capabilities |
- * if necessary. |
- * |
- * An `Isolate` object cannot be sent over a `SendPort`, but the control port |
- * and capabilities can be sent, and can be used to create a new functioning |
- * `Isolate` object in the receiving port's isolate. |
- */ |
-class Isolate { |
- /** Argument to `ping` and `kill`: Ask for immediate action. */ |
- static const int IMMEDIATE = 0; |
- /** Argument to `ping` and `kill`: Ask for action before the next event. */ |
- static const int BEFORE_NEXT_EVENT = 1; |
- /** Argument to `ping` and `kill`: Ask for action after normal events. */ |
- static const int AS_EVENT = 2; |
- |
- /** |
- * Control port used to send control messages to the isolate. |
- * |
- * This class provides helper functions that sends control messages |
- * to the control port. |
- * |
- * The control port identifies the isolate. |
- */ |
- final SendPort controlPort; |
- |
- /** |
- * Capability granting the ability to pause the isolate. |
- * |
- * This capability is used by [pause]. |
- * If the capability is not the correct pause capability of the isolate, |
- * including if the capability is `null`, then calls to `pause` will have no |
- * effect. |
- * |
- * If the isolate is started in a paused state, use this capability as |
- * argument to [resume] to resume the isolate. |
- */ |
- final Capability pauseCapability; |
- |
- /** |
- * Capability granting the ability to terminate the isolate. |
- * |
- * This capability is used by [kill] and [setErrorsFatal]. |
- * If the capability is not the correct termination capability of the isolate, |
- * including if the capability is `null`, then calls to those methods will |
- * have no effect. |
- */ |
- final Capability terminateCapability; |
- |
- /** |
- * Create a new [Isolate] object with a restricted set of capabilities. |
- * |
- * The port should be a control port for an isolate, as taken from |
- * another `Isolate` object. |
- * |
- * The capabilities should be the subset of the capabilities that are |
- * available to the original isolate. |
- * Capabilities of an isolate are locked to that isolate, and have no effect |
- * anywhere else, so the capabilities should come from the same isolate as |
- * the control port. |
- * |
- * If all the available capabilities are included, |
- * there is no reason to create a new object, |
- * since the behavior is defined entirely |
- * by the control port and capabilities. |
- */ |
- Isolate(this.controlPort, {this.pauseCapability, |
- this.terminateCapability}); |
- |
- /** |
- * Return the current [Isolate]. |
- * |
- * The isolate gives access to the capabilities needed to inspect, |
- * pause or kill the isolate, and allows granting these capabilities |
- * to others. |
- */ |
- external static Isolate get current; |
- |
- /** |
- * Creates and spawns an isolate that shares the same code as the current |
- * isolate. |
- * |
- * The argument [entryPoint] specifies the entry point of the spawned |
- * isolate. It must be a top-level function or a static method that |
- * takes one argument - that is, one-parameter functions that can be |
- * compile-time constant function values. |
- * It is not allowed to pass the value of function expressions or an instance |
- * method extracted from an object. |
- * |
- * The entry-point function is invoked with the initial [message]. |
- * Usually the initial [message] contains a [SendPort] so |
- * that the spawner and spawnee can communicate with each other. |
- * |
- * If the [paused] parameter is set to `true`, |
- * the isolate will start up in a paused state, |
- * as if by an initial call of `isolate.pause(isolate.pauseCapability)`. |
- * This allows setting up error or exit listeners on the isolate |
- * before it starts running. |
- * To resume the isolate, call `isolate.resume(isolate.pauseCapability)`. |
- * |
- * WARNING: The `pause` parameter is not implemented on all platforms yet. |
- * |
- * Returns a future that will complete with an [Isolate] instance if the |
- * spawning succeeded. It will complete with an error otherwise. |
- */ |
- external static Future<Isolate> spawn(void entryPoint(message), var message, |
- { bool paused: false }); |
- |
- /** |
- * Creates and spawns an isolate that runs the code from the library with |
- * the specified URI. |
- * |
- * The isolate starts executing the top-level `main` function of the library |
- * with the given URI. |
- * |
- * The target `main` must be a subtype of one of these three signatures: |
- * |
- * * `main()` |
- * * `main(args)` |
- * * `main(args, message)` |
- * |
- * When present, the parameter `args` is set to the provided [args] list. |
- * When present, the parameter `message` is set to the initial [message]. |
- * |
- * If the [packageRoot] parameter is provided, it is used to find the location |
- * of packages imports in the spawned isolate. |
- * The `packageRoot` URI must be a "file" or "http"/"https" URI that specifies |
- * a directory. If it doesn't end in a slash, one will be added before |
- * using the URI, and any query or fragment parts are ignored. |
- * Package imports (like "package:foo/bar.dart") in the new isolate are |
- * resolved against this location, as by |
- * `packageRoot.resolve("foo/bar.dart")`. |
- * This includes the main entry [uri] if it happens to be a package-URL. |
- * If [packageRoot] is omitted, it defaults to the same URI that |
- * the current isolate is using. |
- * |
- * WARNING: The [packageRoot] parameter is not implemented on all |
- * platforms yet. |
- * |
- * If the [paused] parameter is set to `true`, |
- * the isolate will start up in a paused state, |
- * as if by an initial call of `isolate.pause(isolate.pauseCapability)`. |
- * This allows setting up error or exit listeners on the isolate |
- * before it starts running. |
- * To resume the isolate, call `isolate.resume(isolate.pauseCapability)`. |
- * |
- * WARNING: The `pause` parameter is not implemented on all platforms yet. |
- * |
- * Returns a future that will complete with an [Isolate] instance if the |
- * spawning succeeded. It will complete with an error otherwise. |
- */ |
- external static Future<Isolate> spawnUri( |
- Uri uri, |
- List<String> args, |
- var message, |
- {bool paused: false, |
- Uri packageRoot}); |
- |
- /** |
- * Requests the isolate to pause. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * The isolate should stop handling events by pausing its event queue. |
- * The request will eventually make the isolate stop doing anything. |
- * It will be handled before any other messages that are later sent to the |
- * isolate from the current isolate, but no other guarantees are provided. |
- * |
- * The event loop may be paused before previously sent, but not yet exeuted, |
- * messages have been reached. |
- * |
- * If [resumeCapability] is provided, it is used to identity the pause, |
- * and must be used again to end the pause using [resume]. |
- * Otherwise a new resume capability is created and returned. |
- * |
- * If an isolate is paused more than once using the same capability, |
- * only one resume with that capability is needed to end the pause. |
- * |
- * If an isolate is paused using more than one capability, |
- * they must all be individully ended before the isolate resumes. |
- * |
- * Returns the capability that must be used to resume end the pause. |
- */ |
- Capability pause([Capability resumeCapability]) { |
- if (resumeCapability == null) resumeCapability = new Capability(); |
- _pause(resumeCapability); |
- return resumeCapability; |
- } |
- |
- /** Internal implementation of [pause]. */ |
- external void _pause(Capability resumeCapability); |
- |
- /** |
- * Resumes a paused isolate. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * Sends a message to an isolate requesting that it ends a pause |
- * that was requested using the [resumeCapability]. |
- * |
- * When all active pause requests have been cancelled, the isolate |
- * will continue handling normal messages. |
- * |
- * The capability must be one returned by a call to [pause] on this |
- * isolate, otherwise the resume call does nothing. |
- */ |
- external void resume(Capability resumeCapability); |
- |
- /** |
- * Asks the isolate to send a message on [responsePort] when it terminates. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * The isolate will send a `null` message on [responsePort] as the last |
- * thing before it terminates. It will run no further code after the message |
- * has been sent. |
- * |
- * If the isolate is already dead, no message will be sent. |
- */ |
- /* TODO(lrn): Can we do better? Can the system recognize this message and |
- * send a reply if the receiving isolate is dead? |
- */ |
- external void addOnExitListener(SendPort responsePort); |
- |
- /** |
- * Stop listening on exit messages from the isolate. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * If a call has previously been made to [addOnExitListener] with the same |
- * send-port, this will unregister the port, and it will no longer receive |
- * a message when the isolate terminates. |
- * A response may still be sent until this operation is fully processed by |
- * the isolate. |
- */ |
- external void removeOnExitListener(SendPort responsePort); |
- |
- /** |
- * Set whether uncaught errors will terminate the isolate. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * If errors are fatal, any uncaught error will terminate the isolate |
- * event loop and shut down the isolate. |
- * |
- * This call requires the [terminateCapability] for the isolate. |
- * If the capability is not correct, no change is made. |
- */ |
- external void setErrorsFatal(bool errorsAreFatal); |
- |
- /** |
- * Requests the isolate to shut down. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * The isolate is requested to terminate itself. |
- * The [priority] argument specifies when this must happen. |
- * |
- * The [priority] must be one of [IMMEDIATE], [BEFORE_NEXT_EVENT] or |
- * [AS_EVENT]. |
- * The shutdown is performed at different times depending on the priority: |
- * |
- * * `IMMEDIATE`: The isolate shuts down as soon as possible. |
- * Control messages are handled in order, so all previously sent control |
- * events from this isolate will all have been processed. |
- * The shutdown should happen no later than if sent with |
- * `BEFORE_NEXT_EVENT`. |
- * It may happen earlier if the system has a way to shut down cleanly |
- * at an earlier time, even during the execution of another event. |
- * * `BEFORE_NEXT_EVENT`: The shutdown is scheduled for the next time |
- * control returns to the event loop of the receiving isolate, |
- * after the current event, and any already scheduled control events, |
- * are completed. |
- * * `AS_EVENT`: The shutdown does not happen until all prevously sent |
- * non-control messages from the current isolate to the receiving isolate |
- * have been processed. |
- * The kill operation effectively puts the shutdown into the normal event |
- * queue after previously sent messages, and it is affected by any control |
- * messages that affect normal events, including `pause`. |
- * This can be used to wait for a another event to be processed. |
- */ |
- external void kill([int priority = BEFORE_NEXT_EVENT]); |
- |
- /** |
- * Request that the isolate send a response on the [responsePort]. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * If the isolate is alive, it will eventually send a `null` response on |
- * the response port. |
- * |
- * The [pingType] must be one of [IMMEDIATE], [BEFORE_NEXT_EVENT] or |
- * [AS_EVENT]. |
- * The response is sent at different times depending on the ping type: |
- * |
- * * `IMMEDIATE`: The isolate responds as soon as it receives the |
- * control message. This is after any previous control message |
- * from the same isolate has been received. |
- * * `BEFORE_NEXT_EVENT`: The response is scheduled for the next time |
- * control returns to the event loop of the receiving isolate, |
- * after the current event, and any already scheduled control events, |
- * are completed. |
- * * `AS_EVENT`: The response is not sent until all prevously sent |
- * non-control messages from the current isolate to the receiving isolate |
- * have been processed. |
- * The ping effectively puts the response into the normal event queue |
- * after previously sent messages, and it is affected by any control |
- * messages that affect normal events, including `pause`. |
- * This can be used to wait for a another event to be processed. |
- */ |
- external void ping(SendPort responsePort, [int pingType = IMMEDIATE]); |
- |
- /** |
- * Requests that uncaught errors of the isolate are sent back to [port]. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * The errors are sent back as two elements lists. |
- * The first element is a `String` representation of the error, usually |
- * created by calling `toString` on the error. |
- * The second element is a `String` representation of an accompanying |
- * stack trace, or `null` if no stack trace was provided. |
- * |
- * Listening using the same port more than once does nothing. It will only |
- * get each error once. |
- */ |
- external void addErrorListener(SendPort port); |
- |
- /** |
- * Stop listening for uncaught errors through [port]. |
- * |
- * WARNING: This method is experimental and not handled on every platform yet. |
- * |
- * The `port` should be a port that is listening for errors through |
- * [addErrorListener]. This call requests that the isolate stops sending |
- * errors on the port. |
- * |
- * If the same port has been passed via `addErrorListener` more than once, |
- * only one call to `removeErrorListener` is needed to stop it from receiving |
- * errors. |
- * |
- * Closing the receive port at the end of the send port will not stop the |
- * isolate from sending errors, they are just going to be lost. |
- */ |
- external void removeErrorListener(SendPort port); |
- |
- /** |
- * Returns a broadcast stream of uncaught errors from the isolate. |
- * |
- * Each error is provided as an error event on the stream. |
- * |
- * The actual error object and stackTraces will not necessarily |
- * be the same object types as in the actual isolate, but they will |
- * always have the same [Object.toString] result. |
- * |
- * This stream is based on [addErrorListener] and [removeErrorListener]. |
- */ |
- Stream get errors { |
- StreamController controller; |
- RawReceivePort port; |
- void handleError(message) { |
- String errorDescription = message[0]; |
- String stackDescription = message[1]; |
- var error = new RemoteError(errorDescription, stackDescription); |
- controller.addError(error, error.stackTrace); |
- } |
- controller = new StreamController.broadcast( |
- sync: true, |
- onListen: () { |
- port = new RawReceivePort(handleError); |
- this.addErrorListener(port.sendPort); |
- }, |
- onCancel: () { |
- this.removeErrorListener(port.sendPort); |
- port.close(); |
- port = null; |
- }); |
- return controller.stream; |
- } |
-} |
- |
-/** |
- * Sends messages to its [ReceivePort]s. |
- * |
- * [SendPort]s are created from [ReceivePort]s. Any message sent through |
- * a [SendPort] is delivered to its corresponding [ReceivePort]. There might be |
- * many [SendPort]s for the same [ReceivePort]. |
- * |
- * [SendPort]s can be transmitted to other isolates, and they preserve equality |
- * when sent. |
- */ |
-abstract class SendPort implements Capability { |
- |
- /** |
- * Sends an asynchronous [message] through this send port, to its |
- * corresponding `ReceivePort`. |
- * |
- * The content of [message] can be: primitive values (null, num, bool, double, |
- * String), instances of [SendPort], and lists and maps whose elements are any |
- * of these. List and maps are also allowed to be cyclic. |
- * |
- * In the special circumstances when two isolates share the same code and are |
- * running in the same process (e.g. isolates created via [Isolate.spawn]), it |
- * is also possible to send object instances (which would be copied in the |
- * process). This is currently only supported by the dartvm. For now, the |
- * dart2js compiler only supports the restricted messages described above. |
- */ |
- void send(var message); |
- |
- /** |
- * Tests whether [other] is a [SendPort] pointing to the same |
- * [ReceivePort] as this one. |
- */ |
- bool operator==(var other); |
- |
- /** |
- * Returns an immutable hash code for this send port that is |
- * consistent with the == operator. |
- */ |
- int get hashCode; |
-} |
- |
-/** |
- * Together with [SendPort], the only means of communication between isolates. |
- * |
- * [ReceivePort]s have a `sendPort` getter which returns a [SendPort]. |
- * Any message that is sent through this [SendPort] |
- * is delivered to the [ReceivePort] it has been created from. There, the |
- * message is dispatched to the `ReceivePort`'s listener. |
- * |
- * A [ReceivePort] is a non-broadcast stream. This means that it buffers |
- * incoming messages until a listener is registered. Only one listener can |
- * receive messages. See [Stream.asBroadcastStream] for transforming the port |
- * to a broadcast stream. |
- * |
- * A [ReceivePort] may have many [SendPort]s. |
- */ |
-abstract class ReceivePort implements Stream { |
- |
- /** |
- * Opens a long-lived port for receiving messages. |
- * |
- * A [ReceivePort] is a non-broadcast stream. This means that it buffers |
- * incoming messages until a listener is registered. Only one listener can |
- * receive messages. See [Stream.asBroadcastStream] for transforming the port |
- * to a broadcast stream. |
- * |
- * A receive port is closed by canceling its subscription. |
- */ |
- external factory ReceivePort(); |
- |
- /** |
- * Creates a [ReceivePort] from a [RawReceivePort]. |
- * |
- * The handler of the given [rawPort] is overwritten during the construction |
- * of the result. |
- */ |
- external factory ReceivePort.fromRawReceivePort(RawReceivePort rawPort); |
- |
- /** |
- * Inherited from [Stream]. |
- * |
- * Note that [onError] and [cancelOnError] are ignored since a ReceivePort |
- * will never receive an error. |
- * |
- * The [onDone] handler will be called when the stream closes. |
- * The stream closes when [close] is called. |
- */ |
- StreamSubscription listen(void onData(var message), |
- { Function onError, |
- void onDone(), |
- bool cancelOnError }); |
- |
- /** |
- * Closes `this`. |
- * |
- * If the stream has not been canceled yet, adds a close-event to the event |
- * queue and discards any further incoming messages. |
- * |
- * If the stream has already been canceled this method has no effect. |
- */ |
- void close(); |
- |
- /** |
- * Returns a [SendPort] that sends to this receive port. |
- */ |
- SendPort get sendPort; |
-} |
- |
-abstract class RawReceivePort { |
- /** |
- * Opens a long-lived port for receiving messages. |
- * |
- * A [RawReceivePort] is low level and does not work with [Zone]s. It |
- * can not be paused. The data-handler must be set before the first |
- * event is received. |
- */ |
- external factory RawReceivePort([void handler(event)]); |
- |
- /** |
- * Sets the handler that is invoked for every incoming message. |
- * |
- * The handler is invoked in the root-zone ([Zone.ROOT]). |
- */ |
- void set handler(Function newHandler); |
- |
- /** |
- * Closes the port. |
- * |
- * After a call to this method any incoming message is silently dropped. |
- */ |
- void close(); |
- |
- /** |
- * Returns a [SendPort] that sends to this raw receive port. |
- */ |
- SendPort get sendPort; |
-} |
- |
-/** |
- * Wraps unhandled exceptions thrown during isolate execution. It is |
- * used to show both the error message and the stack trace for unhandled |
- * exceptions. |
- */ |
-// TODO(floitsch): probably going to remove and replace with something else. |
-class _IsolateUnhandledException implements Exception { |
- /** Message being handled when exception occurred. */ |
- final message; |
- |
- /** Wrapped exception. */ |
- final source; |
- |
- /** Trace for the wrapped exception. */ |
- final StackTrace stackTrace; |
- |
- const _IsolateUnhandledException(this.message, this.source, this.stackTrace); |
- |
- String toString() { |
- return 'IsolateUnhandledException: exception while handling message: ' |
- '${message} \n ' |
- '${source.toString().replaceAll("\n", "\n ")}\n' |
- 'original stack trace:\n ' |
- '${stackTrace.toString().replaceAll("\n","\n ")}'; |
- } |
-} |
- |
-/** |
- * Description of an error from another isolate. |
- * |
- * This error has the same `toString()` and `stackTrace.toString()` behavior |
- * as the original error, but has no other features of the original error. |
- */ |
-class RemoteError implements Error { |
- final String _description; |
- final StackTrace stackTrace; |
- RemoteError(String description, String stackDescription) |
- : _description = description, |
- stackTrace = new _RemoteStackTrace(stackDescription); |
- String toString() => _description; |
-} |
- |
-class _RemoteStackTrace implements StackTrace { |
- String _trace; |
- _RemoteStackTrace(this._trace); |
- String toString() => _trace; |
-} |