mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-06 09:35:41 -05:00
243 lines
6.5 KiB
TypeScript
243 lines
6.5 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { areSameExtensions } from 'vs/platform/extensionManagement/common/extensionManagementUtil';
|
|
import * as strings from 'vs/base/common/strings';
|
|
import { ILocalization } from 'vs/platform/localizations/common/localizations';
|
|
import { URI } from 'vs/base/common/uri';
|
|
|
|
export const MANIFEST_CACHE_FOLDER = 'CachedExtensions';
|
|
export const USER_MANIFEST_CACHE_FILE = 'user';
|
|
export const BUILTIN_MANIFEST_CACHE_FILE = 'builtin';
|
|
|
|
export interface ICommand {
|
|
command: string;
|
|
title: string;
|
|
category?: string;
|
|
}
|
|
|
|
export interface IConfigurationProperty {
|
|
description: string;
|
|
type: string | string[];
|
|
default?: any;
|
|
}
|
|
|
|
export interface IConfiguration {
|
|
properties: { [key: string]: IConfigurationProperty; };
|
|
}
|
|
|
|
export interface IDebugger {
|
|
label?: string;
|
|
type: string;
|
|
runtime?: string;
|
|
}
|
|
|
|
export interface IGrammar {
|
|
language: string;
|
|
}
|
|
|
|
export interface IJSONValidation {
|
|
fileMatch: string;
|
|
url: string;
|
|
}
|
|
|
|
export interface IKeyBinding {
|
|
command: string;
|
|
key: string;
|
|
when?: string;
|
|
mac?: string;
|
|
linux?: string;
|
|
win?: string;
|
|
}
|
|
|
|
export interface ILanguage {
|
|
id: string;
|
|
extensions: string[];
|
|
aliases: string[];
|
|
}
|
|
|
|
export interface IMenu {
|
|
command: string;
|
|
alt?: string;
|
|
when?: string;
|
|
group?: string;
|
|
}
|
|
|
|
export interface ISnippet {
|
|
language: string;
|
|
}
|
|
|
|
export interface ITheme {
|
|
label: string;
|
|
}
|
|
|
|
export interface IViewContainer {
|
|
id: string;
|
|
title: string;
|
|
}
|
|
|
|
export interface IView {
|
|
id: string;
|
|
name: string;
|
|
}
|
|
|
|
export interface IColor {
|
|
id: string;
|
|
description: string;
|
|
defaults: { light: string, dark: string, highContrast: string };
|
|
}
|
|
|
|
export interface IExtensionContributions {
|
|
commands?: ICommand[];
|
|
configuration?: IConfiguration | IConfiguration[];
|
|
debuggers?: IDebugger[];
|
|
grammars?: IGrammar[];
|
|
jsonValidation?: IJSONValidation[];
|
|
keybindings?: IKeyBinding[];
|
|
languages?: ILanguage[];
|
|
menus?: { [context: string]: IMenu[] };
|
|
snippets?: ISnippet[];
|
|
themes?: ITheme[];
|
|
iconThemes?: ITheme[];
|
|
viewsContainers?: { [location: string]: IViewContainer[] };
|
|
views?: { [location: string]: IView[] };
|
|
colors?: IColor[];
|
|
localizations?: ILocalization[];
|
|
}
|
|
|
|
export type ExtensionKind = 'ui' | 'workspace';
|
|
|
|
export class ExtensionIdentifierWithVersion {
|
|
constructor(
|
|
readonly identifier: IExtensionIdentifier,
|
|
readonly version: string
|
|
) { }
|
|
|
|
key(): string {
|
|
return `${this.identifier.id}-${this.version}`;
|
|
}
|
|
|
|
equals(o: any): boolean {
|
|
if (!(o instanceof ExtensionIdentifierWithVersion)) {
|
|
return false;
|
|
}
|
|
return areSameExtensions(this.identifier, o.identifier) && this.version === o.version;
|
|
}
|
|
}
|
|
|
|
export function isIExtensionIdentifier(thing: any): thing is IExtensionIdentifier {
|
|
return thing
|
|
&& typeof thing === 'object'
|
|
&& typeof thing.id === 'string'
|
|
&& (!thing.uuid || typeof thing.uuid === 'string');
|
|
}
|
|
|
|
export interface IExtensionIdentifier {
|
|
id: string;
|
|
uuid?: string;
|
|
}
|
|
|
|
export interface IExtensionManifest {
|
|
readonly name: string;
|
|
readonly displayName?: string;
|
|
readonly publisher: string;
|
|
readonly version: string;
|
|
// {{SQL CARBON EDIT}}
|
|
engines: { vscode: string; azdata?: string };
|
|
readonly description?: string;
|
|
readonly main?: string;
|
|
readonly icon?: string;
|
|
readonly categories?: string[];
|
|
readonly keywords?: string[];
|
|
readonly activationEvents?: string[];
|
|
readonly extensionDependencies?: string[];
|
|
readonly extensionPack?: string[];
|
|
readonly extensionKind?: ExtensionKind;
|
|
readonly contributes?: IExtensionContributions;
|
|
readonly repository?: { url: string; };
|
|
readonly bugs?: { url: string; };
|
|
readonly enableProposedApi?: boolean;
|
|
readonly api?: string;
|
|
}
|
|
|
|
export const enum ExtensionType {
|
|
System,
|
|
User
|
|
}
|
|
|
|
export interface IExtension {
|
|
readonly type: ExtensionType;
|
|
readonly identifier: IExtensionIdentifier;
|
|
readonly manifest: IExtensionManifest;
|
|
readonly location: URI;
|
|
}
|
|
|
|
/**
|
|
* **!Do not construct directly!**
|
|
*
|
|
* **!Only static methods because it gets serialized!**
|
|
*
|
|
* This represents the "canonical" version for an extension identifier. Extension ids
|
|
* have to be case-insensitive (due to the marketplace), but we must ensure case
|
|
* preservation because the extension API is already public at this time.
|
|
*
|
|
* For example, given an extension with the publisher `"Hello"` and the name `"World"`,
|
|
* its canonical extension identifier is `"Hello.World"`. This extension could be
|
|
* referenced in some other extension's dependencies using the string `"hello.world"`.
|
|
*
|
|
* To make matters more complicated, an extension can optionally have an UUID. When two
|
|
* extensions have the same UUID, they are considered equal even if their identifier is different.
|
|
*/
|
|
export class ExtensionIdentifier {
|
|
public readonly value: string;
|
|
private readonly _lower: string;
|
|
|
|
constructor(value: string) {
|
|
this.value = value;
|
|
this._lower = value.toLowerCase();
|
|
}
|
|
|
|
public static equals(a: ExtensionIdentifier | string | null | undefined, b: ExtensionIdentifier | string | null | undefined) {
|
|
if (typeof a === 'undefined' || a === null) {
|
|
return (typeof b === 'undefined' || b === null);
|
|
}
|
|
if (typeof b === 'undefined' || b === null) {
|
|
return false;
|
|
}
|
|
if (typeof a === 'string' || typeof b === 'string') {
|
|
// At least one of the arguments is an extension id in string form,
|
|
// so we have to use the string comparison which ignores case.
|
|
let aValue = (typeof a === 'string' ? a : a.value);
|
|
let bValue = (typeof b === 'string' ? b : b.value);
|
|
return strings.equalsIgnoreCase(aValue, bValue);
|
|
}
|
|
|
|
// Now we know both arguments are ExtensionIdentifier
|
|
return (a._lower === b._lower);
|
|
}
|
|
|
|
/**
|
|
* Gives the value by which to index (for equality).
|
|
*/
|
|
public static toKey(id: ExtensionIdentifier | string): string {
|
|
if (typeof id === 'string') {
|
|
return id.toLowerCase();
|
|
}
|
|
return id._lower;
|
|
}
|
|
}
|
|
|
|
export interface IExtensionDescription extends IExtensionManifest {
|
|
readonly identifier: ExtensionIdentifier;
|
|
readonly uuid?: string;
|
|
readonly isBuiltin: boolean;
|
|
readonly isUnderDevelopment: boolean;
|
|
readonly extensionLocation: URI;
|
|
enableProposedApi?: boolean;
|
|
}
|
|
|
|
export function isLanguagePackExtension(manifest: IExtensionManifest): boolean {
|
|
return manifest.contributes && manifest.contributes.localizations ? manifest.contributes.localizations.length > 0 : false;
|
|
} |