Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | |
| 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. | |
| 4 | |
| 5 part of dart.async; | |
| 6 | |
| 7 typedef void _AsyncCallback(); | |
| 8 | |
| 9 bool _callbacksAreEnqueued = false; | |
| 10 List<_AsyncCallback> _asyncCallbacks = <_AsyncCallback>[]; | |
| 11 | |
| 12 void _asyncRunCallback() { | |
| 13 // As long as we are iterating over the registered callbacks we don't | |
| 14 // unset the [_callbacksAreEnqueued] boolean. | |
| 15 while (!_asyncCallbacks.isEmpty) { | |
| 16 List callbacks = _asyncCallbacks; | |
| 17 // Create a new list, to avoid that the we grow too much if the callbacks | |
|
siva
2013/03/07 02:39:17
This comment does not read well.
floitsch
2013/03/08 20:04:41
done.
| |
| 18 // add new callbacks themselves. | |
| 19 _asyncCallbacks = <_AsyncCallback>[]; | |
| 20 for (int i = 0; i < callbacks.length; i++) { | |
| 21 Function callback = callbacks[i]; | |
| 22 callbacks[i] = null; | |
| 23 try { | |
| 24 callback(); | |
| 25 } catch (e) { | |
| 26 List remainingCallbacks = | |
| 27 _asyncCallbacks.getRange(i + 1, _asyncCallbacks.length - i + 1); | |
|
siva
2013/03/07 02:39:17
shouldn't this be:
List remainingCallbacks = callb
floitsch
2013/03/08 20:04:41
Done.
| |
| 28 List newCallbacks = _asyncCallbacks; | |
| 29 _asyncCallbacks = <_AsyncCallback>[]; | |
| 30 _asyncCallbacks.addAll(remainingCallbacks); | |
| 31 _asyncCallbacks.addAll(newCallbacks); | |
| 32 _AsyncRun._enqueueImmediate(_asyncRunCallback); | |
| 33 throw; | |
| 34 } | |
| 35 } | |
| 36 } | |
| 37 // Any new callback must register a callback function now. | |
| 38 _callbacksAreEnqueued = false; | |
| 39 } | |
| 40 | |
| 41 /** | |
| 42 * Runs the given [callback] asynchronously. | |
| 43 * | |
| 44 * Callbacks register through this function are always executed in order and | |
|
siva
2013/03/07 02:39:17
registered
floitsch
2013/03/08 20:04:41
Done.
| |
| 45 * are guaranteed to run before other asynchronous events (like [Timer] events, | |
| 46 * or DOM events). | |
| 47 * | |
| 48 * Warning: it is possible to starve the DOM by registering asynchronous | |
| 49 * callbacks through this method. For example the following program will | |
| 50 * run the callbacks without ever giving the Timer callback a chance to execute: | |
| 51 * | |
| 52 * Timer.run(() { print("executed"); }); // Will never be executed; | |
| 53 * foo() { | |
| 54 * asyncRun(foo); // Schedules [foo] in front of other events. | |
| 55 * } | |
| 56 * main() { | |
| 57 * foo(); | |
| 58 * } | |
| 59 */ | |
| 60 void runAsync(void callback()) { | |
| 61 // Optimizing a group of Timer.run callbacks to be executed in the | |
| 62 // same Timer callback. | |
| 63 _asyncCallbacks.add(callback); | |
| 64 if (!_callbacksAreEnqueued) { | |
| 65 _AsyncRun._enqueueImmediate(_asyncRunCallback); | |
| 66 _callbacksAreEnqueued = true; | |
| 67 } | |
| 68 } | |
| 69 | |
| 70 class _AsyncRun { | |
| 71 /** Enqueues the given callback before any other event in the event-loop. */ | |
| 72 external static void _enqueueImmediate(void callback()); | |
| 73 } | |
| OLD | NEW |