| Index: third_party/google_input_tools/third_party/closure_library/closure/goog/debug/entrypointregistry.js
|
| diff --git a/third_party/google_input_tools/third_party/closure_library/closure/goog/debug/entrypointregistry.js b/third_party/google_input_tools/third_party/closure_library/closure/goog/debug/entrypointregistry.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..9394f7f5dc095d5fa2594b4aa03bc33f737408f1
|
| --- /dev/null
|
| +++ b/third_party/google_input_tools/third_party/closure_library/closure/goog/debug/entrypointregistry.js
|
| @@ -0,0 +1,158 @@
|
| +// Copyright 2010 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.
|
| +
|
| +/**
|
| + * @fileoverview A global registry for entry points into a program,
|
| + * so that they can be instrumented. Each module should register their
|
| + * entry points with this registry. Designed to be compiled out
|
| + * if no instrumentation is requested.
|
| + *
|
| + * Entry points may be registered before or after a call to
|
| + * goog.debug.entryPointRegistry.monitorAll. If an entry point is registered
|
| + * later, the existing monitor will instrument the new entry point.
|
| + *
|
| + * @author nicksantos@google.com (Nick Santos)
|
| + */
|
| +
|
| +goog.provide('goog.debug.EntryPointMonitor');
|
| +goog.provide('goog.debug.entryPointRegistry');
|
| +
|
| +goog.require('goog.asserts');
|
| +
|
| +
|
| +
|
| +/**
|
| + * @interface
|
| + */
|
| +goog.debug.EntryPointMonitor = function() {};
|
| +
|
| +
|
| +/**
|
| + * Instruments a function.
|
| + *
|
| + * @param {!Function} fn A function to instrument.
|
| + * @return {!Function} The instrumented function.
|
| + */
|
| +goog.debug.EntryPointMonitor.prototype.wrap;
|
| +
|
| +
|
| +/**
|
| + * Try to remove an instrumentation wrapper created by this monitor.
|
| + * If the function passed to unwrap is not a wrapper created by this
|
| + * monitor, then we will do nothing.
|
| + *
|
| + * Notice that some wrappers may not be unwrappable. For example, if other
|
| + * monitors have applied their own wrappers, then it will be impossible to
|
| + * unwrap them because their wrappers will have captured our wrapper.
|
| + *
|
| + * So it is important that entry points are unwrapped in the reverse
|
| + * order that they were wrapped.
|
| + *
|
| + * @param {!Function} fn A function to unwrap.
|
| + * @return {!Function} The unwrapped function, or {@code fn} if it was not
|
| + * a wrapped function created by this monitor.
|
| + */
|
| +goog.debug.EntryPointMonitor.prototype.unwrap;
|
| +
|
| +
|
| +/**
|
| + * An array of entry point callbacks.
|
| + * @type {!Array.<function(!Function)>}
|
| + * @private
|
| + */
|
| +goog.debug.entryPointRegistry.refList_ = [];
|
| +
|
| +
|
| +/**
|
| + * Monitors that should wrap all the entry points.
|
| + * @type {!Array.<!goog.debug.EntryPointMonitor>}
|
| + * @private
|
| + */
|
| +goog.debug.entryPointRegistry.monitors_ = [];
|
| +
|
| +
|
| +/**
|
| + * Whether goog.debug.entryPointRegistry.monitorAll has ever been called.
|
| + * Checking this allows the compiler to optimize out the registrations.
|
| + * @type {boolean}
|
| + * @private
|
| + */
|
| +goog.debug.entryPointRegistry.monitorsMayExist_ = false;
|
| +
|
| +
|
| +/**
|
| + * Register an entry point with this module.
|
| + *
|
| + * The entry point will be instrumented when a monitor is passed to
|
| + * goog.debug.entryPointRegistry.monitorAll. If this has already occurred, the
|
| + * entry point is instrumented immediately.
|
| + *
|
| + * @param {function(!Function)} callback A callback function which is called
|
| + * with a transforming function to instrument the entry point. The callback
|
| + * is responsible for wrapping the relevant entry point with the
|
| + * transforming function.
|
| + */
|
| +goog.debug.entryPointRegistry.register = function(callback) {
|
| + // Don't use push(), so that this can be compiled out.
|
| + goog.debug.entryPointRegistry.refList_[
|
| + goog.debug.entryPointRegistry.refList_.length] = callback;
|
| + // If no one calls monitorAll, this can be compiled out.
|
| + if (goog.debug.entryPointRegistry.monitorsMayExist_) {
|
| + var monitors = goog.debug.entryPointRegistry.monitors_;
|
| + for (var i = 0; i < monitors.length; i++) {
|
| + callback(goog.bind(monitors[i].wrap, monitors[i]));
|
| + }
|
| + }
|
| +};
|
| +
|
| +
|
| +/**
|
| + * Configures a monitor to wrap all entry points.
|
| + *
|
| + * Entry points that have already been registered are immediately wrapped by
|
| + * the monitor. When an entry point is registered in the future, it will also
|
| + * be wrapped by the monitor when it is registered.
|
| + *
|
| + * @param {!goog.debug.EntryPointMonitor} monitor An entry point monitor.
|
| + */
|
| +goog.debug.entryPointRegistry.monitorAll = function(monitor) {
|
| + goog.debug.entryPointRegistry.monitorsMayExist_ = true;
|
| + var transformer = goog.bind(monitor.wrap, monitor);
|
| + for (var i = 0; i < goog.debug.entryPointRegistry.refList_.length; i++) {
|
| + goog.debug.entryPointRegistry.refList_[i](transformer);
|
| + }
|
| + goog.debug.entryPointRegistry.monitors_.push(monitor);
|
| +};
|
| +
|
| +
|
| +/**
|
| + * Try to unmonitor all the entry points that have already been registered. If
|
| + * an entry point is registered in the future, it will not be wrapped by the
|
| + * monitor when it is registered. Note that this may fail if the entry points
|
| + * have additional wrapping.
|
| + *
|
| + * @param {!goog.debug.EntryPointMonitor} monitor The last monitor to wrap
|
| + * the entry points.
|
| + * @throws {Error} If the monitor is not the most recently configured monitor.
|
| + */
|
| +goog.debug.entryPointRegistry.unmonitorAllIfPossible = function(monitor) {
|
| + var monitors = goog.debug.entryPointRegistry.monitors_;
|
| + goog.asserts.assert(monitor == monitors[monitors.length - 1],
|
| + 'Only the most recent monitor can be unwrapped.');
|
| + var transformer = goog.bind(monitor.unwrap, monitor);
|
| + for (var i = 0; i < goog.debug.entryPointRegistry.refList_.length; i++) {
|
| + goog.debug.entryPointRegistry.refList_[i](transformer);
|
| + }
|
| + monitors.length--;
|
| +};
|
|
|