| Index: third_party/google_input_tools/third_party/closure_library/closure/goog/async/run.js
|
| diff --git a/third_party/google_input_tools/third_party/closure_library/closure/goog/async/run.js b/third_party/google_input_tools/third_party/closure_library/closure/goog/async/run.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..001075265f85b086cd4e2abdb8dfb13c380de662
|
| --- /dev/null
|
| +++ b/third_party/google_input_tools/third_party/closure_library/closure/goog/async/run.js
|
| @@ -0,0 +1,150 @@
|
| +// Copyright 2013 The Closure Library Authors. All Rights Reserved.
|
| +//
|
| +// Licensed under the Apache License, Version 2.0 (the "License");
|
| +// you may not use this file except in compliance with the License.
|
| +// You may obtain a copy of the License at
|
| +//
|
| +// http://www.apache.org/licenses/LICENSE-2.0
|
| +//
|
| +// Unless required by applicable law or agreed to in writing, software
|
| +// distributed under the License is distributed on an "AS-IS" BASIS,
|
| +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
| +// See the License for the specific language governing permissions and
|
| +// limitations under the License.
|
| +
|
| +goog.provide('goog.async.run');
|
| +
|
| +goog.require('goog.async.nextTick');
|
| +goog.require('goog.async.throwException');
|
| +goog.require('goog.testing.watchers');
|
| +
|
| +
|
| +/**
|
| + * Fires the provided callback just before the current callstack unwinds, or as
|
| + * soon as possible after the current JS execution context.
|
| + * @param {function(this:THIS)} callback
|
| + * @param {THIS=} opt_context Object to use as the "this value" when calling
|
| + * the provided function.
|
| + * @template THIS
|
| + */
|
| +goog.async.run = function(callback, opt_context) {
|
| + if (!goog.async.run.schedule_) {
|
| + goog.async.run.initializeRunner_();
|
| + }
|
| + if (!goog.async.run.workQueueScheduled_) {
|
| + // Nothing is currently scheduled, schedule it now.
|
| + goog.async.run.schedule_();
|
| + goog.async.run.workQueueScheduled_ = true;
|
| + }
|
| +
|
| + goog.async.run.workQueue_.push(
|
| + new goog.async.run.WorkItem_(callback, opt_context));
|
| +};
|
| +
|
| +
|
| +/**
|
| + * Initializes the function to use to process the work queue.
|
| + * @private
|
| + */
|
| +goog.async.run.initializeRunner_ = function() {
|
| + // If native Promises are available in the browser, just schedule the callback
|
| + // on a fulfilled promise, which is specified to be async, but as fast as
|
| + // possible.
|
| + if (goog.global.Promise && goog.global.Promise.resolve) {
|
| + var promise = goog.global.Promise.resolve();
|
| + goog.async.run.schedule_ = function() {
|
| + promise.then(goog.async.run.processWorkQueue);
|
| + };
|
| + } else {
|
| + goog.async.run.schedule_ = function() {
|
| + goog.async.nextTick(goog.async.run.processWorkQueue);
|
| + };
|
| + }
|
| +};
|
| +
|
| +
|
| +/**
|
| + * Forces goog.async.run to use nextTick instead of Promise.
|
| + *
|
| + * This should only be done in unit tests. It's useful because MockClock
|
| + * replaces nextTick, but not the browser Promise implementation, so it allows
|
| + * Promise-based code to be tested with MockClock.
|
| + */
|
| +goog.async.run.forceNextTick = function() {
|
| + goog.async.run.schedule_ = function() {
|
| + goog.async.nextTick(goog.async.run.processWorkQueue);
|
| + };
|
| +};
|
| +
|
| +
|
| +/**
|
| + * The function used to schedule work asynchronousely.
|
| + * @private {function()}
|
| + */
|
| +goog.async.run.schedule_;
|
| +
|
| +
|
| +/** @private {boolean} */
|
| +goog.async.run.workQueueScheduled_ = false;
|
| +
|
| +
|
| +/** @private {!Array.<!goog.async.run.WorkItem_>} */
|
| +goog.async.run.workQueue_ = [];
|
| +
|
| +
|
| +if (goog.DEBUG) {
|
| + /**
|
| + * Reset the event queue.
|
| + * @private
|
| + */
|
| + goog.async.run.resetQueue_ = function() {
|
| + goog.async.run.workQueueScheduled_ = false;
|
| + goog.async.run.workQueue_ = [];
|
| + };
|
| +
|
| + // If there is a clock implemenation in use for testing
|
| + // and it is reset, reset the queue.
|
| + goog.testing.watchers.watchClockReset(goog.async.run.resetQueue_);
|
| +}
|
| +
|
| +
|
| +/**
|
| + * Run any pending goog.async.run work items. This function is not intended
|
| + * for general use, but for use by entry point handlers to run items ahead of
|
| + * goog.async.nextTick.
|
| + */
|
| +goog.async.run.processWorkQueue = function() {
|
| + // NOTE: additional work queue items may be pushed while processing.
|
| + while (goog.async.run.workQueue_.length) {
|
| + // Don't let the work queue grow indefinitely.
|
| + var workItems = goog.async.run.workQueue_;
|
| + goog.async.run.workQueue_ = [];
|
| + for (var i = 0; i < workItems.length; i++) {
|
| + var workItem = workItems[i];
|
| + try {
|
| + workItem.fn.call(workItem.scope);
|
| + } catch (e) {
|
| + goog.async.throwException(e);
|
| + }
|
| + }
|
| + }
|
| +
|
| + // There are no more work items, reset the work queue.
|
| + goog.async.run.workQueueScheduled_ = false;
|
| +};
|
| +
|
| +
|
| +
|
| +/**
|
| + * @constructor
|
| + * @final
|
| + * @struct
|
| + * @private
|
| + *
|
| + * @param {function()} fn
|
| + * @param {Object|null|undefined} scope
|
| + */
|
| +goog.async.run.WorkItem_ = function(fn, scope) {
|
| + /** @const */ this.fn = fn;
|
| + /** @const */ this.scope = scope;
|
| +};
|
|
|