blob: b28f64f348f3c751b05a765bdac0e602cf3b77cf [file] [log] [blame]
/**
* @license
* Copyright 2017 The Bazel 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
* Provides APIs for extending TypeScript.
* Based on the LanguageService plugin API in TS 2.3
*/
import * as ts from 'typescript';
/**
* This API is simpler than LanguageService plugins.
* It's used for plugins that only target the command-line and never run in an
* editor context.
* IMPORTANT: plugins must propagate the diagnostics from the original program.
* Execution of plugins is not additive; only the result from the top-most
* wrapped Program is used.
*/
export interface TscPlugin { wrap(p: ts.Program, config?: {}): ts.Program; }
// TODO(alexeagle): this should be unioned with tsserverlibrary.PluginModule
export type Plugin = TscPlugin;
/**
* The proxy design pattern, allowing us to customize behavior of the delegate
* object.
* This creates a property-by-property copy of the object, so it can be mutated
* without affecting other users of the original object.
* See https://en.wikipedia.org/wiki/Proxy_pattern
*/
export function createProxy<T>(delegate: T): T {
const proxy = Object.create(null);
for (const k of Object.keys(delegate)) {
proxy[k] = function() {
return (delegate as any)[k].apply(delegate, arguments);
};
}
return proxy;
}